[MPlayer-dev-eng] [PATCH] process window-manager close events

Reimar Döffinger Reimar.Doeffinger at stud.uni-karlsruhe.de
Mon Apr 17 14:31:54 CEST 2006


Hi,
attached is a slightly modified patch from Rickard N\344rstr\366m
(rickard narstrom at gmail com).
Comments?

Greetings,
Reimar Döffinger
-------------- next part --------------
Index: libvo/x11_common.c
===================================================================
RCS file: /cvsroot/mplayer/main/libvo/x11_common.c,v
retrieving revision 1.206
diff -u -r1.206 x11_common.c
--- libvo/x11_common.c	16 Apr 2006 13:38:28 -0000	1.206
+++ libvo/x11_common.c	17 Apr 2006 12:29:56 -0000
@@ -100,6 +100,8 @@
 static Atom XA_WIN_LAYER;
 static Atom XA_WIN_HINTS;
 static Atom XA_BLACKBOX_PID;
+static Atom XAWM_PROTOCOLS;
+static Atom XAWM_DELETE_WINDOW;
 
 #define XA_INIT(x) XA##x = XInternAtom(mDisplay, #x, False)
 
@@ -357,6 +360,8 @@
     XA_INIT(_WIN_LAYER);
     XA_INIT(_WIN_HINTS);
     XA_INIT(_BLACKBOX_PID);
+    XA_INIT(WM_PROTOCOLS);
+    XA_INIT(WM_DELETE_WINDOW);
 }
 
 void update_xinerama_info(void) {
@@ -1137,6 +1142,10 @@
                 XSetWMNormalHints(mDisplay, vo_window, &vo_hint);
                 vo_fs_flip = 0;
                 break;
+	    case ClientMessage:
+                if (Event.xclient.message_type == XAWM_PROTOCOLS &&
+                    Event.xclient.data.l[0] == XAWM_DELETE_WINDOW)
+                    mplayer_put_key(KEY_CLOSE_WIN);
         }
     }
     return ret;
@@ -1241,6 +1250,7 @@
     ret_win =
         XCreateWindow(mDisplay, mRootWin, x, y, width, height, 0, depth,
                       CopyFromParent, vis, xswamask, &xswa);
+    XSetWMProtocols(mDisplay, ret_win, &XAWM_DELETE_WINDOW, 1);
     if (!f_gc)
         f_gc = XCreateGC(mDisplay, ret_win, 0, 0);
     XSetForeground(mDisplay, f_gc, 0);


More information about the MPlayer-dev-eng mailing list