Class AbstractBinaryMemcacheDecoder<M extends BinaryMemcacheMessage>
java.lang.Object
io.netty.channel.ChannelHandlerAdapter
io.netty.channel.ChannelInboundHandlerAdapter
io.netty.handler.codec.ByteToMessageDecoder
io.netty.handler.codec.memcache.AbstractMemcacheObjectDecoder
io.netty.handler.codec.memcache.binary.AbstractBinaryMemcacheDecoder<M>
- All Implemented Interfaces:
ChannelHandler, ChannelInboundHandler
- Direct Known Subclasses:
BinaryMemcacheRequestDecoder, BinaryMemcacheResponseDecoder
@UnstableApi
public abstract class AbstractBinaryMemcacheDecoder<M extends BinaryMemcacheMessage>
extends AbstractMemcacheObjectDecoder
Decoder for both
BinaryMemcacheRequest and BinaryMemcacheResponse.
The difference in the protocols (header) is implemented by the subclasses.-
Nested Class Summary
Nested classes/interfaces inherited from class ByteToMessageDecoder
ByteToMessageDecoder.CumulatorNested classes/interfaces inherited from interface ChannelHandler
ChannelHandler.Sharable -
Field Summary
FieldsFields inherited from class ByteToMessageDecoder
COMPOSITE_CUMULATOR, MERGE_CUMULATOR -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedCreate a newAbstractBinaryMemcacheDecoderwith default settings.protectedAbstractBinaryMemcacheDecoder(int chunkSize) Create a newAbstractBinaryMemcacheDecoderwith custom settings. -
Method Summary
Modifier and TypeMethodDescriptionprotected abstract MHelper method to create a upstream message when the incoming parsing did fail.voidWhen the channel goes inactive, release all frames to prevent data leaks.protected voiddecode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) Decode the from oneByteBufto an other.protected abstract MdecodeHeader(ByteBuf in) Decode and return the parsedBinaryMemcacheMessage.protected voidPrepare for next decoding iteration.Methods inherited from class ByteToMessageDecoder
actualReadableBytes, callDecode, channelRead, channelReadComplete, decodeLast, discardSomeReadBytes, handlerRemoved, handlerRemoved0, internalBuffer, isSingleDecode, setCumulator, setDiscardAfterReads, setSingleDecode, userEventTriggeredMethods inherited from class ChannelInboundHandlerAdapter
channelActive, channelRegistered, channelUnregistered, channelWritabilityChanged, exceptionCaughtMethods inherited from class ChannelHandlerAdapter
ensureNotSharable, handlerAdded, isSharableMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ChannelHandler
handlerAdded
-
Field Details
-
DEFAULT_MAX_CHUNK_SIZE
public static final int DEFAULT_MAX_CHUNK_SIZE- See Also:
-
-
Constructor Details
-
AbstractBinaryMemcacheDecoder
protected AbstractBinaryMemcacheDecoder()Create a newAbstractBinaryMemcacheDecoderwith default settings. -
AbstractBinaryMemcacheDecoder
protected AbstractBinaryMemcacheDecoder(int chunkSize) Create a newAbstractBinaryMemcacheDecoderwith custom settings.- Parameters:
chunkSize- the maximum chunk size of the payload.
-
-
Method Details
-
decode
Description copied from class:ByteToMessageDecoderDecode the from oneByteBufto an other. This method will be called till either the inputByteBufhas nothing to read when return from this method or till nothing was read from the inputByteBuf.- Specified by:
decodein classByteToMessageDecoder- Parameters:
ctx- theChannelHandlerContextwhich thisByteToMessageDecoderbelongs toin- theByteBuffrom which to read dataout- theListto which decoded messages should be added- Throws:
Exception- is thrown if an error occurs
-
channelInactive
When the channel goes inactive, release all frames to prevent data leaks.- Specified by:
channelInactivein interfaceChannelInboundHandler- Overrides:
channelInactivein classByteToMessageDecoder- Parameters:
ctx- handler context- Throws:
Exception
-
resetDecoder
protected void resetDecoder()Prepare for next decoding iteration. -
decodeHeader
Decode and return the parsedBinaryMemcacheMessage.- Parameters:
in- the incoming buffer.- Returns:
- the decoded header.
-
buildInvalidMessage
Helper method to create a upstream message when the incoming parsing did fail.- Returns:
- a message indicating a decoding failure.
-