westoy: Remove MAXIMIZED and FULLSCREEN as separate window types
xdg_shell changes this around so that they are flags on the remote object itself, not separate surface types. Move to a system where we calculate the state from the flags ourselves and set the appropriate wl_shell_surface type. When we port to xdg_shell, we'll drop these flags and simply sync on the client.
This commit is contained in:
parent
76ec0826bc
commit
c0f17aba5e
@ -137,8 +137,6 @@ struct display {
|
|||||||
enum {
|
enum {
|
||||||
TYPE_NONE,
|
TYPE_NONE,
|
||||||
TYPE_TOPLEVEL,
|
TYPE_TOPLEVEL,
|
||||||
TYPE_FULLSCREEN,
|
|
||||||
TYPE_MAXIMIZED,
|
|
||||||
TYPE_MENU,
|
TYPE_MENU,
|
||||||
TYPE_CUSTOM
|
TYPE_CUSTOM
|
||||||
};
|
};
|
||||||
@ -231,13 +229,15 @@ struct window {
|
|||||||
int redraw_task_scheduled;
|
int redraw_task_scheduled;
|
||||||
struct task redraw_task;
|
struct task redraw_task;
|
||||||
int resize_needed;
|
int resize_needed;
|
||||||
int saved_type;
|
|
||||||
int type;
|
int type;
|
||||||
int focus_count;
|
int focus_count;
|
||||||
|
|
||||||
int resizing;
|
int resizing;
|
||||||
int configure_requests;
|
int configure_requests;
|
||||||
|
|
||||||
|
int fullscreen;
|
||||||
|
int maximized;
|
||||||
|
|
||||||
enum preferred_format preferred_format;
|
enum preferred_format preferred_format;
|
||||||
|
|
||||||
window_key_handler_t key_handler;
|
window_key_handler_t key_handler;
|
||||||
@ -2151,13 +2151,13 @@ frame_resize_handler(struct widget *widget,
|
|||||||
struct rectangle input;
|
struct rectangle input;
|
||||||
struct rectangle opaque;
|
struct rectangle opaque;
|
||||||
|
|
||||||
if (widget->window->type == TYPE_FULLSCREEN) {
|
if (widget->window->fullscreen) {
|
||||||
interior.x = 0;
|
interior.x = 0;
|
||||||
interior.y = 0;
|
interior.y = 0;
|
||||||
interior.width = width;
|
interior.width = width;
|
||||||
interior.height = height;
|
interior.height = height;
|
||||||
} else {
|
} else {
|
||||||
if (widget->window->type == TYPE_MAXIMIZED) {
|
if (widget->window->maximized) {
|
||||||
frame_set_flag(frame->frame, FRAME_FLAG_MAXIMIZED);
|
frame_set_flag(frame->frame, FRAME_FLAG_MAXIMIZED);
|
||||||
} else {
|
} else {
|
||||||
frame_unset_flag(frame->frame, FRAME_FLAG_MAXIMIZED);
|
frame_unset_flag(frame->frame, FRAME_FLAG_MAXIMIZED);
|
||||||
@ -2175,7 +2175,7 @@ frame_resize_handler(struct widget *widget,
|
|||||||
child->resize_handler(child, interior.width, interior.height,
|
child->resize_handler(child, interior.width, interior.height,
|
||||||
child->user_data);
|
child->user_data);
|
||||||
|
|
||||||
if (widget->window->type == TYPE_FULLSCREEN) {
|
if (widget->window->fullscreen) {
|
||||||
width = child->allocation.width;
|
width = child->allocation.width;
|
||||||
height = child->allocation.height;
|
height = child->allocation.height;
|
||||||
} else {
|
} else {
|
||||||
@ -2191,7 +2191,7 @@ frame_resize_handler(struct widget *widget,
|
|||||||
|
|
||||||
widget->surface->input_region =
|
widget->surface->input_region =
|
||||||
wl_compositor_create_region(widget->window->display->compositor);
|
wl_compositor_create_region(widget->window->display->compositor);
|
||||||
if (widget->window->type != TYPE_FULLSCREEN) {
|
if (!widget->window->fullscreen) {
|
||||||
frame_input_rect(frame->frame, &input.x, &input.y,
|
frame_input_rect(frame->frame, &input.x, &input.y,
|
||||||
&input.width, &input.height);
|
&input.width, &input.height);
|
||||||
wl_region_add(widget->surface->input_region,
|
wl_region_add(widget->surface->input_region,
|
||||||
@ -2203,7 +2203,7 @@ frame_resize_handler(struct widget *widget,
|
|||||||
widget_set_allocation(widget, 0, 0, width, height);
|
widget_set_allocation(widget, 0, 0, width, height);
|
||||||
|
|
||||||
if (child->opaque) {
|
if (child->opaque) {
|
||||||
if (widget->window->type != TYPE_FULLSCREEN) {
|
if (!widget->window->fullscreen) {
|
||||||
frame_opaque_rect(frame->frame, &opaque.x, &opaque.y,
|
frame_opaque_rect(frame->frame, &opaque.x, &opaque.y,
|
||||||
&opaque.width, &opaque.height);
|
&opaque.width, &opaque.height);
|
||||||
|
|
||||||
@ -2227,7 +2227,7 @@ frame_redraw_handler(struct widget *widget, void *data)
|
|||||||
struct window_frame *frame = data;
|
struct window_frame *frame = data;
|
||||||
struct window *window = widget->window;
|
struct window *window = widget->window;
|
||||||
|
|
||||||
if (window->type == TYPE_FULLSCREEN)
|
if (window->fullscreen)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (window->focus_count) {
|
if (window->focus_count) {
|
||||||
@ -2396,7 +2396,7 @@ frame_handle_status(struct window_frame *frame, struct input *input,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (status & FRAME_STATUS_MAXIMIZE) {
|
if (status & FRAME_STATUS_MAXIMIZE) {
|
||||||
window_set_maximized(window, window->type != TYPE_MAXIMIZED);
|
window_set_maximized(window, !window->maximized);
|
||||||
frame_status_clear(frame->frame, FRAME_STATUS_MAXIMIZE);
|
frame_status_clear(frame->frame, FRAME_STATUS_MAXIMIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2507,9 +2507,9 @@ window_frame_set_child_size(struct widget *widget, int child_width,
|
|||||||
struct theme *t = display->theme;
|
struct theme *t = display->theme;
|
||||||
int decoration_width, decoration_height;
|
int decoration_width, decoration_height;
|
||||||
int width, height;
|
int width, height;
|
||||||
int margin = widget->window->type == TYPE_MAXIMIZED ? 0 : t->margin;
|
int margin = widget->window->maximized ? 0 : t->margin;
|
||||||
|
|
||||||
if (widget->window->type != TYPE_FULLSCREEN) {
|
if (!widget->window->fullscreen) {
|
||||||
decoration_width = (t->width + margin) * 2;
|
decoration_width = (t->width + margin) * 2;
|
||||||
decoration_height = t->width +
|
decoration_height = t->width +
|
||||||
t->titlebar_height + margin * 2;
|
t->titlebar_height + margin * 2;
|
||||||
@ -2926,8 +2926,7 @@ keyboard_handle_key(void *data, struct wl_keyboard *keyboard,
|
|||||||
|
|
||||||
if (sym == XKB_KEY_F5 && input->modifiers == MOD_ALT_MASK) {
|
if (sym == XKB_KEY_F5 && input->modifiers == MOD_ALT_MASK) {
|
||||||
if (state == WL_KEYBOARD_KEY_STATE_PRESSED)
|
if (state == WL_KEYBOARD_KEY_STATE_PRESSED)
|
||||||
window_set_maximized(window,
|
window_set_maximized(window, !window->maximized);
|
||||||
window->type != TYPE_MAXIMIZED);
|
|
||||||
} else if (sym == XKB_KEY_F11 &&
|
} else if (sym == XKB_KEY_F11 &&
|
||||||
window->fullscreen_handler &&
|
window->fullscreen_handler &&
|
||||||
state == WL_KEYBOARD_KEY_STATE_PRESSED) {
|
state == WL_KEYBOARD_KEY_STATE_PRESSED) {
|
||||||
@ -4071,7 +4070,7 @@ window_schedule_redraw(struct window *window)
|
|||||||
int
|
int
|
||||||
window_is_fullscreen(struct window *window)
|
window_is_fullscreen(struct window *window)
|
||||||
{
|
{
|
||||||
return window->type == TYPE_FULLSCREEN;
|
return window->fullscreen;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -4105,43 +4104,44 @@ window_defer_redraw_until_configure(struct window* window)
|
|||||||
window->configure_requests++;
|
window->configure_requests++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
window_sync_type(struct window *window)
|
||||||
|
{
|
||||||
|
if (window->fullscreen) {
|
||||||
|
window->saved_allocation = window->main_surface->allocation;
|
||||||
|
wl_shell_surface_set_fullscreen(window->shell_surface,
|
||||||
|
WL_SHELL_SURFACE_FULLSCREEN_METHOD_DEFAULT,
|
||||||
|
0, NULL);
|
||||||
|
} else if (window->maximized) {
|
||||||
|
window->saved_allocation = window->main_surface->allocation;
|
||||||
|
wl_shell_surface_set_maximized(window->shell_surface, NULL);
|
||||||
|
} else {
|
||||||
|
wl_shell_surface_set_toplevel(window->shell_surface);
|
||||||
|
window_schedule_resize(window,
|
||||||
|
window->saved_allocation.width,
|
||||||
|
window->saved_allocation.height);
|
||||||
|
}
|
||||||
|
|
||||||
|
window_defer_redraw_until_configure(window);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
window_set_fullscreen(struct window *window, int fullscreen)
|
window_set_fullscreen(struct window *window, int fullscreen)
|
||||||
{
|
{
|
||||||
if (!window->display->shell)
|
if (!window->display->shell)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((window->type == TYPE_FULLSCREEN) == fullscreen)
|
if (window->fullscreen == fullscreen)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (fullscreen) {
|
window->fullscreen = fullscreen;
|
||||||
window->saved_type = window->type;
|
window_sync_type(window);
|
||||||
if (window->type == TYPE_TOPLEVEL) {
|
|
||||||
window->saved_allocation = window->main_surface->allocation;
|
|
||||||
}
|
|
||||||
window->type = TYPE_FULLSCREEN;
|
|
||||||
wl_shell_surface_set_fullscreen(window->shell_surface,
|
|
||||||
WL_SHELL_SURFACE_FULLSCREEN_METHOD_DEFAULT,
|
|
||||||
0, NULL);
|
|
||||||
window_defer_redraw_until_configure (window);
|
|
||||||
} else {
|
|
||||||
if (window->saved_type == TYPE_MAXIMIZED) {
|
|
||||||
window_set_maximized(window, 1);
|
|
||||||
} else {
|
|
||||||
window->type = TYPE_TOPLEVEL;
|
|
||||||
wl_shell_surface_set_toplevel(window->shell_surface);
|
|
||||||
window_schedule_resize(window,
|
|
||||||
window->saved_allocation.width,
|
|
||||||
window->saved_allocation.height);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
window_is_maximized(struct window *window)
|
window_is_maximized(struct window *window)
|
||||||
{
|
{
|
||||||
return window->type == TYPE_MAXIMIZED;
|
return window->maximized;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -4150,25 +4150,12 @@ window_set_maximized(struct window *window, int maximized)
|
|||||||
if (!window->display->shell)
|
if (!window->display->shell)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((window->type == TYPE_MAXIMIZED) == maximized)
|
if (window->maximized == maximized)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (window->type == TYPE_TOPLEVEL) {
|
window->maximized = maximized;
|
||||||
window->saved_allocation = window->main_surface->allocation;
|
if (!window->fullscreen)
|
||||||
wl_shell_surface_set_maximized(window->shell_surface, NULL);
|
window_sync_type(window);
|
||||||
window->type = TYPE_MAXIMIZED;
|
|
||||||
window_defer_redraw_until_configure(window);
|
|
||||||
} else if (window->type == TYPE_FULLSCREEN) {
|
|
||||||
wl_shell_surface_set_maximized(window->shell_surface, NULL);
|
|
||||||
window->type = TYPE_MAXIMIZED;
|
|
||||||
window_defer_redraw_until_configure(window);
|
|
||||||
} else {
|
|
||||||
wl_shell_surface_set_toplevel(window->shell_surface);
|
|
||||||
window->type = TYPE_TOPLEVEL;
|
|
||||||
window_schedule_resize(window,
|
|
||||||
window->saved_allocation.width,
|
|
||||||
window->saved_allocation.height);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
Loading…
Reference in New Issue
Block a user