use XGetWMProtocols and simplify WM_PROTOCOL handling

This commit is contained in:
okan 2013-05-19 17:02:04 +00:00
parent 3253f5a4a1
commit 01bfdd7b42
2 changed files with 20 additions and 20 deletions

View File

@ -121,6 +121,11 @@ struct winname {
}; };
TAILQ_HEAD(winname_q, winname); TAILQ_HEAD(winname_q, winname);
enum wm_protocols {
_WM_DELETE_WINDOW = 0x0001,
_WM_TAKE_FOCUS = 0x0002,
};
struct client_ctx { struct client_ctx {
TAILQ_ENTRY(client_ctx) entry; TAILQ_ENTRY(client_ctx) entry;
TAILQ_ENTRY(client_ctx) group_entry; TAILQ_ENTRY(client_ctx) group_entry;
@ -147,9 +152,7 @@ struct client_ctx {
int x; /* x position */ int x; /* x position */
int y; /* y position */ int y; /* y position */
} ptr; } ptr;
#define CLIENT_PROTO_DELETE 0x0001 enum wm_protocols xproto;
#define CLIENT_PROTO_TAKEFOCUS 0x0002
int xproto;
#define CLIENT_HIDDEN 0x0001 #define CLIENT_HIDDEN 0x0001
#define CLIENT_IGNORE 0x0002 #define CLIENT_IGNORE 0x0002
#define CLIENT_VMAXIMIZED 0x0004 #define CLIENT_VMAXIMIZED 0x0004

View File

@ -36,7 +36,7 @@ static struct client_ctx *client_mruprev(struct client_ctx *);
static void client_mtf(struct client_ctx *); static void client_mtf(struct client_ctx *);
static void client_none(struct screen_ctx *); static void client_none(struct screen_ctx *);
static void client_placecalc(struct client_ctx *); static void client_placecalc(struct client_ctx *);
static void client_update(struct client_ctx *); static void client_wm_protocols(struct client_ctx *);
static void client_getmwmhints(struct client_ctx *); static void client_getmwmhints(struct client_ctx *);
static int client_inbound(struct client_ctx *, int, int); static int client_inbound(struct client_ctx *, int, int);
@ -132,7 +132,7 @@ client_init(Window win, struct screen_ctx *sc, int mapped)
xu_ewmh_net_client_list(sc); xu_ewmh_net_client_list(sc);
client_update(cc); client_wm_protocols(cc);
if (mapped) if (mapped)
group_autogroup(cc); group_autogroup(cc);
@ -497,29 +497,26 @@ client_draw_border(struct client_ctx *cc)
} }
static void static void
client_update(struct client_ctx *cc) client_wm_protocols(struct client_ctx *cc)
{ {
Atom *p; Atom *p;
int i; int i, j;
long n;
if ((n = xu_getprop(cc->win, cwmh[WM_PROTOCOLS].atom, if (XGetWMProtocols(X_Dpy, cc->win, &p, &j)) {
XA_ATOM, 20L, (u_char **)&p)) <= 0) for (i = 0; i < j; i++) {
return; if (p[i] == cwmh[WM_DELETE_WINDOW].atom)
cc->xproto |= _WM_DELETE_WINDOW;
for (i = 0; i < n; i++) else if (p[i] == cwmh[WM_TAKE_FOCUS].atom)
if (p[i] == cwmh[WM_DELETE_WINDOW].atom) cc->xproto |= _WM_TAKE_FOCUS;
cc->xproto |= CLIENT_PROTO_DELETE; }
else if (p[i] == cwmh[WM_TAKE_FOCUS].atom) XFree(p);
cc->xproto |= CLIENT_PROTO_TAKEFOCUS; }
XFree(p);
} }
void void
client_send_delete(struct client_ctx *cc) client_send_delete(struct client_ctx *cc)
{ {
if (cc->xproto & CLIENT_PROTO_DELETE) if (cc->xproto & _WM_DELETE_WINDOW)
xu_sendmsg(cc->win, xu_sendmsg(cc->win,
cwmh[WM_PROTOCOLS].atom, cwmh[WM_DELETE_WINDOW].atom); cwmh[WM_PROTOCOLS].atom, cwmh[WM_DELETE_WINDOW].atom);
else else