diff options
author | okan <okan> | 2016-09-16 14:32:02 +0000 |
---|---|---|
committer | okan <okan> | 2016-09-16 14:32:02 +0000 |
commit | 6a53e3a859cd55b6f01ecb2a8a8a30af5d940345 (patch) | |
tree | a12b6268f4446ce69a18a218e8996ebfe18e4786 /xutil.c | |
parent | 2bbe111cc0e2ddd8b684e22dab337086c39ac46a (diff) | |
download | cwm-6a53e3a859cd55b6f01ecb2a8a8a30af5d940345.tar.gz cwm-6a53e3a859cd55b6f01ecb2a8a8a30af5d940345.tar.xz cwm-6a53e3a859cd55b6f01ecb2a8a8a30af5d940345.zip |
During init, query screen for _NET_ACTIVE_WINDOW and set that client as
active; while we already look at what's under the pointer, use this information first, then look under the pointer (saving that round-trip). This restores the active state to a client after restart even if the pointer is not above it (and of course the pointer is not above another client).
Diffstat (limited to 'xutil.c')
-rw-r--r-- | xutil.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/xutil.c b/xutil.c index a831794..eaaa0a4 100644 --- a/xutil.c +++ b/xutil.c @@ -256,6 +256,22 @@ xu_ewmh_net_active_window(struct screen_ctx *sc, Window w) XA_WINDOW, 32, PropModeReplace, (unsigned char *)&w, 1); } +Window +xu_ewmh_get_net_active_window(struct screen_ctx *sc) +{ + long *p; + Window win; + + if ((xu_getprop(sc->rootwin, ewmh[_NET_ACTIVE_WINDOW], + XA_WINDOW, 32, (unsigned char **)&p)) <= 0) + return(None); + + win = (Window)*p; + XFree(p); + + return(win); +} + void xu_ewmh_net_wm_desktop_viewport(struct screen_ctx *sc) { |