aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorokan2020-03-24 14:47:29 +0000
committerWynn Wolf Arbor2020-03-26 20:12:46 +0100
commit19eacc39316879fb7008f3b71b36e52b09f3b464 (patch)
tree4d314e660401a208ac806d981d67b59cc179ba58
parent6230ae9cbeb69c9ed040e112328552e339d36d96 (diff)
downloadcwm-19eacc39316879fb7008f3b71b36e52b09f3b464.tar.gz
Instead of using _NET_ACTIVE_WINDOW on restart, use the pointer location to determine what client to set active. Reduces a round trip for every window.
-rw-r--r--calmwm.h5
-rw-r--r--client.c14
-rw-r--r--screen.c29
-rw-r--r--xevents.c4
-rw-r--r--xutil.c18
5 files changed, 25 insertions, 45 deletions
diff --git a/calmwm.h b/calmwm.h
index cee10a7..bd15a87 100644
--- a/calmwm.h
+++ b/calmwm.h
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: calmwm.h,v 1.373 2020/02/27 14:56:39 okan Exp $
+ * $OpenBSD: calmwm.h,v 1.374 2020/03/24 14:47:29 okan Exp $
*/
#ifndef _CALMWM_H_
@@ -395,7 +395,7 @@ void client_get_sizehints(struct client_ctx *);
void client_hide(struct client_ctx *);
void client_htile(struct client_ctx *);
int client_inbound(struct client_ctx *, int, int);
-struct client_ctx *client_init(Window, struct screen_ctx *, int);
+struct client_ctx *client_init(Window, struct screen_ctx *);
void client_lower(struct client_ctx *);
void client_move(struct client_ctx *);
void client_mtf(struct client_ctx *);
@@ -563,7 +563,6 @@ void xu_ewmh_net_workarea(struct screen_ctx *);
void xu_ewmh_net_client_list(struct screen_ctx *);
void xu_ewmh_net_client_list_stacking(struct screen_ctx *);
void xu_ewmh_net_active_window(struct screen_ctx *, Window);
-Window xu_ewmh_get_net_active_window(struct screen_ctx *);
void xu_ewmh_net_number_of_desktops(struct screen_ctx *);
void xu_ewmh_net_showing_desktop(struct screen_ctx *);
void xu_ewmh_net_virtual_roots(struct screen_ctx *);
diff --git a/client.c b/client.c
index effedd8..ffb1ed1 100644
--- a/client.c
+++ b/client.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: client.c,v 1.261 2020/03/16 17:50:44 tim Exp $
+ * $OpenBSD: client.c,v 1.262 2020/03/24 14:47:29 okan Exp $
*/
#include <sys/types.h>
@@ -37,14 +37,11 @@ static void client_mwm_hints(struct client_ctx *);
static void client_wm_protocols(struct client_ctx *);
struct client_ctx *
-client_init(Window win, struct screen_ctx *sc, int active)
+client_init(Window win, struct screen_ctx *sc)
{
struct client_ctx *cc;
XWindowAttributes wattr;
int mapped;
- Window rwin, cwin;
- int x, y, wx, wy;
- unsigned int mask;
long state;
if (win == None)
@@ -108,10 +105,6 @@ client_init(Window win, struct screen_ctx *sc, int active)
client_resize(cc, 0);
if (cc->initial_state)
xu_set_wm_state(cc->win, cc->initial_state);
- } else {
- if ((active == 0) && (XQueryPointer(X_Dpy, cc->win, &rwin,
- &cwin, &x, &y, &wx, &wy, &mask)) && (cwin != None))
- active = 1;
}
XSelectInput(X_Dpy, cc->win,
@@ -152,9 +145,6 @@ out:
XSync(X_Dpy, False);
XUngrabServer(X_Dpy);
- if (active)
- client_set_active(cc);
-
return cc;
}
diff --git a/screen.c b/screen.c
index 2e55ac3..b76cf7a 100644
--- a/screen.c
+++ b/screen.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: screen.c,v 1.96 2020/03/20 15:16:31 okan Exp $
+ * $OpenBSD: screen.c,v 1.97 2020/03/24 14:47:29 okan Exp $
*/
#include <sys/types.h>
@@ -33,13 +33,12 @@
#include "calmwm.h"
static struct geom screen_apply_gap(struct screen_ctx *, struct geom);
-static void screen_scan(struct screen_ctx *, Window);
+static void screen_scan(struct screen_ctx *);
void
screen_init(int which)
{
struct screen_ctx *sc;
- Window active = None;
XSetWindowAttributes attr;
sc = xmalloc(sizeof(*sc));
@@ -67,7 +66,6 @@ screen_init(int which)
xu_ewmh_net_number_of_desktops(sc);
xu_ewmh_net_showing_desktop(sc);
xu_ewmh_net_virtual_roots(sc);
- active = xu_ewmh_get_net_active_window(sc);
attr.cursor = Conf.cursor[CF_NORMAL];
attr.event_mask = SubstructureRedirectMask | SubstructureNotifyMask |
@@ -77,7 +75,7 @@ screen_init(int which)
if (Conf.xrandr)
XRRSelectInput(X_Dpy, sc->rootwin, RRScreenChangeNotifyMask);
- screen_scan(sc, active);
+ screen_scan(sc);
screen_updatestackingorder(sc);
TAILQ_INSERT_TAIL(&Screenq, sc, entry);
@@ -86,17 +84,26 @@ screen_init(int which)
}
static void
-screen_scan(struct screen_ctx *sc, Window active)
+screen_scan(struct screen_ctx *sc)
{
- Window *wins, w0, w1;
- unsigned int nwins, i;
+ struct client_ctx *cc, *active = NULL;
+ Window *wins, w0, w1, rwin, cwin;
+ unsigned int nwins, i, mask;
+ int rx, ry, wx, wy;
- if (XQueryTree(X_Dpy, sc->rootwin, &w0, &w1, &wins, &nwins)) {
- for (i = 0; i < nwins; i++)
- (void)client_init(wins[i], sc, (active == wins[i]));
+ XQueryPointer(X_Dpy, sc->rootwin, &rwin, &cwin,
+ &rx, &ry, &wx, &wy, &mask);
+ if (XQueryTree(X_Dpy, sc->rootwin, &w0, &w1, &wins, &nwins)) {
+ for (i = 0; i < nwins; i++) {
+ if ((cc = client_init(wins[i], sc)) != NULL)
+ if (cc->win == cwin)
+ active = cc;
+ }
XFree(wins);
}
+ if (active)
+ client_set_active(active);
}
struct screen_ctx *
diff --git a/xevents.c b/xevents.c
index 659341e..8c6be52 100644
--- a/xevents.c
+++ b/xevents.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: xevents.c,v 1.149 2020/02/27 14:56:39 okan Exp $
+ * $OpenBSD: xevents.c,v 1.150 2020/03/24 14:47:29 okan Exp $
*/
/*
@@ -87,7 +87,7 @@ xev_handle_maprequest(XEvent *ee)
client_ptr_save(old_cc);
if ((cc = client_find(e->window)) == NULL)
- cc = client_init(e->window, NULL, 0);
+ cc = client_init(e->window, NULL);
if ((cc != NULL) && (!(cc->flags & CLIENT_IGNORE)))
client_ptr_warp(cc);
diff --git a/xutil.c b/xutil.c
index c5f773f..01a7dc5 100644
--- a/xutil.c
+++ b/xutil.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: xutil.c,v 1.111 2020/02/27 14:56:39 okan Exp $
+ * $OpenBSD: xutil.c,v 1.112 2020/03/24 14:47:29 okan Exp $
*/
#include <sys/types.h>
@@ -296,22 +296,6 @@ 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_get_prop(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_number_of_desktops(struct screen_ctx *sc)
{