RFR: 8372756: Mouse additional buttons and horizontal scrolling are broken on XWayland GNOME >= 47 after JDK-8351907

Alexander Zvegintsev azvegint at openjdk.org
Wed Dec 3 00:25:20 UTC 2025


On Wed, 3 Dec 2025 00:04:43 GMT, Alexander Zvegintsev <azvegint at openjdk.org> wrote:

> The #25265 change introduced an artificial restriction that is actually unnecessary and harmful:
> 
> https://github.com/openjdk/jdk/blob/f5e4cd7f0d12fd21399b192b32a5c9abfe8a3564/src/java.desktop/unix/classes/sun/awt/X11/XToolkit.java#L1526-L1529
> 
>> Trying to click any mouse additional button raises an exception like the following:
>>
>> WARN - sun.awt.X11.XToolkit - Exception on Toolkit thread
> java.lang.IllegalArgumentException: Nonexistent button 6
>         at java.desktop/java.awt.event.MouseEvent.<init>(MouseEvent.java:774)
>         at java.desktop/sun.awt.X11.XWindow.handleButtonPressRelease(XWindow.java:765)
>         at java.desktop/sun.awt.X11.XContentWindow.handleButtonPressRelease(XContentWindow.java:45)
>         at java.desktop/sun.awt.X11.XBaseWindow.dispatchEvent(XBaseWindow.java:1206)
>         at java.desktop/sun.awt.X11.XBaseWindow.dispatchToWindow(XBaseWindow.java:1178)
>         at java.desktop/sun.awt.X11.XToolkit.dispatchEvent(XToolkit.java:939)
>         at java.desktop/sun.awt.X11.XToolkit.run(XToolkit.java:1086)
>         at java.desktop/sun.awt.X11.XToolkit.run(XToolkit.java:968)
>         at java.base/java.lang.Thread.run(Thread.java:1583)
> 
> This changeset simply reverses the check, returning it to its original state.
> 
> The actual check for the supported mouse buttons for the robot is maintained here.
> 
> https://github.com/openjdk/jdk/blob/f5e4cd7f0d12fd21399b192b32a5c9abfe8a3564/src/java.desktop/share/classes/java/awt/Robot.java#L367-L371
> 
> https://github.com/openjdk/jdk/blob/f5e4cd7f0d12fd21399b192b32a5c9abfe8a3564/src/java.desktop/share/classes/java/awt/Robot.java#L208-L214

src/java.desktop/unix/classes/sun/awt/X11/XToolkit.java line 1530:

> 1528:                 //If we have 3 physical buttons and a wheel, we report 3 buttons.
> 1529:                 //If we have 1,2,3 physical buttons, we report it as is i.e. 1,2 or 3 respectively.
> 1530:                 if (numberOfButtons >= 5) {

Suggestion:

                if (numberOfButtons > 5) {

It actually should be `>5`, without it the `numberOfButtons == 5` in `else if` branch is always false.

I want to put the fix to 26, so I intentionally left it as it was before because it had been tested for years. Once we agree on that, I'll file an issue.

-------------

PR Review Comment: https://git.openjdk.org/jdk/pull/28621#discussion_r2583185136


More information about the client-libs-dev mailing list