Summary: | Since Plasma 6.1, the icons in systray for gtk2 applications do not work on Wayland after the first click | ||
---|---|---|---|
Product: | [Plasma] plasmashell | Reporter: | painless roaster <painless.roaster> |
Component: | XembedSNIProxy | Assignee: | Plasma Bugs List <plasma-bugs> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | bugseforuns, kde, kdedev, materka, mdogg, nate, notmart, siavosh.kasravi, torriem, xsoadxx075 |
Priority: | NOR | Keywords: | regression, wayland |
Version: | 6.1.3 | ||
Target Milestone: | 1.0 | ||
Platform: | Other | ||
OS: | Linux | ||
Latest Commit: | https://invent.kde.org/plasma/plasma-workspace/-/commit/e2cc2c2aab112edd29d1f713df1769c068f3f20f | Version Fixed In: | 6.2.0 |
Sentry Crash Report: | |||
Attachments: | simple test application |
can confirm with the test app edit: i can only *partly* reproduce it: if i start that systray test app, right clicking works and shows a "quit" entry, which all works. But, if i left click it, then after that right click won't work anymore. can you confirm? reverting xembedsniproxy doesn't seem to solve the issue for me, which is more "click forwarding only works once" than not working at all (In reply to Marco Martin from comment #2) > edit: i can only *partly* reproduce it: if i start that systray test app, > right clicking works and shows a "quit" entry, which all works. > > But, if i left click it, then after that right click won't work anymore. can > you confirm? Even the first right click doesn't work for me. I am testing on Fedora FC40. But even your testing conclusion confirms the problem. There is a bug somewhere since 6.1 that affects gtk2 applications. It only not working with wayland. If I install plasma-workspace-x11 and use x11 instead of wayland, it works. related ticket: https://bugs.kde.org/show_bug.cgi?id=488778 *** Bug 488778 has been marked as a duplicate of this bug. *** A possibly relevant merge request was started @ https://invent.kde.org/plasma/plasma-workspace/-/merge_requests/4487 A possibly relevant merge request was started @ https://invent.kde.org/plasma/plasma-workspace/-/merge_requests/4487 having this problem as well with 'hexchat' arch linux with kde 6.1 *** Bug 489590 has been marked as a duplicate of this bug. *** A possibly relevant merge request was started @ https://invent.kde.org/plasma/plasma-workspace/-/merge_requests/4505 Git commit 7ee0f7a2cdac1a348af3f634ad3c8c2073b55ce6 by David Edmundson, on behalf of David Redondo. Committed on 09/07/2024 at 10:33. Pushed by davidedmundson into branch 'master'. xembedsniproxy: Warp pointer to click location on wayland Some clients track pointer focus and ignore clicks if they think they dont have a window under the cursor. On Wayland pointer focus is driven by the compositor - the client receives a click without a prior enter event. To workaround this warp the pointer to the click position before clicking which generates the needed enter. FIXED-IN:6.1.3 M +4 -0 xembed-sni-proxy/sniproxy.cpp https://invent.kde.org/plasma/plasma-workspace/-/commit/7ee0f7a2cdac1a348af3f634ad3c8c2073b55ce6 Git commit e2cc2c2aab112edd29d1f713df1769c068f3f20f by David Edmundson, on behalf of David Edmundson. Committed on 09/07/2024 at 10:53. Pushed by davidedmundson into branch 'Plasma/6.1'. xembedsniproxy: Warp pointer to click location on wayland Some clients track pointer focus and ignore clicks if they think they dont have a window under the cursor. On Wayland pointer focus is driven by the compositor - the client receives a click without a prior enter event. To workaround this warp the pointer to the click position before clicking which generates the needed enter. FIXED-IN:6.1.3 (cherry picked from commit 7ee0f7a2cdac1a348af3f634ad3c8c2073b55ce6) Co-authored-by: David Redondo <kde@david-redondo.de> M +4 -0 xembed-sni-proxy/sniproxy.cpp https://invent.kde.org/plasma/plasma-workspace/-/commit/e2cc2c2aab112edd29d1f713df1769c068f3f20f Git commit c13cb9026a467e2469ec266a0b4ba156e6152e6a by Fushan Wen. Committed on 09/07/2024 at 12:33. Pushed by fusionfuture into branch 'master'. appiumtests: test xembedsniproxy with real click M +61 -58 appiumtests/applets/systemtraytest.py https://invent.kde.org/plasma/plasma-workspace/-/commit/c13cb9026a467e2469ec266a0b4ba156e6152e6a Not completely fixed on Plasma 6.1.3: Steps to reproduce: 1. open Hexchat irc client 2. right-click on the tray icon of Hexchat 3. dismiss the context menu by clicking on Hexchat window 4. right or left click on the tray icon of Hexchat Result: a subtle animation with the tray icon happens after the last step, nothing else Operating System: Arch Linux KDE Plasma Version: 6.1.3 KDE Frameworks Version: 6.4.0 Qt Version: 6.7.2 Graphics Platform: Wayland I can't reproduce that with current git master, FWIW. I was unable to reproduce either Plasma 6.1.3 using Hexchat git-master using the sample systray application This bug is very much still present in 6.1.3. Running Fedora 40 with KDE Wayland 6.1.3. Both hexchat and pidgin tray icons do not work still. The person who said they couldn't reproduce with hexchat and plasma 6.1.3 was apparently using X11, not wayland. Any chance of re-opening this bug? It's not the end of the world, but it would be nice to use pidgin again. while it's not working in 6.1.3, it does appear to work when I build from git master. so hopefully in the next release we'll see it working again. Hmm. After working for a few days, it's now not working again. This is with the binary from git master. So it appears the bug is not yet truly fixed. I have 6 applications that are configured to 'Minimize to the Systray when Closed'. Signal-Desktop, Spotify, KeePassXC, SMPlayer, DeaDBeeF, and HexChat. All of these apps behave as expected when logged into x11, however in a Wayland session, DeadBeeF and HedChat do not. HexChat - The HexChat app icon appears in the Systray, and when hovering over the HexChat icon, a pop-up title "HexChat" appears. Left or right-clicking the icon does nothing. The application cannot be brought back up once minimized to the Systray in Wayland (at least I can't figure out how to bring it back up). Running 'hexchat' again brings up a brand new instance, which isn't helpful. DeaDBeeF - Hitting the 'x' to close the app/minimize it to he Systray causes DeaDBeeF to completely disappear, however the application continues to run (continues playing audio files) just as it should - No icon in the Systray or anywhere else. Running the program from the Plasma 6 launcher or running 'deadbeef' from bash brings the application back up without any process interruption, which is nice. The only issue with this application is that in Wayland, it vanishes rather than entering the Systray as it should - but at least it is possible to have it re-present itself on the Wayland desktop. The link below provides some technical info about my hardware, OS, etc. --> https://www.mdogg.com/mdogg/temp/mdogg-SysInfo_kde-wayland_bug-489286.txt Thank you for your time and consideration, and I look forward to a resolution in Plasma version 6.2.0 I cannot reproduce with HexChat. Plasma 6.1.80 (compiled from master), KDE Neon with libwayland 1.22, wayland-protocols 1.36, XWayland 24.1 (compiled from sources) I CAN reproduce with HexChat and XWayland from KDE Neon - 23.2.4! Both Plasma 6.1.4 and compiled from master So the problem is with too old XWayland. IIRC recently there were some improvements in xembedsniproxy that require newer XWayland. |
Created attachment 171065 [details] simple test application since version 6.1 the icons in systray for gtk2 applications do not work I attach a simple test application try: gcc systray.c -o systray `pkg-config --cflags --libs gtk+-2.0` ./systray try right click on new icon in systray result: no response