[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