This is an automated email from the ASF dual-hosted git repository.

rmaucher pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/tomcat.git


The following commit(s) were added to refs/heads/main by this push:
     new d3c87f2e9b Refactor for consistency
d3c87f2e9b is described below

commit d3c87f2e9b65c0caf5c5bcfe7426eecb92838177
Author: remm <[email protected]>
AuthorDate: Tue May 19 21:37:11 2026 +0200

    Refactor for consistency
    
    Removes weird duplicate constructor parameter.
---
 java/org/apache/coyote/http2/Http2AsyncParser.java | 36 +++++++++++++++-------
 .../coyote/http2/Http2AsyncUpgradeHandler.java     |  2 +-
 2 files changed, 26 insertions(+), 12 deletions(-)

diff --git a/java/org/apache/coyote/http2/Http2AsyncParser.java 
b/java/org/apache/coyote/http2/Http2AsyncParser.java
index 5274374d0d..31a6c7735e 100644
--- a/java/org/apache/coyote/http2/Http2AsyncParser.java
+++ b/java/org/apache/coyote/http2/Http2AsyncParser.java
@@ -24,6 +24,7 @@ import java.util.concurrent.TimeUnit;
 import jakarta.servlet.http.WebConnection;
 
 import org.apache.coyote.ProtocolException;
+import org.apache.tomcat.util.net.AbstractEndpoint;
 import org.apache.tomcat.util.net.SocketEvent;
 import org.apache.tomcat.util.net.SocketWrapperBase;
 import org.apache.tomcat.util.net.SocketWrapperBase.BlockingMode;
@@ -33,16 +34,15 @@ import 
org.apache.tomcat.util.net.SocketWrapperBase.CompletionState;
 
 class Http2AsyncParser extends Http2Parser {
 
+    private final AsyncOutput output;
     private final SocketWrapperBase<?> socketWrapper;
-    private final Http2AsyncUpgradeHandler upgradeHandler;
     private volatile Throwable error = null;
 
-    Http2AsyncParser(String connectionId, Input input, Output output, 
SocketWrapperBase<?> socketWrapper,
-            Http2AsyncUpgradeHandler upgradeHandler) {
+    Http2AsyncParser(String connectionId, Input input, Output output, 
SocketWrapperBase<?> socketWrapper) {
         super(connectionId, input, output);
         this.socketWrapper = socketWrapper;
         socketWrapper.getSocketBufferHandler().expand(input.getMaxFrameSize());
-        this.upgradeHandler = upgradeHandler;
+        this.output = (AsyncOutput) output;
     }
 
 
@@ -121,13 +121,12 @@ class Http2AsyncParser extends Http2Parser {
                     socketWrapper.unRead(payload);
                 }
                 // Finish processing the connection
-                upgradeHandler.processConnectionCallback(webConnection, 
stream);
+                output.processConnectionCallback(webConnection, stream);
             } else {
-                upgradeHandler
-                        .closeConnection(new 
ConnectionException(error.getMessage(), Http2Error.PROTOCOL_ERROR, error));
+                output.closeConnection(new 
ConnectionException(error.getMessage(), Http2Error.PROTOCOL_ERROR, error));
             }
             // Continue reading frames
-            upgradeHandler.upgradeDispatch(SocketEvent.OPEN_READ);
+            output.upgradeDispatch(SocketEvent.OPEN_READ);
         }
     }
 
@@ -281,7 +280,7 @@ class Http2AsyncParser extends Http2Parser {
                                     readUnknownFrame(streamId, frameTypeId, 
flags, payloadSize, payload);
                             }
                         }
-                        if (!upgradeHandler.isOverheadLimitExceeded()) {
+                        if (!output.isOverheadLimitExceeded()) {
                             // See if there is a new 9 byte header and 
continue parsing if possible
                             if (payload.remaining() >= 9) {
                                 int position = payload.position();
@@ -319,7 +318,7 @@ class Http2AsyncParser extends Http2Parser {
             if (state == CompletionState.DONE) {
                 // The call was not completed inline, so must start reading 
new frames
                 // or process the stream exception
-                upgradeHandler.upgradeDispatch(SocketEvent.OPEN_READ);
+                output.upgradeDispatch(SocketEvent.OPEN_READ);
             }
         }
 
@@ -331,10 +330,25 @@ class Http2AsyncParser extends Http2Parser {
                 log.debug(sm.getString("http2Parser.error", connectionId, 
Integer.valueOf(streamId), frameType), e);
             }
             if (state == null || state == CompletionState.DONE) {
-                upgradeHandler.upgradeDispatch(SocketEvent.ERROR);
+                output.upgradeDispatch(SocketEvent.ERROR);
             }
         }
 
     }
 
+    /**
+     * Interface that must be implemented to receive notifications from the 
parser as it processes incoming frames.
+     */
+    interface AsyncOutput extends Output {
+
+        boolean isOverheadLimitExceeded();
+
+        AbstractEndpoint.Handler.SocketState upgradeDispatch(SocketEvent 
status);
+
+        void closeConnection(Http2Exception ce);
+
+        void processConnectionCallback(WebConnection webConnection, Stream 
stream);
+
+    }
+
 }
diff --git a/java/org/apache/coyote/http2/Http2AsyncUpgradeHandler.java 
b/java/org/apache/coyote/http2/Http2AsyncUpgradeHandler.java
index 83b9adb6d7..77c3e4cf35 100644
--- a/java/org/apache/coyote/http2/Http2AsyncUpgradeHandler.java
+++ b/java/org/apache/coyote/http2/Http2AsyncUpgradeHandler.java
@@ -94,7 +94,7 @@ public class Http2AsyncUpgradeHandler extends 
Http2UpgradeHandler {
 
     @Override
     protected Http2Parser getParser(String connectionId) {
-        return new Http2AsyncParser(connectionId, this, this, socketWrapper, 
this);
+        return new Http2AsyncParser(connectionId, this, this, socketWrapper);
     }
 
 


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to