From 9e02a9bbee4cd3db1fa08955cb7fe4515bf3c50c Mon Sep 17 00:00:00 2001 From: Norman Maurer Date: Thu, 17 Apr 2014 16:01:26 +0200 Subject: [PATCH] Move validatePromise(...) to ChannelHandlerInvokerUtil. Related to [#2398] Motivation: Once a user implement a custom ChannelHandlerInvoker it is needed to validate the ChannelPromise. We should expose a utility method for this. Modifications: Move validatePromise(...) from DefaultChannelHandlerInvoker to ChannelHandlerInvokerUtil and make it public. Result: User is able to reuse code --- .../channel/ChannelHandlerInvokerUtil.java | 40 +++++++++++++++++++ .../channel/DefaultChannelHandlerInvoker.java | 39 ------------------ 2 files changed, 40 insertions(+), 39 deletions(-) diff --git a/transport/src/main/java/io/netty/channel/ChannelHandlerInvokerUtil.java b/transport/src/main/java/io/netty/channel/ChannelHandlerInvokerUtil.java index 2b9df27eef68..7cfb0bb2c4b0 100644 --- a/transport/src/main/java/io/netty/channel/ChannelHandlerInvokerUtil.java +++ b/transport/src/main/java/io/netty/channel/ChannelHandlerInvokerUtil.java @@ -16,6 +16,8 @@ package io.netty.channel; +import io.netty.util.internal.StringUtil; + import java.net.SocketAddress; import static io.netty.channel.DefaultChannelPipeline.*; @@ -174,6 +176,44 @@ public static void invokeWriteAndFlushNow(ChannelHandlerContext ctx, Object msg, invokeFlushNow(ctx); } + public static boolean validatePromise( + ChannelHandlerContext ctx, ChannelPromise promise, boolean allowVoidPromise) { + if (ctx == null) { + throw new NullPointerException("ctx"); + } + + if (promise == null) { + throw new NullPointerException("promise"); + } + + if (promise.isDone()) { + if (promise.isCancelled()) { + return false; + } + throw new IllegalArgumentException("promise already done: " + promise); + } + + if (promise.channel() != ctx.channel()) { + throw new IllegalArgumentException(String.format( + "promise.channel does not match: %s (expected: %s)", promise.channel(), ctx.channel())); + } + + if (promise.getClass() == DefaultChannelPromise.class) { + return true; + } + + if (!allowVoidPromise && promise instanceof VoidChannelPromise) { + throw new IllegalArgumentException( + StringUtil.simpleClassName(VoidChannelPromise.class) + " not allowed for this operation"); + } + + if (promise instanceof AbstractChannel.CloseFuture) { + throw new IllegalArgumentException( + StringUtil.simpleClassName(AbstractChannel.CloseFuture.class) + " not allowed in a pipeline"); + } + return true; + } + private static void notifyHandlerException(ChannelHandlerContext ctx, Throwable cause) { if (inExceptionCaught(cause)) { if (logger.isWarnEnabled()) { diff --git a/transport/src/main/java/io/netty/channel/DefaultChannelHandlerInvoker.java b/transport/src/main/java/io/netty/channel/DefaultChannelHandlerInvoker.java index 71fd7b9e7c6f..1e024d7e2e54 100644 --- a/transport/src/main/java/io/netty/channel/DefaultChannelHandlerInvoker.java +++ b/transport/src/main/java/io/netty/channel/DefaultChannelHandlerInvoker.java @@ -20,7 +20,6 @@ import io.netty.util.ReferenceCountUtil; import io.netty.util.concurrent.EventExecutor; import io.netty.util.internal.OneTimeTask; -import io.netty.util.internal.StringUtil; import java.net.SocketAddress; @@ -397,44 +396,6 @@ public void invokeWriteAndFlush(ChannelHandlerContext ctx, Object msg, ChannelPr invokeWrite(ctx, msg, true, promise); } - private static boolean validatePromise( - ChannelHandlerContext ctx, ChannelPromise promise, boolean allowVoidPromise) { - if (ctx == null) { - throw new NullPointerException("ctx"); - } - - if (promise == null) { - throw new NullPointerException("promise"); - } - - if (promise.isDone()) { - if (promise.isCancelled()) { - return false; - } - throw new IllegalArgumentException("promise already done: " + promise); - } - - if (promise.channel() != ctx.channel()) { - throw new IllegalArgumentException(String.format( - "promise.channel does not match: %s (expected: %s)", promise.channel(), ctx.channel())); - } - - if (promise.getClass() == DefaultChannelPromise.class) { - return true; - } - - if (!allowVoidPromise && promise instanceof VoidChannelPromise) { - throw new IllegalArgumentException( - StringUtil.simpleClassName(VoidChannelPromise.class) + " not allowed for this operation"); - } - - if (promise instanceof AbstractChannel.CloseFuture) { - throw new IllegalArgumentException( - StringUtil.simpleClassName(AbstractChannel.CloseFuture.class) + " not allowed in a pipeline"); - } - return true; - } - private void safeExecuteInbound(Runnable task, Object msg) { boolean success = false; try {