public class BufferingStompDecoder extends Object
StompDecoder
 that buffers content remaining in the input ByteBuffer after the parent
 class has read all (complete) STOMP frames from it. The remaining content
 represents an incomplete STOMP frame. When called repeatedly with additional
 data, the decode method returns one or more messages or, if there is not
 enough data still, continues to buffer.
 A single instance of this decoder can be invoked repeatedly to read all messages from a single stream (e.g. WebSocket session) as long as decoding does not fail. If there is an exception, StompDecoder instance should not be used any more as its internal state is not guaranteed to be consistent. It is expected that the underlying session is closed at that point.
StompDecoder| Constructor and Description | 
|---|
| BufferingStompDecoder(StompDecoder stompDecoder,
                     int bufferSizeLimit)Create a new  BufferingStompDecoderwrapping the givenStompDecoder. | 
| Modifier and Type | Method and Description | 
|---|---|
| List<Message<byte[]>> | decode(ByteBuffer newBuffer)Decodes one or more STOMP frames from the given  ByteBufferinto a
 list ofMessages. | 
| int | getBufferSize()Calculate the current buffer size. | 
| int | getBufferSizeLimit()Return the configured buffer size limit. | 
| Integer | getExpectedContentLength()Get the expected content length of the currently buffered, incomplete STOMP frame. | 
| StompDecoder | getStompDecoder()Return the wrapped  StompDecoder. | 
public BufferingStompDecoder(StompDecoder stompDecoder, int bufferSizeLimit)
BufferingStompDecoder wrapping the given StompDecoder.stompDecoder - the target decoder to wrapbufferSizeLimit - the buffer size limitpublic final StompDecoder getStompDecoder()
StompDecoder.public final int getBufferSizeLimit()
public List<Message<byte[]>> decode(ByteBuffer newBuffer)
ByteBuffer into a
 list of Messages.
 If there was enough data to parse a "content-length" header, then the value is used to determine how much more data is needed before a new attempt to decode is made.
If there was not enough data to parse the "content-length", or if there is "content-length" header, every subsequent call to decode attempts to parse again with all available data. Therefore the presence of a "content-length" header helps to optimize the decoding of large messages.
newBuffer - a buffer containing new data to decodeStompConversionException - raised in case of decoding issuespublic int getBufferSize()