external/java_websocket/UnpackedTarball_java_websocket.mk                      
|    1 
 external/java_websocket/patches/0001-cid-1545249-Bad-bit-shift-operation.patch 
|   50 ++++++++++
 2 files changed, 51 insertions(+)

New commits:
commit f2019dd0e5493d7a33c8a0cea17bc110dcb4271c
Author:     Caolán McNamara <caolan.mcnam...@collabora.com>
AuthorDate: Wed Oct 4 15:22:28 2023 +0100
Commit:     Caolán McNamara <caolan.mcnam...@collabora.com>
CommitDate: Thu Oct 5 11:37:33 2023 +0200

    cid#1545249 Bad bit shift operation
    
    Change-Id: I90a6e1751891e57543a2b2f4312b424df6080f95
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/157571
    Tested-by: Jenkins
    Tested-by: Caolán McNamara <caolan.mcnam...@collabora.com>
    Reviewed-by: Caolán McNamara <caolan.mcnam...@collabora.com>

diff --git a/external/java_websocket/UnpackedTarball_java_websocket.mk 
b/external/java_websocket/UnpackedTarball_java_websocket.mk
index 5b619c2c9e92..1e116656f65b 100644
--- a/external/java_websocket/UnpackedTarball_java_websocket.mk
+++ b/external/java_websocket/UnpackedTarball_java_websocket.mk
@@ -24,6 +24,7 @@ $(eval $(call gb_UnpackedTarball_add_patches,java_websocket,\
        
external/java_websocket/patches/0001-cid-1545515-Dm-Dubious-method-used.patch \
        
external/java_websocket/patches/0001-cid-1546264-Dm-Dubious-method-used.patch \
        
external/java_websocket/patches/0001-cid-1546341-Resource-leak-on-an-exceptional-path.patch
 \
+       
external/java_websocket/patches/0001-cid-1545249-Bad-bit-shift-operation.patch \
 ))
 
 # vim: set noet sw=4 ts=4:
diff --git 
a/external/java_websocket/patches/0001-cid-1545249-Bad-bit-shift-operation.patch
 
b/external/java_websocket/patches/0001-cid-1545249-Bad-bit-shift-operation.patch
new file mode 100644
index 000000000000..759038d8d331
--- /dev/null
+++ 
b/external/java_websocket/patches/0001-cid-1545249-Bad-bit-shift-operation.patch
@@ -0,0 +1,50 @@
+From 49a74350016b59c4cca054c5802b4437c0b3857f Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Caol=C3=A1n=20McNamara?= <caolan.mcnam...@collabora.com>
+Date: Wed, 4 Oct 2023 15:19:13 +0100
+Subject: [PATCH] cid#1545249 Bad bit shift operation
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+https://docs.oracle.com/javase/specs/jls/se7/html/jls-15.html#jls-15.19
+
+If the promoted type of the left-hand operand is int, only the five
+lowest-order bits of the right-hand operand are used as the shift
+distance. It is as if the right-hand operand were subjected to a bitwise
+logical AND operator & (§15.22.1) with the mask value 0x1f (0b11111).
+The shift distance actually used is therefore always in the range 0 to
+31, inclusive.
+
+so a >>> of 32 is the same as >>> 0 so this is
+result = 31 * result + (maxFrameSize ^ maxFrameSize);
+i.e.
+result = 31 * result + (0);
+
+which all looks a bit dubious.
+
+Working theory from https://gerrit.libreoffice.org/c/core/+/157571/1 is
+that at some point maxFrameSize was a long value, and then got changed
+to an int, but the hashCode() was not updated and should now read as
+changed here.
+
+    result = 31 * result + maxFrameSize;
+---
+ src/main/java/org/java_websocket/drafts/Draft_6455.java | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/src/main/java/org/java_websocket/drafts/Draft_6455.java 
b/src/main/java/org/java_websocket/drafts/Draft_6455.java
+index 1e08448..635fa1f 100644
+--- a/src/main/java/org/java_websocket/drafts/Draft_6455.java
++++ b/src/main/java/org/java_websocket/drafts/Draft_6455.java
+@@ -1150,7 +1150,7 @@ public class Draft_6455 extends Draft {
+   public int hashCode() {
+     int result = negotiatedExtension != null ? negotiatedExtension.hashCode() 
: 0;
+     result = 31 * result + (protocol != null ? protocol.hashCode() : 0);
+-    result = 31 * result + (maxFrameSize ^ (maxFrameSize >>> 32));
++    result = 31 * result + maxFrameSize;
+     return result;
+   }
+ 
+-- 
+2.41.0
+

Reply via email to