From d1cb2b052defe7a4d8ed6d7d9858e69475899aa9 Mon Sep 17 00:00:00 2001 From: markt Date: Fri, 8 Jul 2011 11:56:33 +0000 Subject: [PATCH] Completely align process methods git-svn-id: https://svn.apache.org/repos/asf/tomcat/trunk@1144276 13f79535-47bb-0310-9956-ffa450edef68 --- java/org/apache/coyote/ajp/AjpAprProtocol.java | 15 +++++++++------ java/org/apache/coyote/ajp/AjpNioProtocol.java | 15 +++++++++------ java/org/apache/coyote/ajp/AjpProtocol.java | 14 ++++++++++---- 3 files changed, 28 insertions(+), 16 deletions(-) diff --git a/java/org/apache/coyote/ajp/AjpAprProtocol.java b/java/org/apache/coyote/ajp/AjpAprProtocol.java index b0266358e..50b25add2 100644 --- a/java/org/apache/coyote/ajp/AjpAprProtocol.java +++ b/java/org/apache/coyote/ajp/AjpAprProtocol.java @@ -134,9 +134,14 @@ public class AjpAprProtocol extends AbstractAjpProtocol { * required. */ public void release(SocketWrapper socket, - AjpAprProcessor processor, boolean isSocketClosing) { + AjpAprProcessor processor, boolean isSocketClosing, + boolean addToPoller) { processor.recycle(isSocketClosing); recycledProcessors.offer(processor); + if (addToPoller) { + ((AprEndpoint)proto.endpoint).getPoller().add( + socket.getSocket().longValue()); + } } @@ -176,12 +181,10 @@ public class AjpAprProtocol extends AbstractAjpProtocol { } else if (state == SocketState.OPEN){ // In keep-alive but between requests. OK to recycle // processor. Continue to poll for the next request. - release(socket, processor, false); - ((AprEndpoint)proto.endpoint).getPoller().add( - socket.getSocket().longValue()); + release(socket, processor, false, true); } else { // Connection closed. OK to recycle the processor. - release(socket, processor, true); + release(socket, processor, true, false); } return state; } catch(java.net.SocketException e) { @@ -203,7 +206,7 @@ public class AjpAprProtocol extends AbstractAjpProtocol { // less-than-verbose logs. log.error(sm.getString("ajpprotocol.proto.error"), e); } - release(socket, processor, true); + release(socket, processor, true, false); return SocketState.CLOSED; } diff --git a/java/org/apache/coyote/ajp/AjpNioProtocol.java b/java/org/apache/coyote/ajp/AjpNioProtocol.java index 1a04b666d..baeaf5c3c 100644 --- a/java/org/apache/coyote/ajp/AjpNioProtocol.java +++ b/java/org/apache/coyote/ajp/AjpNioProtocol.java @@ -163,17 +163,21 @@ public class AjpNioProtocol extends AbstractAjpProtocol { } } - /** * Expected to be used by the handler once the processor is no longer * required. */ public void release(SocketWrapper socket, - AjpNioProcessor processor, boolean isSocketClosing) { + AjpNioProcessor processor, boolean isSocketClosing, + boolean addToPoller) { processor.recycle(isSocketClosing); recycledProcessors.offer(processor); + if (addToPoller) { + socket.getSocket().getPoller().add(socket.getSocket()); + } } + @Override public SocketState process(SocketWrapper socket, SocketStatus status) { @@ -210,11 +214,10 @@ public class AjpNioProtocol extends AbstractAjpProtocol { } else if (state == SocketState.OPEN){ // In keep-alive but between requests. OK to recycle // processor. Continue to poll for the next request. - release(socket, processor, false); - socket.getSocket().getPoller().add(socket.getSocket()); + release(socket, processor, false, true); } else { // Connection closed. OK to recycle the processor. - release(socket, processor, true); + release(socket, processor, true, false); } return state; } catch(java.net.SocketException e) { @@ -236,7 +239,7 @@ public class AjpNioProtocol extends AbstractAjpProtocol { // less-than-verbose logs. log.error(sm.getString("ajpprotocol.proto.error"), e); } - release(socket, processor, true); + release(socket, processor, true, false); return SocketState.CLOSED; } diff --git a/java/org/apache/coyote/ajp/AjpProtocol.java b/java/org/apache/coyote/ajp/AjpProtocol.java index fa4b979da..014d9104e 100644 --- a/java/org/apache/coyote/ajp/AjpProtocol.java +++ b/java/org/apache/coyote/ajp/AjpProtocol.java @@ -127,9 +127,15 @@ public class AjpProtocol extends AbstractAjpProtocol { /** * Expected to be used by the handler once the processor is no longer * required. + * + * @param socket Ignored for BIO + * @param processor + * @param isSocketClosing + * @param addToPoller Ignored for BIO */ public void release(SocketWrapper socket, - AjpProcessor processor, boolean isSocketClosing) { + AjpProcessor processor, boolean isSocketClosing, + boolean addToPoller) { processor.recycle(isSocketClosing); recycledProcessors.offer(processor); } @@ -171,10 +177,10 @@ public class AjpProtocol extends AbstractAjpProtocol { } else if (state == SocketState.OPEN){ // In keep-alive but between requests. OK to recycle // processor. Continue to poll for the next request. - release(socket, processor, false); + release(socket, processor, false, true); } else { // Connection closed. OK to recycle the processor. - release(socket, processor, true); + release(socket, processor, true, false); } return state; } catch(java.net.SocketException e) { @@ -196,7 +202,7 @@ public class AjpProtocol extends AbstractAjpProtocol { // less-than-verbose logs. log.error(sm.getString("ajpprotocol.proto.error"), e); } - release(socket, processor, true); + release(socket, processor, true, false); return SocketState.CLOSED; } -- 2.11.0