mirror of
https://github.com/leahneukirchen/cwm.git
synced 2023-08-10 21:13:12 +03:00
use XGetWMProtocols and simplify WM_PROTOCOL handling
This commit is contained in:
parent
3253f5a4a1
commit
01bfdd7b42
9
calmwm.h
9
calmwm.h
@ -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
|
||||||
|
31
client.c
31
client.c
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user