diff options
author | Simon Ser <contact@emersion.fr> | 2023-02-20 10:29:25 +0100 |
---|---|---|
committer | Kenny Levinsen <kl@kl.wtf> | 2023-02-20 12:20:42 +0100 |
commit | 7d2e4a51063ac90f950cb44f141ab391cbcaff5f (patch) | |
tree | 31e691356b28b8ca57f17d1009eebe5c4c8b3610 /sway/desktop/layer_shell.c | |
parent | 7a6c7d60d5dece586654d8855f34da25e92987fa (diff) |
layer-shell: enter output before surface is mapped
This sends fractional-scale-v1 events before the first configure
event. That way clients have all of the metadata they need to render
the first frame.
Diffstat (limited to 'sway/desktop/layer_shell.c')
-rw-r--r-- | sway/desktop/layer_shell.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/sway/desktop/layer_shell.c b/sway/desktop/layer_shell.c index 795eb4cd..e16bee78 100644 --- a/sway/desktop/layer_shell.c +++ b/sway/desktop/layer_shell.c @@ -383,7 +383,6 @@ static void handle_map(struct wl_listener *listener, void *data) { struct sway_output *output = wlr_output->data; output_damage_surface(output, sway_layer->geo.x, sway_layer->geo.y, sway_layer->layer_surface->surface, true); - surface_enter_output(sway_layer->layer_surface->surface, output); cursor_rebase_all(); } @@ -679,6 +678,8 @@ void handle_layer_shell_surface(struct wl_listener *listener, void *data) { wl_list_insert(&output->layers[layer_surface->pending.layer], &sway_layer->link); + surface_enter_output(layer_surface->surface, output); + // Temporarily set the layer's current state to pending // So that we can easily arrange it struct wlr_layer_surface_v1_state old_state = layer_surface->current; |