trait ByteReader extends AutoCloseable
A ByteReader provides a stateful API to extract bytes from an underlying buffer, which in most cases is a Buf. This conveniently allows codec implementations to decode frames, specifically when they need to decode and interpret the bytes as a numeric value.
- Note
- Unless otherwise stated, ByteReader implementations are not thread safe. 
- Alphabetic
- By Inheritance
- ByteReader
- AutoCloseable
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Abstract Value Members
-   abstract  def close(): Unit- Definition Classes
- AutoCloseable
- Annotations
- @throws(classOf[java.lang.Exception])
 
-   abstract  def process(from: Int, until: Int, processor: Processor): IntProcess the underlying buffer 1-byte at a time using the given Buf.Processor, starting at index fromof the underlying buffer until indexuntilof the underlying buffer.Process the underlying buffer 1-byte at a time using the given Buf.Processor, starting at index fromof the underlying buffer until indexuntilof the underlying buffer. Processing will halt if the processor returnsfalseor after processing the final byte.- from
- the starting index, inclusive. Must be non-negative. 
- until
- the ending index, exclusive. Must be non-negative. 
- returns
- -1 if the processor processed all bytes or the last processed index if the processor returns - false. Will return -1 if- fromis greater than or equal to- untilor- lengthof the underlying buffer. Will return -1 if- untilis greater than or equal to- lengthof the underlying buffer.
 - Note
- this does not advance the byte cursor. 
 
-   abstract  def process(processor: Processor): IntProcess the underlying buffer 1-byte at a time using the given Buf.Processor, starting at index 0of the underlying buffer until indexlengthof the underlying buffer.Process the underlying buffer 1-byte at a time using the given Buf.Processor, starting at index 0of the underlying buffer until indexlengthof the underlying buffer. Processing will halt if the processor returnsfalseor after processing the final byte.- returns
- -1 if the processor processed all bytes or the last processed index if the processor returns - false.
 - Note
- this does not advance the byte cursor. 
 
-   abstract  def readAll(): BufLike read, but extracts the remainder of bytes from cursor to the length.Like read, but extracts the remainder of bytes from cursor to the length. Note, this advances the cursor to the end of the buf.
-   abstract  def readByte(): ByteExtract 8 bits and interpret as a signed integer, advancing the byte cursor by 1. 
-   abstract  def readBytes(n: Int): BufReturns a new buffer representing a slice of this buffer, delimited by the indices [cursor, remaining).Returns a new buffer representing a slice of this buffer, delimited by the indices [cursor, remaining). Out of bounds indices are truncated. Negative indices are not accepted.
-   abstract  def readDoubleBE(): DoubleExtract 64 bits and interpret as a big endian floating point, advancing the byte cursor by 4. 
-   abstract  def readDoubleLE(): DoubleExtract 64 bits and interpret as a little endian floating point, advancing the byte cursor by 4. 
-   abstract  def readFloatBE(): FloatExtract 32 bits and interpret as a big endian floating point, advancing the byte cursor by 4. 
-   abstract  def readFloatLE(): FloatExtract 32 bits and interpret as a little endian floating point, advancing the byte cursor by 4. 
-   abstract  def readIntBE(): IntExtract 32 bits and interpret as a big endian integer, advancing the byte cursor by 4. 
-   abstract  def readIntLE(): IntExtract 32 bits and interpret as a little endian int, advancing the byte cursor by 4. 
-   abstract  def readLongBE(): LongExtract 64 bits and interpret as a big endian integer, advancing the byte cursor by 8. 
-   abstract  def readLongLE(): LongExtract 64 bits and interpret as a little endian integer, advancing the byte cursor by 8. 
-   abstract  def readMediumBE(): IntExtract 24 bits and interpret as a big endian integer, advancing the byte cursor by 3. 
-   abstract  def readMediumLE(): IntExtract 24 bits and interpret as a little endian integer, advancing the byte cursor by 3. 
-   abstract  def readShortBE(): ShortExtract 16 bits and interpret as a big endian integer, advancing the byte cursor by 2. 
-   abstract  def readShortLE(): ShortExtract 16 bits and interpret as a little endian integer, advancing the byte cursor by 2. 
-   abstract  def readString(bytes: Int, charset: Charset): StringExtract exactly the specified number of bytes into a Stringusing the specifiedCharset, advancing the byte cursor bybytes.Extract exactly the specified number of bytes into a Stringusing the specifiedCharset, advancing the byte cursor bybytes.- Exceptions thrown
- ByteReader.UnderflowExceptionif there are <- bytesbytes available
 
-   abstract  def readUnsignedByte(): ShortExtract 8 bits and interpret as an unsigned integer, advancing the byte cursor by 1. 
-   abstract  def readUnsignedIntBE(): LongExtract 32 bits and interpret as a big endian unsigned integer, advancing the byte cursor by 4. 
-   abstract  def readUnsignedIntLE(): LongExtract 32 bits and interpret as a little endian unsigned integer, advancing the byte cursor by 4. 
-   abstract  def readUnsignedLongBE(): BigIntExtract 64 bits and interpret as a big endian unsigned integer, advancing the byte cursor by 8. 
-   abstract  def readUnsignedLongLE(): BigIntExtract 64 bits and interpret as a little endian unsigned integer, advancing the byte cursor by 8. 
-   abstract  def readUnsignedMediumBE(): IntExtract 24 bits and interpret as a big endian unsigned integer, advancing the byte cursor by 3. 
-   abstract  def readUnsignedMediumLE(): IntExtract 24 bits and interpret as a little endian unsigned integer, advancing the byte cursor by 3. 
-   abstract  def readUnsignedShortBE(): IntExtract 16 bits and interpret as a big endian unsigned integer, advancing the byte cursor by 2. 
-   abstract  def readUnsignedShortLE(): IntExtract 16 bits and interpret as a little endian unsigned integer, advancing the byte cursor by 2. 
-   abstract  def remaining: IntThe remainder of bytes that the reader is capable of reading. 
-   abstract  def remainingUntil(byte: Byte): IntThe remainder of bytes until the first occurrence of byte(exclusive).The remainder of bytes until the first occurrence of byte(exclusive). Returns-1whenbyteis not found on the underlying resource.- Note
- All util and finagle Buf implementations will not copy onto the heap, but for other implementations, it may trigger a copy. 
 
-   abstract  def skip(n: Int): UnitSkip over the next nbytes.Skip over the next nbytes.- Exceptions thrown
- ByteReader.UnderflowExceptionif there are <- nbytes available
 
Concrete Value Members
-   final  def !=(arg0: Any): Boolean- Definition Classes
- AnyRef → Any
 
-   final  def ##: Int- Definition Classes
- AnyRef → Any
 
-   final  def ==(arg0: Any): Boolean- Definition Classes
- AnyRef → Any
 
-   final  def asInstanceOf[T0]: T0- Definition Classes
- Any
 
-    def clone(): AnyRef- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.CloneNotSupportedException]) @native()
 
-   final  def eq(arg0: AnyRef): Boolean- Definition Classes
- AnyRef
 
-    def equals(arg0: AnyRef): Boolean- Definition Classes
- AnyRef → Any
 
-    def finalize(): Unit- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable])
 
-   final  def getClass(): Class[_ <: AnyRef]- Definition Classes
- AnyRef → Any
- Annotations
- @native()
 
-    def hashCode(): Int- Definition Classes
- AnyRef → Any
- Annotations
- @native()
 
-   final  def isInstanceOf[T0]: Boolean- Definition Classes
- Any
 
-   final  def ne(arg0: AnyRef): Boolean- Definition Classes
- AnyRef
 
-   final  def notify(): Unit- Definition Classes
- AnyRef
- Annotations
- @native()
 
-   final  def notifyAll(): Unit- Definition Classes
- AnyRef
- Annotations
- @native()
 
-   final  def synchronized[T0](arg0: => T0): T0- Definition Classes
- AnyRef
 
-    def toString(): String- Definition Classes
- AnyRef → Any
 
-   final  def wait(): Unit- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
 
-   final  def wait(arg0: Long, arg1: Int): Unit- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
 
-   final  def wait(arg0: Long): Unit- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException]) @native()