Remove unused panel_size (and fix rearrange)

desktop_shell.panel_size was only used to determine if sway should
rearrange the output when rendering the panel in the output_pre_render
hook. This is not needed since the output will have been arranged at
that point.
It also caused sway to rearrange all the time when running with two
or more different monitors/resolutions because panel_size kept changing
with every output_pre_render callback.

Should fix #514
This commit is contained in:
Mikkel Oscar Lyderik 2016-03-17 23:31:14 +01:00
parent 50b9a4e8a6
commit f63512480c
3 changed files with 0 additions and 6 deletions

View file

@ -28,7 +28,6 @@ struct desktop_shell_state {
list_t *panels; list_t *panels;
list_t *lock_surfaces; list_t *lock_surfaces;
bool is_locked; bool is_locked;
struct wlc_size panel_size;
}; };
struct swaylock_state { struct swaylock_state {

View file

@ -93,7 +93,6 @@ static void set_panel(struct wl_client *client, struct wl_resource *resource,
config->surface = wlc_resource_from_wl_surface_resource(surface); config->surface = wlc_resource_from_wl_surface_resource(surface);
config->wl_surface_res = surface; config->wl_surface_res = surface;
wl_resource_set_destructor(surface, panel_surface_destructor); wl_resource_set_destructor(surface, panel_surface_destructor);
desktop_shell.panel_size = *wlc_surface_get_size(config->surface);
arrange_windows(&root_container, -1, -1); arrange_windows(&root_container, -1, -1);
wlc_output_schedule_render(config->output); wlc_output_schedule_render(config->output);
} }

View file

@ -141,10 +141,6 @@ static void handle_output_pre_render(wlc_handle output) {
break; break;
} }
wlc_surface_render(config->surface, &geo); wlc_surface_render(config->surface, &geo);
if (size.w != desktop_shell.panel_size.w || size.h != desktop_shell.panel_size.h) {
desktop_shell.panel_size = size;
arrange_windows(&root_container, -1, -1);
}
break; break;
} }
} }