Allow to specify the used buffer type for ChannelInboundByteBufHandler and ChannelOutboundByteBufHandler by configuration. As default it tries to use a direct ByteBuf
This commit is contained in:
parent
a9a29bdf3f
commit
fd3f923b52
@ -19,6 +19,7 @@ import io.netty.buffer.ByteBuf;
|
|||||||
import io.netty.channel.ChannelDuplexHandler;
|
import io.netty.channel.ChannelDuplexHandler;
|
||||||
import io.netty.channel.ChannelHandler;
|
import io.netty.channel.ChannelHandler;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandler;
|
import io.netty.channel.ChannelInboundByteHandler;
|
||||||
import io.netty.channel.ChannelInboundMessageHandler;
|
import io.netty.channel.ChannelInboundMessageHandler;
|
||||||
import io.netty.channel.ChannelPipeline;
|
import io.netty.channel.ChannelPipeline;
|
||||||
@ -63,7 +64,7 @@ public abstract class SpdyOrHttpChooser extends ChannelDuplexHandler implements
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -17,6 +17,7 @@ package io.netty.handler.codec;
|
|||||||
|
|
||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A decoder that splits the received {@link ByteBuf}s by the fixed number
|
* A decoder that splits the received {@link ByteBuf}s by the fixed number
|
||||||
@ -67,7 +68,7 @@ public class FixedLengthFrameDecoder extends ByteToMessageDecoder {
|
|||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
if (allocateFullBuffer) {
|
if (allocateFullBuffer) {
|
||||||
return ctx.alloc().ioBuffer(frameLength);
|
return ChannelHandlerUtil.allocate(ctx, frameLength);
|
||||||
} else {
|
} else {
|
||||||
return super.newInboundBuffer(ctx);
|
return super.newInboundBuffer(ctx);
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@ import com.yammer.metrics.core.Meter;
|
|||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.buffer.Unpooled;
|
import io.netty.buffer.Unpooled;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
import io.netty.channel.udt.nio.NioUdtProvider;
|
import io.netty.channel.udt.nio.NioUdtProvider;
|
||||||
@ -76,7 +77,7 @@ public class ByteEchoClientHandler extends ChannelInboundByteHandlerAdapter {
|
|||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx)
|
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
return ctx.alloc().ioBuffer(
|
return ChannelHandlerUtil.allocate(ctx,
|
||||||
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
|
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@ package io.netty.example.udt.echo.bytes;
|
|||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.channel.ChannelHandler.Sharable;
|
import io.netty.channel.ChannelHandler.Sharable;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
import io.netty.channel.udt.nio.NioUdtProvider;
|
import io.netty.channel.udt.nio.NioUdtProvider;
|
||||||
@ -57,7 +58,7 @@ public class ByteEchoServerHandler extends ChannelInboundByteHandlerAdapter {
|
|||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx)
|
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
return ctx.alloc().ioBuffer(
|
return ChannelHandlerUtil.allocate(ctx,
|
||||||
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
|
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,6 +17,7 @@ package io.netty.handler.logging;
|
|||||||
|
|
||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandler;
|
import io.netty.channel.ChannelInboundByteHandler;
|
||||||
import io.netty.channel.ChannelOutboundByteHandler;
|
import io.netty.channel.ChannelOutboundByteHandler;
|
||||||
import io.netty.channel.ChannelPromise;
|
import io.netty.channel.ChannelPromise;
|
||||||
@ -108,7 +109,7 @@ public class ByteLoggingHandler
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -123,7 +124,7 @@ public class ByteLoggingHandler
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -23,6 +23,7 @@ import io.netty.channel.ChannelFlushPromiseNotifier;
|
|||||||
import io.netty.channel.ChannelFuture;
|
import io.netty.channel.ChannelFuture;
|
||||||
import io.netty.channel.ChannelFutureListener;
|
import io.netty.channel.ChannelFutureListener;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandler;
|
import io.netty.channel.ChannelInboundByteHandler;
|
||||||
import io.netty.channel.ChannelOutboundByteHandler;
|
import io.netty.channel.ChannelOutboundByteHandler;
|
||||||
import io.netty.channel.ChannelPipeline;
|
import io.netty.channel.ChannelPipeline;
|
||||||
@ -380,7 +381,7 @@ public class SslHandler
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -395,7 +396,7 @@ public class SslHandler
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -21,6 +21,7 @@ import io.netty.buffer.ByteBuf;
|
|||||||
import io.netty.buffer.Unpooled;
|
import io.netty.buffer.Unpooled;
|
||||||
import io.netty.channel.Channel;
|
import io.netty.channel.Channel;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
||||||
import io.netty.channel.ChannelInitializer;
|
import io.netty.channel.ChannelInitializer;
|
||||||
import io.netty.channel.sctp.SctpChannel;
|
import io.netty.channel.sctp.SctpChannel;
|
||||||
@ -160,7 +161,7 @@ public class SctpEchoTest extends AbstractSctpTest {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer(0, maxInboundBufferSize);
|
return ChannelHandlerUtil.allocate(ctx, 0, maxInboundBufferSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -21,6 +21,7 @@ import io.netty.buffer.ByteBuf;
|
|||||||
import io.netty.buffer.Unpooled;
|
import io.netty.buffer.Unpooled;
|
||||||
import io.netty.channel.Channel;
|
import io.netty.channel.Channel;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
||||||
import io.netty.channel.ChannelInitializer;
|
import io.netty.channel.ChannelInitializer;
|
||||||
import io.netty.channel.socket.SocketChannel;
|
import io.netty.channel.socket.SocketChannel;
|
||||||
@ -186,7 +187,7 @@ public class SocketEchoTest extends AbstractSocketTest {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer(0, maxInboundBufferSize);
|
return ChannelHandlerUtil.allocate(ctx, 0, maxInboundBufferSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -195,4 +195,9 @@ final class DefaultRxtxChannelConfig extends DefaultChannelConfig implements Rxt
|
|||||||
public RxtxChannelConfig setAutoRead(boolean autoRead) {
|
public RxtxChannelConfig setAutoRead(boolean autoRead) {
|
||||||
return (RxtxChannelConfig) super.setAutoRead(autoRead);
|
return (RxtxChannelConfig) super.setAutoRead(autoRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public RxtxChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
return (RxtxChannelConfig) super.setDefaultHandlerByteBufType(type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -269,4 +269,7 @@ public interface RxtxChannelConfig extends ChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
RxtxChannelConfig setAutoRead(boolean autoRead);
|
RxtxChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
RxtxChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@ package io.netty.channel.sctp;
|
|||||||
import com.sun.nio.sctp.SctpChannel;
|
import com.sun.nio.sctp.SctpChannel;
|
||||||
import com.sun.nio.sctp.SctpStandardSocketOptions;
|
import com.sun.nio.sctp.SctpStandardSocketOptions;
|
||||||
import io.netty.buffer.ByteBufAllocator;
|
import io.netty.buffer.ByteBufAllocator;
|
||||||
|
import io.netty.channel.ChannelConfig;
|
||||||
import io.netty.channel.ChannelException;
|
import io.netty.channel.ChannelException;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
import io.netty.channel.DefaultChannelConfig;
|
import io.netty.channel.DefaultChannelConfig;
|
||||||
@ -189,4 +190,9 @@ public class DefaultSctpChannelConfig extends DefaultChannelConfig implements Sc
|
|||||||
public SctpChannelConfig setAutoRead(boolean autoRead) {
|
public SctpChannelConfig setAutoRead(boolean autoRead) {
|
||||||
return (SctpChannelConfig) super.setAutoRead(autoRead);
|
return (SctpChannelConfig) super.setAutoRead(autoRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SctpChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
return (SctpChannelConfig) super.setDefaultHandlerByteBufType(type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -173,4 +173,9 @@ public class DefaultSctpServerChannelConfig extends DefaultChannelConfig impleme
|
|||||||
public SctpServerChannelConfig setAutoRead(boolean autoRead) {
|
public SctpServerChannelConfig setAutoRead(boolean autoRead) {
|
||||||
return (SctpServerChannelConfig) super.setAutoRead(autoRead);
|
return (SctpServerChannelConfig) super.setAutoRead(autoRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SctpServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
return (SctpServerChannelConfig) super.setDefaultHandlerByteBufType(type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -107,4 +107,7 @@ public interface SctpChannelConfig extends ChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
SctpChannelConfig setAutoRead(boolean autoRead);
|
SctpChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
SctpChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -102,4 +102,7 @@ public interface SctpServerChannelConfig extends ChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
SctpServerChannelConfig setAutoRead(boolean autoRead);
|
SctpServerChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
SctpServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@ import com.barchart.udt.OptionUDT;
|
|||||||
import com.barchart.udt.SocketUDT;
|
import com.barchart.udt.SocketUDT;
|
||||||
import com.barchart.udt.nio.ChannelUDT;
|
import com.barchart.udt.nio.ChannelUDT;
|
||||||
import io.netty.buffer.ByteBufAllocator;
|
import io.netty.buffer.ByteBufAllocator;
|
||||||
|
import io.netty.channel.ChannelConfig;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
import io.netty.channel.DefaultChannelConfig;
|
import io.netty.channel.DefaultChannelConfig;
|
||||||
|
|
||||||
@ -254,4 +255,10 @@ public class DefaultUdtChannelConfig extends DefaultChannelConfig implements
|
|||||||
super.setAutoRead(autoRead);
|
super.setAutoRead(autoRead);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public UdtChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
super.setDefaultHandlerByteBufType(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -157,4 +157,10 @@ public class DefaultUdtServerChannelConfig extends DefaultUdtChannelConfig
|
|||||||
super.setAutoRead(autoRead);
|
super.setAutoRead(autoRead);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public UdtServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
super.setDefaultHandlerByteBufType(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -162,4 +162,6 @@ public interface UdtChannelConfig extends ChannelConfig {
|
|||||||
*/
|
*/
|
||||||
UdtChannelConfig setSystemSendBufferSize(int size);
|
UdtChannelConfig setSystemSendBufferSize(int size);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
UdtChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -80,4 +80,6 @@ public interface UdtServerChannelConfig extends UdtChannelConfig {
|
|||||||
@Override
|
@Override
|
||||||
UdtServerChannelConfig setSystemSendBufferSize(int size);
|
UdtServerChannelConfig setSystemSendBufferSize(int size);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
UdtServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@ import com.yammer.metrics.core.Meter;
|
|||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.buffer.Unpooled;
|
import io.netty.buffer.Unpooled;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
import io.netty.channel.ChannelInboundByteHandlerAdapter;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
import io.netty.channel.udt.nio.NioUdtProvider;
|
import io.netty.channel.udt.nio.NioUdtProvider;
|
||||||
@ -97,7 +98,7 @@ public class EchoByteHandler extends ChannelInboundByteHandlerAdapter {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer(
|
return ChannelHandlerUtil.allocate(ctx,
|
||||||
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
|
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
*/
|
*/
|
||||||
package io.netty.channel;
|
package io.netty.channel;
|
||||||
|
|
||||||
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.buffer.ByteBufAllocator;
|
import io.netty.buffer.ByteBufAllocator;
|
||||||
import io.netty.channel.socket.SocketChannelConfig;
|
import io.netty.channel.socket.SocketChannelConfig;
|
||||||
|
|
||||||
@ -62,6 +63,12 @@ import java.util.Map;
|
|||||||
*/
|
*/
|
||||||
public interface ChannelConfig {
|
public interface ChannelConfig {
|
||||||
|
|
||||||
|
enum ChannelHandlerByteBufType {
|
||||||
|
HEAP,
|
||||||
|
DIRECT,
|
||||||
|
PREFER_DIRECT
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return all set {@link ChannelOption}'s.
|
* Return all set {@link ChannelOption}'s.
|
||||||
*/
|
*/
|
||||||
@ -162,4 +169,23 @@ public interface ChannelConfig {
|
|||||||
* need to call it at all. The default value is {@code true}.
|
* need to call it at all. The default value is {@code true}.
|
||||||
*/
|
*/
|
||||||
ChannelConfig setAutoRead(boolean autoRead);
|
ChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the {@link ChannelHandlerByteBufType} which is used to determine what kind of {@link ByteBuf} will
|
||||||
|
* be created by the {@link ChannelInboundByteHandler#newInboundBuffer(ChannelHandlerContext)} and
|
||||||
|
* {@link ChannelOutboundByteHandler#newOutboundBuffer(ChannelHandlerContext)} methods.
|
||||||
|
* <p>
|
||||||
|
* The implementation of {@link ChannelInboundByteHandler} or {@link ChannelOutboundByteHandler} may still return
|
||||||
|
* another {@link ByteBuf} if it depends on a special type.
|
||||||
|
*
|
||||||
|
* The default is {@link ChannelHandlerByteBufType#PREFER_DIRECT}.
|
||||||
|
*/
|
||||||
|
ChannelHandlerByteBufType getDefaultHandlerByteBufType();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the {@link ChannelHandlerByteBufType} which is used to determine what kind of {@link ByteBuf} will
|
||||||
|
* be created by the {@link ChannelInboundByteHandler#newInboundBuffer(ChannelHandlerContext)} and
|
||||||
|
* {@link ChannelOutboundByteHandler#newOutboundBuffer(ChannelHandlerContext)} methods.
|
||||||
|
*/
|
||||||
|
ChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
package io.netty.channel;
|
package io.netty.channel;
|
||||||
|
|
||||||
import io.netty.buffer.BufUtil;
|
import io.netty.buffer.BufUtil;
|
||||||
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.buffer.MessageBuf;
|
import io.netty.buffer.MessageBuf;
|
||||||
import io.netty.util.Signal;
|
import io.netty.util.Signal;
|
||||||
import io.netty.util.internal.logging.InternalLogger;
|
import io.netty.util.internal.logging.InternalLogger;
|
||||||
@ -151,6 +152,56 @@ public final class ChannelHandlerUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allocate a {@link ByteBuf} taking the {@link ChannelConfig#getDefaultHandlerByteBufType()}
|
||||||
|
* setting into account.
|
||||||
|
*/
|
||||||
|
public static ByteBuf allocate(ChannelHandlerContext ctx) {
|
||||||
|
switch(ctx.channel().config().getDefaultHandlerByteBufType()) {
|
||||||
|
case DIRECT:
|
||||||
|
return ctx.alloc().directBuffer();
|
||||||
|
case PREFER_DIRECT:
|
||||||
|
return ctx.alloc().ioBuffer();
|
||||||
|
case HEAP:
|
||||||
|
return ctx.alloc().heapBuffer();
|
||||||
|
default:
|
||||||
|
throw new IllegalStateException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allocate a {@link ByteBuf} taking the {@link ChannelConfig#getDefaultHandlerByteBufType()}
|
||||||
|
* setting into account.
|
||||||
|
*/
|
||||||
|
public static ByteBuf allocate(ChannelHandlerContext ctx, int initialCapacity) {
|
||||||
|
switch(ctx.channel().config().getDefaultHandlerByteBufType()) {
|
||||||
|
case DIRECT:
|
||||||
|
return ctx.alloc().directBuffer(initialCapacity);
|
||||||
|
case PREFER_DIRECT:
|
||||||
|
return ctx.alloc().ioBuffer(initialCapacity);
|
||||||
|
case HEAP:
|
||||||
|
return ctx.alloc().heapBuffer(initialCapacity);
|
||||||
|
default:
|
||||||
|
throw new IllegalStateException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allocate a {@link ByteBuf} taking the {@link ChannelConfig#getDefaultHandlerByteBufType()}
|
||||||
|
* setting into account.
|
||||||
|
*/
|
||||||
|
public static ByteBuf allocate(ChannelHandlerContext ctx, int initialCapacity, int maxCapacity) {
|
||||||
|
switch(ctx.channel().config().getDefaultHandlerByteBufType()) {
|
||||||
|
case DIRECT:
|
||||||
|
return ctx.alloc().directBuffer(initialCapacity, maxCapacity);
|
||||||
|
case PREFER_DIRECT:
|
||||||
|
return ctx.alloc().ioBuffer(initialCapacity, maxCapacity);
|
||||||
|
case HEAP:
|
||||||
|
return ctx.alloc().heapBuffer(initialCapacity, maxCapacity);
|
||||||
|
default:
|
||||||
|
throw new IllegalStateException();
|
||||||
|
}
|
||||||
|
}
|
||||||
private ChannelHandlerUtil() { }
|
private ChannelHandlerUtil() { }
|
||||||
|
|
||||||
public interface SingleInboundMessageHandler<T> {
|
public interface SingleInboundMessageHandler<T> {
|
||||||
@ -162,10 +213,10 @@ public final class ChannelHandlerUtil {
|
|||||||
boolean acceptInboundMessage(Object msg) throws Exception;
|
boolean acceptInboundMessage(Object msg) throws Exception;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Will get notified once {@link #inboundBufferUpdated(ChannelHandlerContext)} was called.
|
* Will get notified once {@link ChannelStateHandler#inboundBufferUpdated(ChannelHandlerContext)} was called.
|
||||||
*
|
*
|
||||||
* If this method returns {@code false} no further processing of the {@link MessageBuf}
|
* If this method returns {@code false} no further processing of the {@link MessageBuf}
|
||||||
* will be done until the next call of {@link #inboundBufferUpdated(ChannelHandlerContext)}.
|
* will be done until the next call of {@link ChannelStateHandler#inboundBufferUpdated(ChannelHandlerContext)}.
|
||||||
*
|
*
|
||||||
* This will return {@code true} by default, and may get overriden by sub-classes for
|
* This will return {@code true} by default, and may get overriden by sub-classes for
|
||||||
* special handling.
|
* special handling.
|
||||||
@ -201,7 +252,8 @@ public final class ChannelHandlerUtil {
|
|||||||
boolean acceptOutboundMessage(Object msg) throws Exception;
|
boolean acceptOutboundMessage(Object msg) throws Exception;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Will get notified once {@link #flush(ChannelHandlerContext, ChannelPromise)} was called.
|
* Will get notified once {@link ChannelOperationHandler#flush(ChannelHandlerContext, ChannelPromise)}
|
||||||
|
* was called.
|
||||||
*
|
*
|
||||||
* @param ctx the {@link ChannelHandlerContext} which this {@link ChannelHandler} belongs to
|
* @param ctx the {@link ChannelHandlerContext} which this {@link ChannelHandler} belongs to
|
||||||
*/
|
*/
|
||||||
@ -216,7 +268,7 @@ public final class ChannelHandlerUtil {
|
|||||||
void flush(ChannelHandlerContext ctx, T msg) throws Exception;
|
void flush(ChannelHandlerContext ctx, T msg) throws Exception;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Is called when {@link #flush(ChannelHandlerContext, ChannelPromise)} returns.
|
* Is called when {@link ChannelOperationHandler#flush(ChannelHandlerContext, ChannelPromise)} returns.
|
||||||
*
|
*
|
||||||
* Super-classes may-override this for special handling.
|
* Super-classes may-override this for special handling.
|
||||||
*
|
*
|
||||||
|
@ -22,6 +22,12 @@ import io.netty.buffer.ByteBuf;
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public interface ChannelInboundByteHandler extends ChannelInboundHandler {
|
public interface ChannelInboundByteHandler extends ChannelInboundHandler {
|
||||||
|
/**
|
||||||
|
* Return the {@link ByteBuf} which will be used for inbound data for the given {@link ChannelHandlerContext}.
|
||||||
|
* Implementations should take {@link ChannelConfig#getDefaultHandlerByteBufType()} into account.
|
||||||
|
* <p>
|
||||||
|
* Use of {@link ChannelHandlerUtil#allocate(ChannelHandlerContext)} is adviced.
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception;
|
ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception;
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ public abstract class ChannelInboundByteHandlerAdapter
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -44,7 +44,8 @@ public class ChannelOption<T> extends UniqueName {
|
|||||||
new ChannelOption<Boolean>("ALLOW_HALF_CLOSURE");
|
new ChannelOption<Boolean>("ALLOW_HALF_CLOSURE");
|
||||||
public static final ChannelOption<Boolean> AUTO_READ =
|
public static final ChannelOption<Boolean> AUTO_READ =
|
||||||
new ChannelOption<Boolean>("AUTO_READ");
|
new ChannelOption<Boolean>("AUTO_READ");
|
||||||
|
public static final ChannelOption<ChannelConfig.ChannelHandlerByteBufType> DEFAULT_HANDLER_BYTEBUF_TYPE =
|
||||||
|
new ChannelOption<ChannelConfig.ChannelHandlerByteBufType>("DEFAULT_HANDLER_BYTEBUF_TYPE");
|
||||||
public static final ChannelOption<Boolean> SO_BROADCAST =
|
public static final ChannelOption<Boolean> SO_BROADCAST =
|
||||||
new ChannelOption<Boolean>("SO_BROADCAST");
|
new ChannelOption<Boolean>("SO_BROADCAST");
|
||||||
public static final ChannelOption<Boolean> SO_KEEPALIVE =
|
public static final ChannelOption<Boolean> SO_KEEPALIVE =
|
||||||
|
@ -21,6 +21,12 @@ import io.netty.buffer.ByteBuf;
|
|||||||
* {@link ChannelOutboundHandler} which operates on bytes which are hold in a {@link ByteBuf}.
|
* {@link ChannelOutboundHandler} which operates on bytes which are hold in a {@link ByteBuf}.
|
||||||
*/
|
*/
|
||||||
public interface ChannelOutboundByteHandler extends ChannelOutboundHandler {
|
public interface ChannelOutboundByteHandler extends ChannelOutboundHandler {
|
||||||
|
/**
|
||||||
|
* Return the {@link ByteBuf} which will be used for outbound data for the given {@link ChannelHandlerContext}.
|
||||||
|
* Implementations should take {@link ChannelConfig#getDefaultHandlerByteBufType()} into account.
|
||||||
|
* <p>
|
||||||
|
* Use of {@link ChannelHandlerUtil#allocate(ChannelHandlerContext)} is adviced.
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception;
|
ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception;
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ public abstract class ChannelOutboundByteHandlerAdapter
|
|||||||
extends ChannelOperationHandlerAdapter implements ChannelOutboundByteHandler {
|
extends ChannelOperationHandlerAdapter implements ChannelOutboundByteHandler {
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -35,6 +35,7 @@ public class DefaultChannelConfig implements ChannelConfig {
|
|||||||
|
|
||||||
protected final Channel channel;
|
protected final Channel channel;
|
||||||
|
|
||||||
|
private volatile ChannelHandlerByteBufType handlerByteBufType = ChannelHandlerByteBufType.PREFER_DIRECT;
|
||||||
private volatile ByteBufAllocator allocator = DEFAULT_ALLOCATOR;
|
private volatile ByteBufAllocator allocator = DEFAULT_ALLOCATOR;
|
||||||
private volatile int connectTimeoutMillis = DEFAULT_CONNECT_TIMEOUT;
|
private volatile int connectTimeoutMillis = DEFAULT_CONNECT_TIMEOUT;
|
||||||
private volatile int writeSpinCount = 16;
|
private volatile int writeSpinCount = 16;
|
||||||
@ -49,7 +50,8 @@ public class DefaultChannelConfig implements ChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Map<ChannelOption<?>, Object> getOptions() {
|
public Map<ChannelOption<?>, Object> getOptions() {
|
||||||
return getOptions(null, CONNECT_TIMEOUT_MILLIS, WRITE_SPIN_COUNT, ALLOCATOR, AUTO_READ);
|
return getOptions(null, CONNECT_TIMEOUT_MILLIS, WRITE_SPIN_COUNT, ALLOCATOR, AUTO_READ,
|
||||||
|
DEFAULT_HANDLER_BYTEBUF_TYPE);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Map<ChannelOption<?>, Object> getOptions(
|
protected Map<ChannelOption<?>, Object> getOptions(
|
||||||
@ -99,6 +101,9 @@ public class DefaultChannelConfig implements ChannelConfig {
|
|||||||
if (option == AUTO_READ) {
|
if (option == AUTO_READ) {
|
||||||
return (T) Boolean.valueOf(isAutoRead());
|
return (T) Boolean.valueOf(isAutoRead());
|
||||||
}
|
}
|
||||||
|
if (option == DEFAULT_ALLOCATOR) {
|
||||||
|
return (T) getDefaultHandlerByteBufType();
|
||||||
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -115,6 +120,8 @@ public class DefaultChannelConfig implements ChannelConfig {
|
|||||||
setAllocator((ByteBufAllocator) value);
|
setAllocator((ByteBufAllocator) value);
|
||||||
} else if (option == AUTO_READ) {
|
} else if (option == AUTO_READ) {
|
||||||
setAutoRead((Boolean) value);
|
setAutoRead((Boolean) value);
|
||||||
|
} else if (option == DEFAULT_HANDLER_BYTEBUF_TYPE) {
|
||||||
|
setDefaultHandlerByteBufType((ChannelHandlerByteBufType) value);
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -187,4 +194,15 @@ public class DefaultChannelConfig implements ChannelConfig {
|
|||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ChannelHandlerByteBufType getDefaultHandlerByteBufType() {
|
||||||
|
return handlerByteBufType;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType handlerByteBufType) {
|
||||||
|
this.handlerByteBufType = handlerByteBufType;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -179,4 +179,7 @@ public interface DatagramChannelConfig extends ChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
DatagramChannelConfig setAutoRead(boolean autoRead);
|
DatagramChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
DatagramChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
package io.netty.channel.socket;
|
package io.netty.channel.socket;
|
||||||
|
|
||||||
import io.netty.buffer.ByteBufAllocator;
|
import io.netty.buffer.ByteBufAllocator;
|
||||||
|
import io.netty.channel.ChannelConfig;
|
||||||
import io.netty.channel.ChannelException;
|
import io.netty.channel.ChannelException;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
import io.netty.channel.DefaultChannelConfig;
|
import io.netty.channel.DefaultChannelConfig;
|
||||||
@ -384,4 +385,9 @@ public class DefaultDatagramChannelConfig extends DefaultChannelConfig implement
|
|||||||
public DatagramChannelConfig setAutoRead(boolean autoRead) {
|
public DatagramChannelConfig setAutoRead(boolean autoRead) {
|
||||||
return (DatagramChannelConfig) super.setAutoRead(autoRead);
|
return (DatagramChannelConfig) super.setAutoRead(autoRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DatagramChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
return (DatagramChannelConfig) super.setDefaultHandlerByteBufType(type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -162,4 +162,9 @@ public class DefaultServerSocketChannelConfig extends DefaultChannelConfig
|
|||||||
public ServerSocketChannelConfig setAutoRead(boolean autoRead) {
|
public ServerSocketChannelConfig setAutoRead(boolean autoRead) {
|
||||||
return (ServerSocketChannelConfig) super.setAutoRead(autoRead);
|
return (ServerSocketChannelConfig) super.setAutoRead(autoRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
return (ServerSocketChannelConfig) super.setDefaultHandlerByteBufType(type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
package io.netty.channel.socket;
|
package io.netty.channel.socket;
|
||||||
|
|
||||||
import io.netty.buffer.ByteBufAllocator;
|
import io.netty.buffer.ByteBufAllocator;
|
||||||
|
import io.netty.channel.ChannelConfig;
|
||||||
import io.netty.channel.ChannelException;
|
import io.netty.channel.ChannelException;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
import io.netty.channel.DefaultChannelConfig;
|
import io.netty.channel.DefaultChannelConfig;
|
||||||
@ -296,4 +297,9 @@ public class DefaultSocketChannelConfig extends DefaultChannelConfig
|
|||||||
public SocketChannelConfig setAutoRead(boolean autoRead) {
|
public SocketChannelConfig setAutoRead(boolean autoRead) {
|
||||||
return (SocketChannelConfig) super.setAutoRead(autoRead);
|
return (SocketChannelConfig) super.setAutoRead(autoRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
return (SocketChannelConfig) super.setDefaultHandlerByteBufType(type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -93,4 +93,7 @@ public interface ServerSocketChannelConfig extends ChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
ServerSocketChannelConfig setAutoRead(boolean autoRead);
|
ServerSocketChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
ServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -17,9 +17,9 @@ package io.netty.channel.socket;
|
|||||||
|
|
||||||
import io.netty.buffer.ByteBufAllocator;
|
import io.netty.buffer.ByteBufAllocator;
|
||||||
import io.netty.channel.ChannelConfig;
|
import io.netty.channel.ChannelConfig;
|
||||||
import io.netty.channel.ChannelHandler;
|
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
import io.netty.channel.ChannelOption;
|
import io.netty.channel.ChannelOption;
|
||||||
|
import io.netty.channel.ChannelStateHandler;
|
||||||
|
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
import java.net.StandardSocketOptions;
|
import java.net.StandardSocketOptions;
|
||||||
@ -148,7 +148,8 @@ public interface SocketChannelConfig extends ChannelConfig {
|
|||||||
/**
|
/**
|
||||||
* Sets whether the channel should not close itself when its remote peer shuts down output to
|
* Sets whether the channel should not close itself when its remote peer shuts down output to
|
||||||
* make the connection half-closed. If {@code true} the connection is not closed when the
|
* make the connection half-closed. If {@code true} the connection is not closed when the
|
||||||
* remote peer shuts down output. Instead, {@link ChannelHandler#userEventTriggered(ChannelHandlerContext, Object)}
|
* remote peer shuts down output. Instead,
|
||||||
|
* {@link ChannelStateHandler#userEventTriggered(ChannelHandlerContext, Object)}
|
||||||
* is invoked with a {@link ChannelInputShutdownEvent} object. If {@code false}, the connection
|
* is invoked with a {@link ChannelInputShutdownEvent} object. If {@code false}, the connection
|
||||||
* is closed automatically.
|
* is closed automatically.
|
||||||
*/
|
*/
|
||||||
@ -165,4 +166,7 @@ public interface SocketChannelConfig extends ChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
SocketChannelConfig setAutoRead(boolean autoRead);
|
SocketChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
SocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -223,4 +223,10 @@ final class AioServerSocketChannelConfig extends DefaultChannelConfig implements
|
|||||||
super.setAutoRead(autoRead);
|
super.setAutoRead(autoRead);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
super.setDefaultHandlerByteBufType(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -111,4 +111,7 @@ public interface AioSocketChannelConfig extends SocketChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
AioSocketChannelConfig setAutoRead(boolean autoRead);
|
AioSocketChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
AioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -356,4 +356,9 @@ final class DefaultAioSocketChannelConfig extends DefaultChannelConfig
|
|||||||
public AioSocketChannelConfig setAutoRead(boolean autoRead) {
|
public AioSocketChannelConfig setAutoRead(boolean autoRead) {
|
||||||
return (AioSocketChannelConfig) super.setAutoRead(autoRead);
|
return (AioSocketChannelConfig) super.setAutoRead(autoRead);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
return (AioSocketChannelConfig) super.setDefaultHandlerByteBufType(type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -130,4 +130,10 @@ public class DefaultOioServerSocketChannelConfig extends DefaultServerSocketChan
|
|||||||
super.setAutoRead(autoRead);
|
super.setAutoRead(autoRead);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public OioServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
super.setDefaultHandlerByteBufType(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -158,4 +158,10 @@ public class DefaultOioSocketChannelConfig extends DefaultSocketChannelConfig im
|
|||||||
super.setAutoRead(autoRead);
|
super.setAutoRead(autoRead);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public OioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
|
||||||
|
super.setDefaultHandlerByteBufType(type);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -72,4 +72,7 @@ public interface OioServerSocketChannelConfig extends ServerSocketChannelConfig
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
OioServerSocketChannelConfig setAutoRead(boolean autoRead);
|
OioServerSocketChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
OioServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -87,4 +87,7 @@ public interface OioSocketChannelConfig extends SocketChannelConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
OioSocketChannelConfig setAutoRead(boolean autoRead);
|
OioSocketChannelConfig setAutoRead(boolean autoRead);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
OioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ import io.netty.buffer.Unpooled;
|
|||||||
import io.netty.channel.Channel;
|
import io.netty.channel.Channel;
|
||||||
import io.netty.channel.ChannelDuplexHandler;
|
import io.netty.channel.ChannelDuplexHandler;
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
|
import io.netty.channel.ChannelHandlerUtil;
|
||||||
import io.netty.channel.ChannelInboundByteHandler;
|
import io.netty.channel.ChannelInboundByteHandler;
|
||||||
import io.netty.channel.ChannelInboundMessageHandler;
|
import io.netty.channel.ChannelInboundMessageHandler;
|
||||||
import io.netty.channel.ChannelInboundMessageHandlerAdapter;
|
import io.netty.channel.ChannelInboundMessageHandlerAdapter;
|
||||||
@ -413,7 +414,7 @@ public class LocalTransportThreadModelTest {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
|
||||||
return ctx.alloc().ioBuffer();
|
return ChannelHandlerUtil.allocate(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
x
Reference in New Issue
Block a user