[vlc-devel] commit: XCB/window: fix always on top ( Rémi Denis-Courmont )

git version control git at videolan.org
Wed May 13 20:09:34 CEST 2009


vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Wed May 13 20:16:38 2009 +0300| [c9a4092a131cfa984348e0c123a8e65d109033c7] | committer: Rémi Denis-Courmont 

XCB/window: fix always on top

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=c9a4092a131cfa984348e0c123a8e65d109033c7
---

 modules/video_output/xcb/window.c |   12 ++++++++----
 1 files changed, 8 insertions(+), 4 deletions(-)

diff --git a/modules/video_output/xcb/window.c b/modules/video_output/xcb/window.c
index 3b4f9ba..6b31351 100644
--- a/modules/video_output/xcb/window.c
+++ b/modules/video_output/xcb/window.c
@@ -114,6 +114,10 @@ xcb_atom_t get_atom (xcb_connection_t *conn, xcb_intern_atom_cookie_t ck)
     return atom;
 }
 
+#define NET_WM_STATE_REMOVE 0
+#define NET_WM_STATE_ADD    1
+#define NET_WM_STATE_TOGGLE 2
+
 /**
  * Create an X11 window.
  */
@@ -181,7 +185,7 @@ static int Open (vlc_object_t *obj)
     xcb_intern_atom_cookie_t wm_state_ck, wm_state_above_ck;
 
     wm_state_ck = xcb_intern_atom (conn, 0, 13, "_NET_WM_STATE");
-    wm_state_above_ck = xcb_intern_atom (conn, 0, 18, "_NET_WM_STATE_ABOVE");
+    wm_state_above_ck = xcb_intern_atom (conn, 0, 19, "_NET_WM_STATE_ABOVE");
 
     p_sys->wm_state = get_atom (conn, wm_state_ck);
     p_sys->wm_state_above = get_atom (conn, wm_state_above_ck);
@@ -289,16 +293,16 @@ static int Control (vout_window_t *wnd, int cmd, va_list ap)
         case VOUT_SET_STAY_ON_TOP:
         {   /* From EWMH "_WM_STATE" */
             xcb_client_message_event_t ev = {
-                .response_type = 0x80 | XCB_CLIENT_MESSAGE,
+                .response_type = XCB_CLIENT_MESSAGE,
                 .format = 32,
                 .window = wnd->handle.xid,
                 .type = p_sys->wm_state,
             };
             bool on = va_arg (ap, int);
 
-            ev.data.data32[0] = on;
+            ev.data.data32[0] = on ? NET_WM_STATE_ADD : NET_WM_STATE_REMOVE;
             ev.data.data32[1] = p_sys->wm_state_above;
-            ev.data.data32[1] = 289;
+            ev.data.data32[2] = 0;
             ev.data.data32[3] = 1;
 
             /* From ICCCM "Changing Window State" */




More information about the vlc-devel mailing list