aboutsummaryrefslogtreecommitdiff
path: root/protocols/wlr-layer-shell-unstable-v1.xml
diff options
context:
space:
mode:
authorGuido Cella <guido@guidocella.xyz>2020-12-19 06:57:14 +0100
committerGuido Cella <guido@guidocella.xyz>2020-12-19 12:34:31 +0100
commit1024928c15cebbeb1c652a6ba4a243f1c330bac8 (patch)
treedce21864e2f00480c290f315a230906058b450ed /protocols/wlr-layer-shell-unstable-v1.xml
parent64faad7cb6dfc59832ef3249b606df89c23327f8 (diff)
deactivate focused client when spawning a new one
Because maprequest immediately calls wl_list_insert(&fstack, &c->flink), in the following call to setmon(), the selclient() which is passed to focusclient() as the old client is actually the newly mapped client, and the real old one is never deactivated. You can see this by, for example, opening Chromium's devtools, then spawning a terminal. The background of the focused line in the devtools doesn't change from light blue to grey. We can't just remove wl_list_insert(&fstack, &c->flink) from maprequest, because calling wl_list_remove in focusclient() with a client that has not been added to the list causes a segmentation fault. Therefore we fix the focusclient call by not passing it the old client every time, but instead using the wlroots function that gets the focused surface and deactivate that, like in TinyWL. This also avoids getting the selected client and passing it to focusclient() on every call unnecessarily, and will allow removing shouldfocusclients in a future commit by checking if old is a layer surface instead.
Diffstat (limited to 'protocols/wlr-layer-shell-unstable-v1.xml')
0 files changed, 0 insertions, 0 deletions