Don't change tiling order in focusnext()

Use the focus stack instead to determine which client is focused
This commit is contained in:
Devin J. Pohly 2020-04-22 11:05:41 -05:00
parent 10bf0ff566
commit fdbe9ee29a

12
dwl.c
View file

@ -413,16 +413,18 @@ focus(Client *c, struct wlr_surface *surface)
void void
focusnext(const Arg *arg) focusnext(const Arg *arg)
{ {
/* Cycle to the next client */ /* XXX will need more logic with clients on different monitors */
if (wl_list_length(&clients) < 2) { if (wl_list_length(&clients) < 2) {
return; return;
} }
Client *c = wl_container_of(clients.next, c, link); /* Find the selected client (top of fstack) and focus the client
* following it in tiling order */
Client *c = wl_container_of(fstack.next, c, flink);
Client *n = wl_container_of(c->link.next, n, link); Client *n = wl_container_of(c->link.next, n, link);
/* Skip the sentinel node if we wrap around the end of the list */
if (&n->link == &clients)
n = wl_container_of(n->link.next, n, link);
focus(n, n->xdg_surface->surface); focus(n, n->xdg_surface->surface);
/* Move the previous client to the end of the list */
wl_list_remove(&c->link);
wl_list_insert(clients.prev, &c->link);
} }
void void