use the focus stack to determine stacking order

Suddenly we have autoraise!
This commit is contained in:
Devin J. Pohly 2020-04-23 21:29:28 -05:00
parent a5a7445dee
commit e6bcf95e2e
1 changed files with 4 additions and 4 deletions

8
dwl.c
View File

@ -822,9 +822,9 @@ rendermon(struct wl_listener *listener, void *data)
wlr_renderer_clear(drw, rootcolor); wlr_renderer_clear(drw, rootcolor);
/* Each subsequent window we render is rendered on top of the last. Because /* Each subsequent window we render is rendered on top of the last. Because
* our client list is ordered front-to-back, we iterate over it backwards. */ * our focus stack is ordered front-to-back, we iterate over it backwards. */
Client *c; Client *c;
wl_list_for_each_reverse(c, &clients, link) { wl_list_for_each_reverse(c, &fstack, flink) {
/* Only render clients which are on this monitor. */ /* Only render clients which are on this monitor. */
/* XXX consider checking wlr_output_layout_intersects, in case a /* XXX consider checking wlr_output_layout_intersects, in case a
* window can be seen on multiple outputs */ * window can be seen on multiple outputs */
@ -1241,9 +1241,9 @@ xytoclient(double x, double y,
struct wlr_surface **surface, double *sx, double *sy) struct wlr_surface **surface, double *sx, double *sy)
{ {
/* This iterates over all of our surfaces and attempts to find one under the /* This iterates over all of our surfaces and attempts to find one under the
* cursor. This relies on clients being ordered from top-to-bottom. */ * cursor. This relies on fstack being ordered from top-to-bottom. */
Client *c; Client *c;
wl_list_for_each(c, &clients, link) { wl_list_for_each(c, &fstack, flink) {
/* Skip clients that aren't visible */ /* Skip clients that aren't visible */
if (!VISIBLEON(c, c->mon)) if (!VISIBLEON(c, c->mon))
continue; continue;