- java.lang.Object
-
- org.xnio.channels.PushBackStreamChannel
-
- All Implemented Interfaces:
java.io.Closeable,java.lang.AutoCloseable,java.nio.channels.Channel,java.nio.channels.InterruptibleChannel,java.nio.channels.ReadableByteChannel,java.nio.channels.ScatteringByteChannel,CloseableChannel,Configurable,StreamSourceChannel,SuspendableReadChannel,WrappedChannel<StreamSourceChannel>
public final class PushBackStreamChannel extends java.lang.Object implements StreamSourceChannel, WrappedChannel<StreamSourceChannel>
A stream source channel which can have data pushed back into it. Note that waiting readers will NOT be interrupted when data is pushed back; therefore data should only be pushed back at points when no waiters are expected to exist.- Author:
- David M. Lloyd
-
-
Field Summary
-
Fields inherited from interface org.xnio.channels.Configurable
EMPTY
-
-
Constructor Summary
Constructors Constructor Description PushBackStreamChannel(StreamSourceChannel channel)Construct a new instance.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidawaitReadable()Block until this channel becomes readable again.voidawaitReadable(long time, java.util.concurrent.TimeUnit timeUnit)Block until this channel becomes readable again, or until the timeout expires.voidclose()Close this channel.StreamSourceChannelgetChannel()Get the channel which is wrapped by this object.ChannelListener.Setter<? extends PushBackStreamChannel>getCloseSetter()Get the setter which can be used to change the close listener for this channel.XnioIoThreadgetIoThread()Get the I/O thread associated with this channel.<T> TgetOption(Option<T> option)Get the value of a channel option.ChannelListener.Setter<? extends PushBackStreamChannel>getReadSetter()Get the setter which can be used to change the read listener for this channel.XnioExecutorgetReadThread()Deprecated.XnioWorkergetWorker()Get the worker for this channel.booleanisOpen()booleanisReadResumed()Determine whether reads are resumed.intread(java.nio.ByteBuffer dst)longread(java.nio.ByteBuffer[] dsts)longread(java.nio.ByteBuffer[] dsts, int offset, int length)voidresumeReads()Resume reads on this channel.voidsetCloseListener(ChannelListener<? super PushBackStreamChannel> closeListener)<T> TsetOption(Option<T> option, T value)Set an option for this channel.voidsetReadListener(ChannelListener<? super PushBackStreamChannel> readListener)voidshutdownReads()Places this readable channel at "end of stream".booleansupportsOption(Option<?> option)Determine whether an option is supported on this channel.voidsuspendReads()Suspend further read notifications on this channel.longtransferTo(long position, long count, java.nio.channels.FileChannel target)Transfers bytes into the given file from this channel.longtransferTo(long count, java.nio.ByteBuffer throughBuffer, StreamSinkChannel target)Transfers bytes into the given channel target.voidunget(Pooled<java.nio.ByteBuffer> buffer)Re-queue the given pooled buffer into this channel.voidwakeupReads()Resume readson this channel, and force the read listener to be triggered even if the channel isn't actually readable.
-
-
-
Constructor Detail
-
PushBackStreamChannel
public PushBackStreamChannel(StreamSourceChannel channel)
Construct a new instance.- Parameters:
channel- the channel to wrap
-
-
Method Detail
-
setReadListener
public void setReadListener(ChannelListener<? super PushBackStreamChannel> readListener)
-
setCloseListener
public void setCloseListener(ChannelListener<? super PushBackStreamChannel> closeListener)
-
getReadSetter
public ChannelListener.Setter<? extends PushBackStreamChannel> getReadSetter()
Description copied from interface:StreamSourceChannelGet the setter which can be used to change the read listener for this channel.- Specified by:
getReadSetterin interfaceStreamSourceChannel- Specified by:
getReadSetterin interfaceSuspendableReadChannel- Returns:
- the setter
-
getCloseSetter
public ChannelListener.Setter<? extends PushBackStreamChannel> getCloseSetter()
Description copied from interface:StreamSourceChannelGet the setter which can be used to change the close listener for this channel. If the channel is already closed, then the listener will not be called.- Specified by:
getCloseSetterin interfaceCloseableChannel- Specified by:
getCloseSetterin interfaceStreamSourceChannel- Specified by:
getCloseSetterin interfaceSuspendableReadChannel- Returns:
- the setter
-
transferTo
public long transferTo(long position, long count, java.nio.channels.FileChannel target) throws java.io.IOExceptionDescription copied from interface:StreamSourceChannelTransfers bytes into the given file from this channel. Using this method in preference toFileChannel.transferFrom(ReadableByteChannel, long, long)may provide a performance advantage on some platforms.If the current thread is interrupted when this method is called, it may throw a
InterruptedIOException; however, if this exception is thrown, theInterruptedIOException.bytesTransferredfield is guaranteed to be 0.- Specified by:
transferToin interfaceStreamSourceChannel- Parameters:
position- the position within the file from which the transfer is to begincount- the number of bytes to be transferredtarget- the file to write to- Returns:
- the number of bytes (possibly 0) that were actually transferred
- Throws:
java.io.IOException- if an I/O error occurs
-
transferTo
public long transferTo(long count, java.nio.ByteBuffer throughBuffer, StreamSinkChannel target) throws java.io.IOExceptionDescription copied from interface:StreamSourceChannelTransfers bytes into the given channel target. On some platforms, this may avoid copying bytes between user and kernel space. On other platforms, bytes are passed through thethroughBufferparameter's buffer space. On entry,throughBufferwill be cleared. On exit, the buffer will be flipped for emptying, and may possibly be empty or may contain data. If this method returns a value less thancount, then the remaining data inthroughBuffermay contain data read from this channel which must be written totargetto complete the operation. Note that using a direct buffer may provide an intermediate performance gain on platforms without zero-copy facilities.If the current thread is interrupted when this method is called, it may throw a
InterruptedIOException; however, if this exception is thrown, theInterruptedIOException.bytesTransferredfield is guaranteed to be 0. Note that the return value is the amount of data that was actually transferred to theStreamSinkChannel. The actual amount of data read could be larger than this, and can be calculated by adding the return value and the amount of data left inthroughBuffer.- Specified by:
transferToin interfaceStreamSourceChannel- Parameters:
count- the number of bytes to be transferredthroughBuffer- the buffer to copy through.target- the destination to write to- Returns:
- the number of bytes (possibly 0) that were actually transferred, or -1 if the end of input was reached
- Throws:
java.io.IOException- if an I/O error occurs
-
read
public int read(java.nio.ByteBuffer dst) throws java.io.IOException- Specified by:
readin interfacejava.nio.channels.ReadableByteChannel- Throws:
java.io.IOException
-
read
public long read(java.nio.ByteBuffer[] dsts) throws java.io.IOException- Specified by:
readin interfacejava.nio.channels.ScatteringByteChannel- Throws:
java.io.IOException
-
read
public long read(java.nio.ByteBuffer[] dsts, int offset, int length) throws java.io.IOException- Specified by:
readin interfacejava.nio.channels.ScatteringByteChannel- Throws:
java.io.IOException
-
unget
public void unget(Pooled<java.nio.ByteBuffer> buffer)
Re-queue the given pooled buffer into this channel. This method transfers ownership of the given buffer to this channel. The buffer should be flipped for emptying.- Parameters:
buffer- the buffer to re-queue
-
suspendReads
public void suspendReads()
Description copied from interface:SuspendableReadChannelSuspend further read notifications on this channel.- Specified by:
suspendReadsin interfaceSuspendableReadChannel
-
resumeReads
public void resumeReads()
Description copied from interface:SuspendableReadChannelResume reads on this channel. The read listener will be called as soon as there is data available to be read.- Specified by:
resumeReadsin interfaceSuspendableReadChannel
-
isReadResumed
public boolean isReadResumed()
Description copied from interface:SuspendableReadChannelDetermine whether reads are resumed.- Specified by:
isReadResumedin interfaceSuspendableReadChannel- Returns:
trueif reads are resumed,falseif reads are suspended
-
wakeupReads
public void wakeupReads()
Description copied from interface:SuspendableReadChannelResume readson this channel, and force the read listener to be triggered even if the channel isn't actually readable.- Specified by:
wakeupReadsin interfaceSuspendableReadChannel
-
shutdownReads
public void shutdownReads() throws java.io.IOExceptionDescription copied from interface:SuspendableReadChannelPlaces this readable channel at "end of stream". Further reads will result in EOF. Shutting down all directions of a channel will causeCloseableChannel.close()to be called automatically.- Specified by:
shutdownReadsin interfaceSuspendableReadChannel- Throws:
java.io.IOException- if an I/O error occurs
-
awaitReadable
public void awaitReadable() throws java.io.IOExceptionDescription copied from interface:SuspendableReadChannelBlock until this channel becomes readable again. This method may return spuriously before the channel becomes readable.- Specified by:
awaitReadablein interfaceSuspendableReadChannel- Throws:
java.io.InterruptedIOException- if the operation is interrupted; the thread's interrupt flag will be set as welljava.io.IOException- if an I/O error occurs
-
awaitReadable
public void awaitReadable(long time, java.util.concurrent.TimeUnit timeUnit) throws java.io.IOExceptionDescription copied from interface:SuspendableReadChannelBlock until this channel becomes readable again, or until the timeout expires. This method may return spuriously before the channel becomes readable or the timeout expires.- Specified by:
awaitReadablein interfaceSuspendableReadChannel- Parameters:
time- the time to waittimeUnit- the time unit- Throws:
java.io.InterruptedIOException- if the operation is interrupted; the thread's interrupt flag will be set as welljava.io.IOException- if an I/O error occurs
-
getReadThread
@Deprecated public XnioExecutor getReadThread()
Deprecated.Description copied from interface:SuspendableReadChannelGet the read thread for this channel.- Specified by:
getReadThreadin interfaceSuspendableReadChannel- Returns:
- the thread, or
nullif none is configured or available
-
getIoThread
public XnioIoThread getIoThread()
Description copied from interface:CloseableChannelGet the I/O thread associated with this channel.- Specified by:
getIoThreadin interfaceCloseableChannel- Returns:
- the I/O thread associated with this channel
-
getWorker
public XnioWorker getWorker()
Description copied from interface:CloseableChannelGet the worker for this channel.- Specified by:
getWorkerin interfaceCloseableChannel- Returns:
- the worker
-
isOpen
public boolean isOpen()
- Specified by:
isOpenin interfacejava.nio.channels.Channel
-
close
public void close() throws java.io.IOExceptionDescription copied from interface:CloseableChannelClose this channel. When a channel is closed, its close listener is invoked. Invoking this method more than once has no additional effect.- Specified by:
closein interfacejava.lang.AutoCloseable- Specified by:
closein interfacejava.nio.channels.Channel- Specified by:
closein interfacejava.io.Closeable- Specified by:
closein interfaceCloseableChannel- Specified by:
closein interfacejava.nio.channels.InterruptibleChannel- Throws:
java.io.IOException- if the close failed
-
supportsOption
public boolean supportsOption(Option<?> option)
Description copied from interface:ConfigurableDetermine whether an option is supported on this channel.- Specified by:
supportsOptionin interfaceConfigurable- Parameters:
option- the option- Returns:
trueif it is supported
-
getOption
public <T> T getOption(Option<T> option) throws java.io.IOException
Description copied from interface:ConfigurableGet the value of a channel option.- Specified by:
getOptionin interfaceConfigurable- Type Parameters:
T- the type of the option value- Parameters:
option- the option to get- Returns:
- the value of the option, or
nullif it is not set - Throws:
java.io.IOException- if an I/O error occurred when reading the option
-
setOption
public <T> T setOption(Option<T> option, T value) throws java.lang.IllegalArgumentException, java.io.IOException
Description copied from interface:ConfigurableSet an option for this channel. Unsupported options are ignored.- Specified by:
setOptionin interfaceConfigurable- Type Parameters:
T- the type of the option value- Parameters:
option- the option to setvalue- the value of the option to set- Returns:
- the previous option value, if any
- Throws:
java.lang.IllegalArgumentException- if the value is not acceptable for this optionjava.io.IOException- if an I/O error occurred when modifying the option
-
getChannel
public StreamSourceChannel getChannel()
Description copied from interface:WrappedChannelGet the channel which is wrapped by this object.- Specified by:
getChannelin interfaceWrappedChannel<StreamSourceChannel>- Returns:
- the wrapped channel
-
-