Package akka.protobuf
Class CodedInputStream
- java.lang.Object
- 
- akka.protobuf.CodedInputStream
 
- 
 public final class CodedInputStream extends java.lang.ObjectReads and decodes protocol message fields. This class contains two kinds of methods: methods that read specific protocol message constructs and field types (e.g.readTag()andreadInt32()) and methods that read low-level values (e.g.readRawVarint32()andreadRawBytes(int)). If you are reading encoded protocol messages, you should use the former methods, but if you are reading some other format of your own design, use the latter.
- 
- 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidcheckLastTagWas(int value)Verifies that the last call to readTag() returned the given tag value.static intdecodeZigZag32(int n)Decode a ZigZag-encoded 32-bit value.static longdecodeZigZag64(long n)Decode a ZigZag-encoded 64-bit value.intgetBytesUntilLimit()Returns the number of bytes to be read before the current limit.intgetTotalBytesRead()The total bytes read up to the current position.booleanisAtEnd()Returns true if the stream has reached the end of the input.static CodedInputStreamnewInstance(byte[] buf)Create a new CodedInputStream wrapping the given byte array.static CodedInputStreamnewInstance(byte[] buf, int off, int len)Create a new CodedInputStream wrapping the given byte array slice.static CodedInputStreamnewInstance(java.io.InputStream input)Create a new CodedInputStream wrapping the given InputStream.voidpopLimit(int oldLimit)Discards the current limit, returning to the previous limit.intpushLimit(int byteLimit)SetscurrentLimitto (current position) +byteLimit.booleanreadBool()Read aboolfield value from the stream.ByteStringreadBytes()Read abytesfield value from the stream.doublereadDouble()Read adoublefield value from the stream.intreadEnum()Read an enum field value from the stream.intreadFixed32()Read afixed32field value from the stream.longreadFixed64()Read afixed64field value from the stream.floatreadFloat()Read afloatfield value from the stream.voidreadGroup(int fieldNumber, MessageLite.Builder builder, ExtensionRegistryLite extensionRegistry)Read agroupfield value from the stream.<T extends MessageLite>
 TreadGroup(int fieldNumber, Parser<T> parser, ExtensionRegistryLite extensionRegistry)Read agroupfield value from the stream.intreadInt32()Read anint32field value from the stream.longreadInt64()Read anint64field value from the stream.voidreadMessage(MessageLite.Builder builder, ExtensionRegistryLite extensionRegistry)Read an embedded message field value from the stream.<T extends MessageLite>
 TreadMessage(Parser<T> parser, ExtensionRegistryLite extensionRegistry)Read an embedded message field value from the stream.bytereadRawByte()Read one byte from the input.byte[]readRawBytes(int size)Read a fixed size of bytes from the input.intreadRawLittleEndian32()Read a 32-bit little-endian integer from the stream.longreadRawLittleEndian64()Read a 64-bit little-endian integer from the stream.intreadRawVarint32()Read a raw Varint from the stream.static intreadRawVarint32(int firstByte, java.io.InputStream input)LikereadRawVarint32(InputStream), but expects that the caller has already read one byte.longreadRawVarint64()Read a raw Varint from the stream.intreadSFixed32()Read ansfixed32field value from the stream.longreadSFixed64()Read ansfixed64field value from the stream.intreadSInt32()Read ansint32field value from the stream.longreadSInt64()Read ansint64field value from the stream.java.lang.StringreadString()Read astringfield value from the stream.intreadTag()Attempt to read a field tag, returning zero if we have reached EOF.intreadUInt32()Read auint32field value from the stream.longreadUInt64()Read auint64field value from the stream.voidreadUnknownGroup(int fieldNumber, MessageLite.Builder builder)Deprecated.UnknownFieldSet.Builder now implements MessageLite.Builder, so you can just callreadGroup(int, akka.protobuf.MessageLite.Builder, akka.protobuf.ExtensionRegistryLite).voidresetSizeCounter()Resets the current size counter to zero (seesetSizeLimit(int)).intsetRecursionLimit(int limit)Set the maximum message recursion depth.intsetSizeLimit(int limit)Set the maximum message size.booleanskipField(int tag)Reads and discards a single field, given its tag value.voidskipMessage()Reads and discards an entire message.voidskipRawBytes(int size)Reads and discardssizebytes.
 
- 
- 
- 
Method Detail- 
newInstancepublic static CodedInputStream newInstance(java.io.InputStream input) Create a new CodedInputStream wrapping the given InputStream.
 - 
newInstancepublic static CodedInputStream newInstance(byte[] buf) Create a new CodedInputStream wrapping the given byte array.
 - 
newInstancepublic static CodedInputStream newInstance(byte[] buf, int off, int len) Create a new CodedInputStream wrapping the given byte array slice.
 - 
readTagpublic int readTag() throws java.io.IOExceptionAttempt to read a field tag, returning zero if we have reached EOF. Protocol message parsers use this to read tags, since a protocol message may legally end wherever a tag occurs, and zero is not a valid tag number.- Throws:
- java.io.IOException
 
 - 
checkLastTagWaspublic void checkLastTagWas(int value) throws InvalidProtocolBufferExceptionVerifies that the last call to readTag() returned the given tag value. This is used to verify that a nested group ended with the correct end tag.- Throws:
- InvalidProtocolBufferException-- valuedoes not match the last tag.
 
 - 
skipFieldpublic boolean skipField(int tag) throws java.io.IOExceptionReads and discards a single field, given its tag value.- Returns:
- falseif the tag is an endgroup tag, in which case nothing is skipped. Otherwise, returns- true.
- Throws:
- java.io.IOException
 
 - 
skipMessagepublic void skipMessage() throws java.io.IOExceptionReads and discards an entire message. This will read either until EOF or until an endgroup tag, whichever comes first.- Throws:
- java.io.IOException
 
 - 
readDoublepublic double readDouble() throws java.io.IOExceptionRead adoublefield value from the stream.- Throws:
- java.io.IOException
 
 - 
readFloatpublic float readFloat() throws java.io.IOExceptionRead afloatfield value from the stream.- Throws:
- java.io.IOException
 
 - 
readUInt64public long readUInt64() throws java.io.IOExceptionRead auint64field value from the stream.- Throws:
- java.io.IOException
 
 - 
readInt64public long readInt64() throws java.io.IOExceptionRead anint64field value from the stream.- Throws:
- java.io.IOException
 
 - 
readInt32public int readInt32() throws java.io.IOExceptionRead anint32field value from the stream.- Throws:
- java.io.IOException
 
 - 
readFixed64public long readFixed64() throws java.io.IOExceptionRead afixed64field value from the stream.- Throws:
- java.io.IOException
 
 - 
readFixed32public int readFixed32() throws java.io.IOExceptionRead afixed32field value from the stream.- Throws:
- java.io.IOException
 
 - 
readBoolpublic boolean readBool() throws java.io.IOExceptionRead aboolfield value from the stream.- Throws:
- java.io.IOException
 
 - 
readStringpublic java.lang.String readString() throws java.io.IOExceptionRead astringfield value from the stream.- Throws:
- java.io.IOException
 
 - 
readGrouppublic void readGroup(int fieldNumber, MessageLite.Builder builder, ExtensionRegistryLite extensionRegistry) throws java.io.IOExceptionRead agroupfield value from the stream.- Throws:
- java.io.IOException
 
 - 
readGrouppublic <T extends MessageLite> T readGroup(int fieldNumber, Parser<T> parser, ExtensionRegistryLite extensionRegistry) throws java.io.IOException Read agroupfield value from the stream.- Throws:
- java.io.IOException
 
 - 
readUnknownGroup@Deprecated public void readUnknownGroup(int fieldNumber, MessageLite.Builder builder) throws java.io.IOExceptionDeprecated.UnknownFieldSet.Builder now implements MessageLite.Builder, so you can just callreadGroup(int, akka.protobuf.MessageLite.Builder, akka.protobuf.ExtensionRegistryLite).Reads agroupfield value from the stream and merges it into the givenUnknownFieldSet.- Throws:
- java.io.IOException
 
 - 
readMessagepublic void readMessage(MessageLite.Builder builder, ExtensionRegistryLite extensionRegistry) throws java.io.IOException Read an embedded message field value from the stream.- Throws:
- java.io.IOException
 
 - 
readMessagepublic <T extends MessageLite> T readMessage(Parser<T> parser, ExtensionRegistryLite extensionRegistry) throws java.io.IOException Read an embedded message field value from the stream.- Throws:
- java.io.IOException
 
 - 
readBytespublic ByteString readBytes() throws java.io.IOException Read abytesfield value from the stream.- Throws:
- java.io.IOException
 
 - 
readUInt32public int readUInt32() throws java.io.IOExceptionRead auint32field value from the stream.- Throws:
- java.io.IOException
 
 - 
readEnumpublic int readEnum() throws java.io.IOExceptionRead an enum field value from the stream. Caller is responsible for converting the numeric value to an actual enum.- Throws:
- java.io.IOException
 
 - 
readSFixed32public int readSFixed32() throws java.io.IOExceptionRead ansfixed32field value from the stream.- Throws:
- java.io.IOException
 
 - 
readSFixed64public long readSFixed64() throws java.io.IOExceptionRead ansfixed64field value from the stream.- Throws:
- java.io.IOException
 
 - 
readSInt32public int readSInt32() throws java.io.IOExceptionRead ansint32field value from the stream.- Throws:
- java.io.IOException
 
 - 
readSInt64public long readSInt64() throws java.io.IOExceptionRead ansint64field value from the stream.- Throws:
- java.io.IOException
 
 - 
readRawVarint32public int readRawVarint32() throws java.io.IOExceptionRead a raw Varint from the stream. If larger than 32 bits, discard the upper bits.- Throws:
- java.io.IOException
 
 - 
readRawVarint32public static int readRawVarint32(int firstByte, java.io.InputStream input) throws java.io.IOExceptionLikereadRawVarint32(InputStream), but expects that the caller has already read one byte. This allows the caller to determine if EOF has been reached before attempting to read.- Throws:
- java.io.IOException
 
 - 
readRawVarint64public long readRawVarint64() throws java.io.IOExceptionRead a raw Varint from the stream.- Throws:
- java.io.IOException
 
 - 
readRawLittleEndian32public int readRawLittleEndian32() throws java.io.IOExceptionRead a 32-bit little-endian integer from the stream.- Throws:
- java.io.IOException
 
 - 
readRawLittleEndian64public long readRawLittleEndian64() throws java.io.IOExceptionRead a 64-bit little-endian integer from the stream.- Throws:
- java.io.IOException
 
 - 
decodeZigZag32public static int decodeZigZag32(int n) Decode a ZigZag-encoded 32-bit value. ZigZag encodes signed integers into values that can be efficiently encoded with varint. (Otherwise, negative values must be sign-extended to 64 bits to be varint encoded, thus always taking 10 bytes on the wire.)- Parameters:
- n- An unsigned 32-bit integer, stored in a signed int because Java has no explicit unsigned support.
- Returns:
- A signed 32-bit integer.
 
 - 
decodeZigZag64public static long decodeZigZag64(long n) Decode a ZigZag-encoded 64-bit value. ZigZag encodes signed integers into values that can be efficiently encoded with varint. (Otherwise, negative values must be sign-extended to 64 bits to be varint encoded, thus always taking 10 bytes on the wire.)- Parameters:
- n- An unsigned 64-bit integer, stored in a signed int because Java has no explicit unsigned support.
- Returns:
- A signed 64-bit integer.
 
 - 
setRecursionLimitpublic int setRecursionLimit(int limit) Set the maximum message recursion depth. In order to prevent malicious messages from causing stack overflows,CodedInputStreamlimits how deeply messages may be nested. The default limit is 64.- Returns:
- the old limit.
 
 - 
setSizeLimitpublic int setSizeLimit(int limit) Set the maximum message size. In order to prevent malicious messages from exhausting memory or causing integer overflows,CodedInputStreamlimits how large a message may be. The default limit is 64MB. You should set this limit as small as you can without harming your app's functionality. Note that size limits only apply when reading from anInputStream, not when constructed around a raw byte array (nor withByteString.newCodedInput()).If you want to read several messages from a single CodedInputStream, you could call resetSizeCounter()after each one to avoid hitting the size limit.- Returns:
- the old limit.
 
 - 
resetSizeCounterpublic void resetSizeCounter() Resets the current size counter to zero (seesetSizeLimit(int)).
 - 
pushLimitpublic int pushLimit(int byteLimit) throws InvalidProtocolBufferExceptionSetscurrentLimitto (current position) +byteLimit. This is called when descending into a length-delimited embedded message.Note that pushLimit()does NOT affect how many bytes theCodedInputStreamreads from an underlyingInputStreamwhen refreshing its buffer. If you need to prevent reading past a certain point in the underlyingInputStream(e.g. because you expect it to contain more data after the end of the message which you need to handle differently) then you must place a wrapper around yourInputStreamwhich limits the amount of data that can be read from it.- Returns:
- the old limit.
- Throws:
- InvalidProtocolBufferException
 
 - 
popLimitpublic void popLimit(int oldLimit) Discards the current limit, returning to the previous limit.- Parameters:
- oldLimit- The old limit, as returned by- pushLimit.
 
 - 
getBytesUntilLimitpublic int getBytesUntilLimit() Returns the number of bytes to be read before the current limit. If no limit is set, returns -1.
 - 
isAtEndpublic boolean isAtEnd() throws java.io.IOExceptionReturns true if the stream has reached the end of the input. This is the case if either the end of the underlying input source has been reached or if the stream has reached a limit created usingpushLimit(int).- Throws:
- java.io.IOException
 
 - 
getTotalBytesReadpublic int getTotalBytesRead() The total bytes read up to the current position. CallingresetSizeCounter()resets this value to zero.
 - 
readRawBytepublic byte readRawByte() throws java.io.IOExceptionRead one byte from the input.- Throws:
- InvalidProtocolBufferException- The end of the stream or the current limit was reached.
- java.io.IOException
 
 - 
readRawBytespublic byte[] readRawBytes(int size) throws java.io.IOExceptionRead a fixed size of bytes from the input.- Throws:
- InvalidProtocolBufferException- The end of the stream or the current limit was reached.
- java.io.IOException
 
 - 
skipRawBytespublic void skipRawBytes(int size) throws java.io.IOExceptionReads and discardssizebytes.- Throws:
- InvalidProtocolBufferException- The end of the stream or the current limit was reached.
- java.io.IOException
 
 
- 
 
-