-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/125655/
-----------------------------------------------------------

(Updated Nov. 3, 2015, 1:09 p.m.)


Status
------

This change has been marked as submitted.


Review request for Plasma.


Changes
-------

Submitted with commit 2fc947526df5d7f62db79e7f224cc13b1aa15493 by David 
Edmundson to branch master.


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

_______________________________________________
Plasma-devel mailing list
Plasma-devel@kde.org
https://mail.kde.org/mailman/listinfo/plasma-devel

Reply via email to