Don't change tiling order in focusnext()
Use the focus stack instead to determine which client is focused
This commit is contained in:
parent
10bf0ff566
commit
fdbe9ee29a
1 changed files with 7 additions and 5 deletions
12
dwl.c
12
dwl.c
|
@ -413,16 +413,18 @@ focus(Client *c, struct wlr_surface *surface)
|
|||
void
|
||||
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) {
|
||||
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);
|
||||
/* 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);
|
||||
/* Move the previous client to the end of the list */
|
||||
wl_list_remove(&c->link);
|
||||
wl_list_insert(clients.prev, &c->link);
|
||||
}
|
||||
|
||||
void
|
||||
|
|
Loading…
Reference in a new issue