Class AbstractBinaryTypeDecoder
java.lang.Object
org.apache.qpid.protonj2.codec.decoders.AbstractPrimitiveTypeDecoder<Binary>
org.apache.qpid.protonj2.codec.decoders.primitives.AbstractBinaryTypeDecoder
- All Implemented Interfaces:
BinaryTypeDecoder
,PrimitiveTypeDecoder<Binary>
,StreamTypeDecoder<Binary>
,TypeDecoder<Binary>
- Direct Known Subclasses:
Binary32TypeDecoder
,Binary8TypeDecoder
public abstract class AbstractBinaryTypeDecoder
extends AbstractPrimitiveTypeDecoder<Binary>
implements BinaryTypeDecoder
Base class for the various Binary type decoders used to read AMQP Binary values.
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionabstract int
readSize
(InputStream stream) Reads the encoded size value for the encoded binary payload and returns it.abstract int
readSize
(ProtonBuffer buffer) Reads the encoded size value for the encoded binary payload and returns it.readValue
(InputStream stream, StreamDecoderState state) Reads the next type from the given buffer and returns it.readValue
(ProtonBuffer buffer, DecoderState state) Reads the next type from the given buffer and returns it.byte[]
readValueAsArray
(InputStream stream, StreamDecoderState state) Read and decode an AMQPBinary
into a byte array instance and return it.byte[]
readValueAsArray
(ProtonBuffer buffer, DecoderState state) Read and decode an AMQPBinary
into a byte array instance and return it.readValueAsBuffer
(InputStream stream, StreamDecoderState state) Read and decode an AMQPBinary
into aProtonBuffer
instance and return it.readValueAsBuffer
(ProtonBuffer buffer, DecoderState state) Read and decode an AMQPBinary
into aProtonBuffer
instance and return it.void
skipValue
(InputStream stream, StreamDecoderState state) Skips over the bytes that compose the type this descriptor decodes.void
skipValue
(ProtonBuffer buffer, DecoderState state) Skips over the bytes that compose the type this descriptor decodes.Methods inherited from class org.apache.qpid.protonj2.codec.decoders.AbstractPrimitiveTypeDecoder
isArrayType, isJavaPrimitive, readArrayElements, readArrayElements
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.apache.qpid.protonj2.codec.decoders.primitives.BinaryTypeDecoder
getTypeClass
Methods inherited from interface org.apache.qpid.protonj2.codec.decoders.PrimitiveTypeDecoder
getTypeCode, isJavaPrimitive
Methods inherited from interface org.apache.qpid.protonj2.codec.StreamTypeDecoder
getTypeClass, isArrayType, readArrayElements
Methods inherited from interface org.apache.qpid.protonj2.codec.TypeDecoder
isArrayType, readArrayElements
-
Constructor Details
-
AbstractBinaryTypeDecoder
public AbstractBinaryTypeDecoder()
-
-
Method Details
-
readValue
Description copied from interface:TypeDecoder
Reads the next type from the given buffer and returns it.- Specified by:
readValue
in interfaceTypeDecoder<Binary>
- Parameters:
buffer
- the source of encoded data.state
- the current state of the decoder.- Returns:
- the next instance in the stream that this decoder handles.
- Throws:
DecodeException
- if an error is encountered while reading the next value.
-
readValueAsBuffer
public ProtonBuffer readValueAsBuffer(ProtonBuffer buffer, DecoderState state) throws DecodeException Read and decode an AMQPBinary
into aProtonBuffer
instance and return it.- Parameters:
buffer
- TheProtonBuffer
where theBinary
encoding should be read from.state
- TheEncoderState
that can be used when reading the encoded value.- Returns:
- the bytes that comprise the encoded Binary wrapped in a
ProtonBuffer
instance. - Throws:
DecodeException
- if an error occurs while reading the Binary value.
-
readValueAsArray
Read and decode an AMQPBinary
into a byte array instance and return it.- Parameters:
buffer
- TheProtonBuffer
where theBinary
encoding should be read from.state
- TheEncoderState
that can be used when reading the encoded value.- Returns:
- the bytes that comprise the encoded Binary copied into a byte array instance.
- Throws:
DecodeException
- if an error occurs while reading the Binary value.
-
readValue
Description copied from interface:StreamTypeDecoder
Reads the next type from the given buffer and returns it.- Specified by:
readValue
in interfaceStreamTypeDecoder<Binary>
- Parameters:
stream
- the source of encoded data.state
- the current state of the decoder.- Returns:
- the next instance in the stream that this decoder handles.
- Throws:
DecodeException
- if an error is encountered while reading the next value.
-
readValueAsBuffer
public ProtonBuffer readValueAsBuffer(InputStream stream, StreamDecoderState state) throws DecodeException Read and decode an AMQPBinary
into aProtonBuffer
instance and return it.- Parameters:
stream
- TheInputStream
where theBinary
encoding should be read from.state
- TheEncoderState
that can be used when reading the encoded value.- Returns:
- the bytes that comprise the encoded Binary wrapped in a
ProtonBuffer
instance. - Throws:
DecodeException
- if an error occurs while reading the Binary value.
-
readValueAsArray
Read and decode an AMQPBinary
into a byte array instance and return it.- Parameters:
stream
- TheInputStream
where theBinary
encoding should be read from.state
- TheEncoderState
that can be used when reading the encoded value.- Returns:
- the bytes that comprise the encoded Binary copied into a byte array instance.
- Throws:
DecodeException
- if an error occurs while reading the Binary value.
-
skipValue
Description copied from interface:TypeDecoder
Skips over the bytes that compose the type this descriptor decodes.Skipping values can be used when the type is not used or processed by the application doing the decoding. An example might be an AMQP message decoder that only needs to decode certain parts of the message and not others.
- Specified by:
skipValue
in interfaceTypeDecoder<Binary>
- Parameters:
buffer
- The buffer that contains the encoded type.state
- The decoder state.- Throws:
DecodeException
- if an error occurs while skipping the value.
-
skipValue
Description copied from interface:StreamTypeDecoder
Skips over the bytes that compose the type this descriptor decodes.Skipping values can be used when the type is not used or processed by the application doing the decoding. An example might be an AMQP message decoder that only needs to decode certain parts of the message and not others.
- Specified by:
skipValue
in interfaceStreamTypeDecoder<Binary>
- Parameters:
stream
- The stream that contains the encoded type.state
- The decoder state.- Throws:
DecodeException
- if an error occurs while skipping the value.
-
readSize
Description copied from interface:BinaryTypeDecoder
Reads the encoded size value for the encoded binary payload and returns it. The read is destructive and theTypeDecoder
read methods cannot be called after this unless theProtonBuffer
is reset via a position marker. This method can be useful when the caller intends to manually read the binary payload from the givenProtonBuffer
.- Specified by:
readSize
in interfaceBinaryTypeDecoder
- Parameters:
buffer
- the buffer from which the binary encoded size should be read.- Returns:
- the size of the binary payload that is encoded in the given
ProtonBuffer
.
-
readSize
Description copied from interface:BinaryTypeDecoder
Reads the encoded size value for the encoded binary payload and returns it. The read is destructive and theTypeDecoder
read methods cannot be called after this unless theInputStream
is reset via a position marker. This method can be useful when the caller intends to manually read the binary payload from the givenInputStream
.- Specified by:
readSize
in interfaceBinaryTypeDecoder
- Parameters:
stream
- the stream from which the binary encoded size should be read.- Returns:
- the size of the binary payload that is encoded in the given
InputStream
.
-