Review Request 125655: Xembed SNI Proxy
Martin Gräßlin
mgraesslin at kde.org
Tue Nov 3 08:56:56 UTC 2015
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/125655/#review87902
-----------------------------------------------------------
Ship it!
Ship It!
- Martin Gräßlin
On Oct. 30, 2015, 4:54 p.m., David Edmundson wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://git.reviewboard.kde.org/r/125655/
> -----------------------------------------------------------
>
> (Updated Oct. 30, 2015, 4:54 p.m.)
>
>
> Review request for Plasma.
>
>
> Repository: plasma-workspace
>
>
> Description
> -------
>
> The goal of this project is to make xembed system trays available in Plasma.
>
> This is to allow legacy apps (xchat, pidgin, tuxguitar) etc. system trays[1] available in Plasma which only supports StatusNotifierItem [2].
>
> Ideally we also want this to work in an xwayland session, making X system tray icons available even when plasmashell only has a wayland connection.
>
> How it works (in theory)
>
> * We register a window as a system tray container
> * We render embeded windows composited offscreen
> * We render contents into an image and send this over DBus via the SNI protocol
> * XDamage events trigger a repaint
> * Activate and context menu events are replyed via X send event into the embedded container as left and right clicks
>
>
> Code is a mix of hacks and bodges bashing client apps into place, and I happily acknowledge it looks pretty bad. Unfotunately most of it seems to be needed, but I'd love to be proved wrong on most of it.
>
> ---
>
> CMakeLists changes are obviously currently wrong, I can strip half of find_packages and I need an add_subdirectory in the root file, but it's easier for me to sync with the separate repo mirror this way till we're close to merging. I expect this to take quite some revisions.
>
>
> Diffs
> -----
>
> xembed-sni-proxy/xembedsniproxy.desktop PRE-CREATION
> xembed-sni-proxy/xcbutils.h PRE-CREATION
> xembed-sni-proxy/sniproxy.cpp PRE-CREATION
> xembed-sni-proxy/snidbus.cpp PRE-CREATION
> xembed-sni-proxy/sniproxy.h PRE-CREATION
> xembed-sni-proxy/org.kde.StatusNotifierWatcher.xml PRE-CREATION
> xembed-sni-proxy/snidbus.h PRE-CREATION
> xembed-sni-proxy/org.kde.StatusNotifierItem.xml PRE-CREATION
> xembed-sni-proxy/main.cpp PRE-CREATION
> xembed-sni-proxy/fdoselectionmanager.cpp PRE-CREATION
> xembed-sni-proxy/fdoselectionmanager.h PRE-CREATION
> CMakeLists.txt 50091ea8ffb01177d34e18217b929cfb9ede3d23
> xembed-sni-proxy/CMakeLists.txt PRE-CREATION
> xembed-sni-proxy/Readme.md PRE-CREATION
>
> Diff: https://git.reviewboard.kde.org/r/125655/diff/
>
>
> Testing
> -------
>
>
> Thanks,
>
> David Edmundson
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/plasma-devel/attachments/20151103/25f2dd7e/attachment.html>
More information about the Plasma-devel
mailing list