public abstract class AbstractEpollStreamChannel extends AbstractChannel implements DuplexChannel
| Modifier and Type | Class and Description |
|---|---|
protected class |
AbstractEpollStreamChannel.SpliceInTask |
AbstractChannel.AbstractUnsafeChannel.Unsafe| Modifier and Type | Field and Description |
|---|---|
protected boolean |
active |
protected int |
flags |
| Modifier | Constructor and Description |
|---|---|
protected |
AbstractEpollStreamChannel(Channel parent,
int fd)
Deprecated.
|
protected |
AbstractEpollStreamChannel(Channel parent,
Socket fd) |
protected |
AbstractEpollStreamChannel(FileDescriptor fd)
Deprecated.
|
protected |
AbstractEpollStreamChannel(int fd)
Deprecated.
|
protected |
AbstractEpollStreamChannel(Socket fd)
Deprecated.
|
protected |
AbstractEpollStreamChannel(Socket fd,
boolean active) |
| Modifier and Type | Method and Description |
|---|---|
protected static void |
checkResolvable(InetSocketAddress addr) |
abstract EpollChannelConfig |
config()
Returns the configuration of this channel.
|
protected void |
doBeginRead()
Schedule a read operation.
|
protected void |
doClose()
Close the
Channel |
protected boolean |
doConnect(SocketAddress remoteAddress,
SocketAddress localAddress)
Connect to the remote peer
|
protected void |
doDeregister()
|
protected void |
doDisconnect()
Disconnect this
Channel from its remote peer |
protected int |
doReadBytes(ByteBuf byteBuf)
Read bytes into the given
ByteBuf and return the amount. |
protected void |
doRegister()
|
protected void |
doWrite(ChannelOutboundBuffer in)
Flush the content of the given buffer to the remote peer.
|
protected int |
doWriteBytes(ByteBuf buf,
int writeSpinCount) |
protected boolean |
doWriteSingle(ChannelOutboundBuffer in,
int writeSpinCount) |
Socket |
fd()
Returns the
FileDescriptor that is used by this Channel. |
protected Object |
filterOutboundMessage(Object msg)
Invoked when a new message is added to a
ChannelOutboundBuffer of this AbstractChannel, so that
the Channel implementation converts the message to another. |
boolean |
isActive()
Return
true if the Channel is active and so connected. |
protected boolean |
isCompatible(EventLoop loop)
Return
true if the given EventLoop is compatible with this instance. |
boolean |
isInputShutdown()
Returns
true if and only if the remote peer shut down its output so that no more
data is received from this channel. |
boolean |
isOpen()
Returns
true if the Channel is open and may get active later |
boolean |
isOutputShutdown() |
ChannelMetadata |
metadata()
|
protected ByteBuf |
newDirectBuffer(ByteBuf buf)
Returns an off-heap copy of the specified
ByteBuf, and releases the original one. |
protected ByteBuf |
newDirectBuffer(Object holder,
ByteBuf buf)
Returns an off-heap copy of the specified
ByteBuf, and releases the specified holder. |
protected io.netty.channel.epoll.AbstractEpollChannel.AbstractEpollUnsafe |
newUnsafe()
Create a new
AbstractChannel.AbstractUnsafe instance which will be used for the life-time of the Channel |
ChannelFuture |
shutdownOutput() |
ChannelFuture |
shutdownOutput(ChannelPromise promise) |
protected void |
shutdownOutput0(ChannelPromise promise) |
ChannelFuture |
spliceTo(AbstractEpollStreamChannel ch,
int len)
Splice from this
AbstractEpollStreamChannel to another AbstractEpollStreamChannel. |
ChannelFuture |
spliceTo(AbstractEpollStreamChannel ch,
int len,
ChannelPromise promise)
Splice from this
AbstractEpollStreamChannel to another AbstractEpollStreamChannel. |
ChannelFuture |
spliceTo(FileDescriptor ch,
int offset,
int len)
Splice from this
AbstractEpollStreamChannel to another FileDescriptor. |
ChannelFuture |
spliceTo(FileDescriptor ch,
int offset,
int len,
ChannelPromise promise)
Splice from this
AbstractEpollStreamChannel to another FileDescriptor. |
alloc, bind, bind, bytesBeforeUnwritable, bytesBeforeWritable, close, close, closeFuture, compareTo, connect, connect, connect, connect, deregister, deregister, disconnect, disconnect, doBind, equals, eventLoop, flush, hashCode, id, invalidateLocalAddress, invalidateRemoteAddress, isRegistered, isWritable, localAddress, localAddress0, newFailedFuture, newId, newProgressivePromise, newPromise, newSucceededFuture, parent, pipeline, read, remoteAddress, remoteAddress0, toString, unsafe, voidPromise, write, write, writeAndFlush, writeAndFlushattr, hasAttrclone, finalize, getClass, notify, notifyAll, wait, wait, waitalloc, bind, bind, bytesBeforeUnwritable, bytesBeforeWritable, close, close, closeFuture, config, connect, connect, connect, connect, deregister, deregister, disconnect, disconnect, eventLoop, flush, id, isActive, isOpen, isRegistered, isWritable, localAddress, metadata, newFailedFuture, newProgressivePromise, newPromise, newSucceededFuture, parent, pipeline, read, remoteAddress, unsafe, voidPromise, write, write, writeAndFlush, writeAndFlushattr, hasAttrcompareTo@Deprecated protected AbstractEpollStreamChannel(Channel parent, int fd)
AbstractEpollStreamChannel(Channel, Socket).@Deprecated protected AbstractEpollStreamChannel(int fd)
AbstractEpollStreamChannel(Socket, boolean).@Deprecated protected AbstractEpollStreamChannel(FileDescriptor fd)
AbstractEpollStreamChannel(Socket, boolean).@Deprecated protected AbstractEpollStreamChannel(Socket fd)
AbstractEpollStreamChannel(Socket, boolean).protected AbstractEpollStreamChannel(Socket fd, boolean active)
protected io.netty.channel.epoll.AbstractEpollChannel.AbstractEpollUnsafe newUnsafe()
AbstractChannelAbstractChannel.AbstractUnsafe instance which will be used for the life-time of the Channelpublic final ChannelFuture spliceTo(AbstractEpollStreamChannel ch, int len)
AbstractEpollStreamChannel to another AbstractEpollStreamChannel.
The len is the number of bytes to splice. If using Integer.MAX_VALUE it will
splice until the ChannelFuture was canceled or it was failed.
Please note:
EventLoop, otherwise an
IllegalArgumentException is thrown. EpollChannelConfig.getEpollMode() must be EpollMode.LEVEL_TRIGGERED for this and the
target AbstractEpollStreamChannelpublic final ChannelFuture spliceTo(AbstractEpollStreamChannel ch, int len, ChannelPromise promise)
AbstractEpollStreamChannel to another AbstractEpollStreamChannel.
The len is the number of bytes to splice. If using Integer.MAX_VALUE it will
splice until the ChannelFuture was canceled or it was failed.
Please note:
EventLoop, otherwise an
IllegalArgumentException is thrown. EpollChannelConfig.getEpollMode() must be EpollMode.LEVEL_TRIGGERED for this and the
target AbstractEpollStreamChannelpublic final ChannelFuture spliceTo(FileDescriptor ch, int offset, int len)
AbstractEpollStreamChannel to another FileDescriptor.
The offset is the offset for the FileDescriptor and len is the
number of bytes to splice. If using Integer.MAX_VALUE it will splice until the
ChannelFuture was canceled or it was failed.
Please note:
EpollChannelConfig.getEpollMode() must be EpollMode.LEVEL_TRIGGERED for this
AbstractEpollStreamChannelFileDescriptor will not be closed after the ChannelFuture is notifiedIllegalStateException will be thrown.public final ChannelFuture spliceTo(FileDescriptor ch, int offset, int len, ChannelPromise promise)
AbstractEpollStreamChannel to another FileDescriptor.
The offset is the offset for the FileDescriptor and len is the
number of bytes to splice. If using Integer.MAX_VALUE it will splice until the
ChannelFuture was canceled or it was failed.
Please note:
EpollChannelConfig.getEpollMode() must be EpollMode.LEVEL_TRIGGERED for this
AbstractEpollStreamChannelFileDescriptor will not be closed after the ChannelPromise is notifiedIllegalStateException will be thrown.protected void doWrite(ChannelOutboundBuffer in) throws Exception
AbstractChanneldoWrite in class AbstractChannelExceptionprotected boolean doWriteSingle(ChannelOutboundBuffer in, int writeSpinCount) throws Exception
Exceptionprotected Object filterOutboundMessage(Object msg)
AbstractChannelChannelOutboundBuffer of this AbstractChannel, so that
the Channel implementation converts the message to another. (e.g. heap buffer -> direct buffer)filterOutboundMessage in class AbstractChannelprotected void shutdownOutput0(ChannelPromise promise)
public boolean isInputShutdown()
DuplexChanneltrue if and only if the remote peer shut down its output so that no more
data is received from this channel. Note that the semantic of this method is different from
that of Socket.shutdownInput() and Socket.isInputShutdown().isInputShutdown in interface DuplexChannelpublic boolean isOutputShutdown()
isOutputShutdown in interface DuplexChannelSocket.isOutputShutdown()public ChannelFuture shutdownOutput()
shutdownOutput in interface DuplexChannelSocket.shutdownOutput()public ChannelFuture shutdownOutput(ChannelPromise promise)
shutdownOutput in interface DuplexChannelWill notify the given {@link ChannelPromise}protected void doClose()
throws Exception
AbstractChannelChannelExceptionprotected boolean doConnect(SocketAddress remoteAddress, SocketAddress localAddress) throws Exception
Exceptionpublic final Socket fd()
UnixChannelFileDescriptor that is used by this Channel.fd in interface UnixChannelpublic abstract EpollChannelConfig config()
Channelpublic boolean isActive()
Channeltrue if the Channel is active and so connected.public ChannelMetadata metadata()
Channelprotected void doDisconnect()
throws Exception
AbstractChannelChannel from its remote peerdoDisconnect in class AbstractChannelExceptionprotected boolean isCompatible(EventLoop loop)
AbstractChanneltrue if the given EventLoop is compatible with this instance.isCompatible in class AbstractChannelpublic boolean isOpen()
Channeltrue if the Channel is open and may get active laterprotected void doDeregister()
throws Exception
AbstractChanneldoDeregister in class AbstractChannelExceptionprotected final void doBeginRead()
throws Exception
AbstractChanneldoBeginRead in class AbstractChannelExceptionprotected void doRegister()
throws Exception
AbstractChannelChannel is registered with its EventLoop as part of the register process.
Sub-classes may override this methoddoRegister in class AbstractChannelExceptionprotected final ByteBuf newDirectBuffer(ByteBuf buf)
ByteBuf, and releases the original one.protected static void checkResolvable(InetSocketAddress addr)
protected final int doReadBytes(ByteBuf byteBuf) throws Exception
ByteBuf and return the amount.ExceptionCopyright © 2008–2016 The Netty Project. All rights reserved.