mirror of
https://github.com/swaywm/sway.git
synced 2024-11-26 18:01:29 +00:00
Fix failure to rearrange output in some cases
This commit is contained in:
parent
f3fbf19312
commit
c91adbd188
|
@ -81,7 +81,6 @@ static void arrange_layer(struct sway_output *output, struct wl_list *list,
|
||||||
&full_area.width, &full_area.height);
|
&full_area.width, &full_area.height);
|
||||||
wl_list_for_each(sway_layer, list, link) {
|
wl_list_for_each(sway_layer, list, link) {
|
||||||
struct wlr_layer_surface *layer = sway_layer->layer_surface;
|
struct wlr_layer_surface *layer = sway_layer->layer_surface;
|
||||||
wlr_log(L_DEBUG, "arranging layer %p %s", sway_layer, layer->namespace);
|
|
||||||
struct wlr_layer_surface_state *state = &layer->current;
|
struct wlr_layer_surface_state *state = &layer->current;
|
||||||
if (exclusive != (state->exclusive_zone > 0)) {
|
if (exclusive != (state->exclusive_zone > 0)) {
|
||||||
continue;
|
continue;
|
||||||
|
@ -167,10 +166,11 @@ void arrange_layers(struct sway_output *output) {
|
||||||
&usable_area, true);
|
&usable_area, true);
|
||||||
arrange_layer(output, &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BACKGROUND],
|
arrange_layer(output, &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BACKGROUND],
|
||||||
&usable_area, true);
|
&usable_area, true);
|
||||||
memcpy(&output->usable_area, &usable_area, sizeof(struct wlr_box));
|
|
||||||
|
|
||||||
if (memcmp(&usable_area, &output->usable_area,
|
if (memcmp(&usable_area, &output->usable_area,
|
||||||
sizeof(struct wlr_box)) != 0) {
|
sizeof(struct wlr_box)) != 0) {
|
||||||
|
wlr_log(L_DEBUG, "Usable area changed, rearranging output");
|
||||||
|
memcpy(&output->usable_area, &usable_area, sizeof(struct wlr_box));
|
||||||
arrange_windows(output->swayc, -1, -1);
|
arrange_windows(output->swayc, -1, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,8 +204,8 @@ static void handle_surface_commit(struct wl_listener *listener, void *data) {
|
||||||
if (wlr_output != NULL) {
|
if (wlr_output != NULL) {
|
||||||
struct sway_output *output = wlr_output->data;
|
struct sway_output *output = wlr_output->data;
|
||||||
struct wlr_box old_geo = layer->geo;
|
struct wlr_box old_geo = layer->geo;
|
||||||
|
arrange_layers(output);
|
||||||
if (memcmp(&old_geo, &layer->geo, sizeof(struct wlr_box)) != 0) {
|
if (memcmp(&old_geo, &layer->geo, sizeof(struct wlr_box)) != 0) {
|
||||||
arrange_layers(output);
|
|
||||||
// TODO DAMAGE apply whole surface from previous and new geos
|
// TODO DAMAGE apply whole surface from previous and new geos
|
||||||
} else {
|
} else {
|
||||||
// TODO DAMAGE from surface damage
|
// TODO DAMAGE from surface damage
|
||||||
|
@ -236,7 +236,6 @@ static void handle_destroy(struct wl_listener *listener, void *data) {
|
||||||
struct sway_output *output = sway_layer->layer_surface->output->data;
|
struct sway_output *output = sway_layer->layer_surface->output->data;
|
||||||
free(sway_layer);
|
free(sway_layer);
|
||||||
arrange_layers(output);
|
arrange_layers(output);
|
||||||
arrange_windows(output->swayc, -1, -1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void handle_map(struct wl_listener *listener, void *data) {
|
static void handle_map(struct wl_listener *listener, void *data) {
|
||||||
|
|
Loading…
Reference in a new issue