Documentation

Mathlib.Deprecated.ByteArray

Main result #

Introduce main properties of Up (well-ordered relation for "upwards" induction on ) and of ByteArray

This entire file has been deprecated on 2024-08-19 in favour of ByteSubarray in Batteries.

@[deprecated "No deprecation message was provided." (since := "2024-08-19")]
def Nat.Up (ub a i : Nat) :

A well-ordered relation for "upwards" induction on the natural numbers up to some bound ub.

Equations
  • ub.Up a i = (i < a i < ub)
Instances For
    theorem Nat.Up.next {ub i : Nat} (h : i < ub) :
    ub.Up (i + 1) i
    theorem Nat.Up.WF (ub : Nat) :
    @[deprecated "No deprecation message was provided." (since := "2024-08-19")]

    A well-ordered relation for "upwards" induction on the natural numbers up to some bound ub.

    Equations
    • ub.upRel = { rel := ub.Up, wf := }
    Instances For
      @[deprecated "No deprecation message was provided." (since := "2024-08-19")]
      structure ByteSliceT :

      A terminal byte slice, a suffix of a byte array.

      Instances For
        @[inline]

        The number of elements in the byte slice.

        Equations
        • self.size = self.arr.size - self.off
        Instances For
          @[inline]
          def ByteSliceT.getOp (self : ByteSliceT) (idx : Nat) :

          Index into a byte slice. The getOp function allows the use of the buf[i] notation.

          Equations
          • self.getOp idx = self.arr.get! (self.off + idx)
          Instances For

            Convert a byte array into a terminal slice.

            Equations
            • arr.toSliceT = { arr := arr, off := 0 }
            Instances For
              @[deprecated Batteries.ByteSubarray (since := "2024-08-19")]
              structure ByteSlice :

              A byte slice, given by a backing byte array, and an offset and length.

              Instances For

                Convert a byte slice into an array, by copying the data if necessary.

                Equations
                • { arr := arr, off := off, len := len }.toArray = arr.extract off len
                Instances For
                  @[inline]
                  def ByteSlice.getOp (self : ByteSlice) (idx : Nat) :

                  Index into a byte slice. The getOp function allows the use of the buf[i] notation.

                  Equations
                  • self.getOp idx = self.arr.get! (self.off + idx)
                  Instances For
                    @[irreducible, deprecated "No deprecation message was provided." (since := "2024-08-19")]
                    def ByteSlice.forIn.loop {m : Type u → Type v} {β : Type u} [Monad m] (f : UInt8βm (ForInStep β)) (arr : ByteArray) (off _end i : Nat) (b : β) :
                    m β

                    The inner loop of the forIn implementation for byte slices.

                    Equations
                    • One or more equations did not get rendered due to their size.
                    Instances For
                      @[deprecated "No deprecation message was provided." (since := "2024-08-19")]
                      Equations
                      • One or more equations did not get rendered due to their size.

                      Convert a terminal byte slice into a regular byte slice.

                      Equations
                      • { arr := arr, off := off }.toSlice = { arr := arr, off := off, len := arr.size - off }
                      Instances For

                        Convert a byte array into a byte slice.

                        Equations
                        • arr.toSlice = { arr := arr, off := 0, len := arr.size }
                        Instances For

                          Convert a byte slice into a string. This does not handle non-ASCII characters correctly: every byte will become a unicode character with codepoint < 256.

                          Equations
                          • One or more equations did not get rendered due to their size.
                          Instances For
                            Equations
                            • One or more equations did not get rendered due to their size.