diff options
Diffstat (limited to 'sway/desktop')
| -rw-r--r-- | sway/desktop/output.c | 9 | ||||
| -rw-r--r-- | sway/desktop/transaction.c | 14 | ||||
| -rw-r--r-- | sway/desktop/xdg_shell.c | 50 | ||||
| -rw-r--r-- | sway/desktop/xdg_shell_v6.c | 50 | ||||
| -rw-r--r-- | sway/desktop/xwayland.c | 41 | 
5 files changed, 149 insertions, 15 deletions
| diff --git a/sway/desktop/output.c b/sway/desktop/output.c index a9808406..a206ac6b 100644 --- a/sway/desktop/output.c +++ b/sway/desktop/output.c @@ -463,11 +463,12 @@ static void output_damage_whole_container_iterator(struct sway_container *con,  void output_damage_whole_container(struct sway_output *output,  		struct sway_container *con) { +	// Pad the box by 1px, because the width is a double and might be a fraction  	struct wlr_box box = { -		.x = con->current.swayc_x - output->wlr_output->lx, -		.y = con->current.swayc_y - output->wlr_output->ly, -		.width = con->current.swayc_width, -		.height = con->current.swayc_height, +		.x = con->current.swayc_x - output->wlr_output->lx - 1, +		.y = con->current.swayc_y - output->wlr_output->ly - 1, +		.width = con->current.swayc_width + 2, +		.height = con->current.swayc_height + 2,  	};  	scale_box(&box, output->wlr_output->scale);  	wlr_output_damage_add_box(output->damage, &box); diff --git a/sway/desktop/transaction.c b/sway/desktop/transaction.c index 19f41efc..2a89880a 100644 --- a/sway/desktop/transaction.c +++ b/sway/desktop/transaction.c @@ -222,24 +222,16 @@ static void transaction_apply(struct sway_transaction *transaction) {  	}  } -/** - * For simplicity, we only progress the queue if it can be completely flushed. - */  static void transaction_progress_queue() { -	// We iterate this list in reverse because we're more likely to find a -	// waiting transactions at the end of the list. -	for (int i = server.transactions->length - 1; i >= 0; --i) { -		struct sway_transaction *transaction = server.transactions->items[i]; +	while (server.transactions->length) { +		struct sway_transaction *transaction = server.transactions->items[0];  		if (transaction->num_waiting) {  			return;  		} -	} -	for (int i = 0; i < server.transactions->length; ++i) { -		struct sway_transaction *transaction = server.transactions->items[i];  		transaction_apply(transaction);  		transaction_destroy(transaction); +		list_del(server.transactions, 0);  	} -	server.transactions->length = 0;  	idle_inhibit_v1_check_active(server.idle_inhibit_manager_v1);  } diff --git a/sway/desktop/xdg_shell.c b/sway/desktop/xdg_shell.c index 98c16faf..706b35c3 100644 --- a/sway/desktop/xdg_shell.c +++ b/sway/desktop/xdg_shell.c @@ -1,4 +1,5 @@  #define _POSIX_C_SOURCE 199309L +#include <float.h>  #include <stdbool.h>  #include <stdlib.h>  #include <wayland-server.h> @@ -95,6 +96,16 @@ static struct sway_xdg_shell_view *xdg_shell_view_from_view(  	return (struct sway_xdg_shell_view *)view;  } +static void get_constraints(struct sway_view *view, double *min_width, +		double *max_width, double *min_height, double *max_height) { +	struct wlr_xdg_toplevel_state *state = +		&view->wlr_xdg_surface->toplevel->current; +	*min_width = state->min_width > 0 ? state->min_width : DBL_MIN; +	*max_width = state->max_width > 0 ? state->max_width : DBL_MAX; +	*min_height = state->min_height > 0 ? state->min_height : DBL_MIN; +	*max_height = state->max_height > 0 ? state->max_height : DBL_MAX; +} +  static const char *get_string_prop(struct sway_view *view, enum sway_view_prop prop) {  	if (xdg_shell_view_from_view(view) == NULL) {  		return NULL; @@ -188,6 +199,7 @@ static void destroy(struct sway_view *view) {  }  static const struct sway_view_impl view_impl = { +	.get_constraints = get_constraints,  	.get_string_prop = get_string_prop,  	.configure = configure,  	.set_activated = set_activated, @@ -248,6 +260,34 @@ static void handle_request_fullscreen(struct wl_listener *listener, void *data)  	transaction_commit_dirty();  } +static void handle_request_move(struct wl_listener *listener, void *data) { +	struct sway_xdg_shell_view *xdg_shell_view = +		wl_container_of(listener, xdg_shell_view, request_move); +	struct sway_view *view = &xdg_shell_view->view; +	if (!container_is_floating(view->swayc)) { +		return; +	} +	struct wlr_xdg_toplevel_move_event *e = data; +	struct sway_seat *seat = e->seat->seat->data; +	if (e->serial == seat->last_button_serial) { +		seat_begin_move(seat, view->swayc, seat->last_button); +	} +} + +static void handle_request_resize(struct wl_listener *listener, void *data) { +	struct sway_xdg_shell_view *xdg_shell_view = +		wl_container_of(listener, xdg_shell_view, request_resize); +	struct sway_view *view = &xdg_shell_view->view; +	if (!container_is_floating(view->swayc)) { +		return; +	} +	struct wlr_xdg_toplevel_resize_event *e = data; +	struct sway_seat *seat = e->seat->seat->data; +	if (e->serial == seat->last_button_serial) { +		seat_begin_resize(seat, view->swayc, seat->last_button, e->edges); +	} +} +  static void handle_unmap(struct wl_listener *listener, void *data) {  	struct sway_xdg_shell_view *xdg_shell_view =  		wl_container_of(listener, xdg_shell_view, unmap); @@ -262,6 +302,8 @@ static void handle_unmap(struct wl_listener *listener, void *data) {  	wl_list_remove(&xdg_shell_view->commit.link);  	wl_list_remove(&xdg_shell_view->new_popup.link);  	wl_list_remove(&xdg_shell_view->request_fullscreen.link); +	wl_list_remove(&xdg_shell_view->request_move.link); +	wl_list_remove(&xdg_shell_view->request_resize.link);  }  static void handle_map(struct wl_listener *listener, void *data) { @@ -299,6 +341,14 @@ static void handle_map(struct wl_listener *listener, void *data) {  	xdg_shell_view->request_fullscreen.notify = handle_request_fullscreen;  	wl_signal_add(&xdg_surface->toplevel->events.request_fullscreen,  			&xdg_shell_view->request_fullscreen); + +	xdg_shell_view->request_move.notify = handle_request_move; +	wl_signal_add(&xdg_surface->toplevel->events.request_move, +			&xdg_shell_view->request_move); + +	xdg_shell_view->request_resize.notify = handle_request_resize; +	wl_signal_add(&xdg_surface->toplevel->events.request_resize, +			&xdg_shell_view->request_resize);  }  static void handle_destroy(struct wl_listener *listener, void *data) { diff --git a/sway/desktop/xdg_shell_v6.c b/sway/desktop/xdg_shell_v6.c index 4d76f0a7..201b5b1e 100644 --- a/sway/desktop/xdg_shell_v6.c +++ b/sway/desktop/xdg_shell_v6.c @@ -1,4 +1,5 @@  #define _POSIX_C_SOURCE 199309L +#include <float.h>  #include <stdbool.h>  #include <stdlib.h>  #include <wayland-server.h> @@ -94,6 +95,16 @@ static struct sway_xdg_shell_v6_view *xdg_shell_v6_view_from_view(  	return (struct sway_xdg_shell_v6_view *)view;  } +static void get_constraints(struct sway_view *view, double *min_width, +		double *max_width, double *min_height, double *max_height) { +	struct wlr_xdg_toplevel_v6_state *state = +		&view->wlr_xdg_surface_v6->toplevel->current; +	*min_width = state->min_width > 0 ? state->min_width : DBL_MIN; +	*max_width = state->max_width > 0 ? state->max_width : DBL_MAX; +	*min_height = state->min_height > 0 ? state->min_height : DBL_MIN; +	*max_height = state->max_height > 0 ? state->max_height : DBL_MAX; +} +  static const char *get_string_prop(struct sway_view *view, enum sway_view_prop prop) {  	if (xdg_shell_v6_view_from_view(view) == NULL) {  		return NULL; @@ -184,6 +195,7 @@ static void destroy(struct sway_view *view) {  }  static const struct sway_view_impl view_impl = { +	.get_constraints = get_constraints,  	.get_string_prop = get_string_prop,  	.configure = configure,  	.set_activated = set_activated, @@ -243,6 +255,34 @@ static void handle_request_fullscreen(struct wl_listener *listener, void *data)  	transaction_commit_dirty();  } +static void handle_request_move(struct wl_listener *listener, void *data) { +	struct sway_xdg_shell_v6_view *xdg_shell_v6_view = +		wl_container_of(listener, xdg_shell_v6_view, request_move); +	struct sway_view *view = &xdg_shell_v6_view->view; +	if (!container_is_floating(view->swayc)) { +		return; +	} +	struct wlr_xdg_toplevel_v6_move_event *e = data; +	struct sway_seat *seat = e->seat->seat->data; +	if (e->serial == seat->last_button_serial) { +		seat_begin_move(seat, view->swayc, seat->last_button); +	} +} + +static void handle_request_resize(struct wl_listener *listener, void *data) { +	struct sway_xdg_shell_v6_view *xdg_shell_v6_view = +		wl_container_of(listener, xdg_shell_v6_view, request_resize); +	struct sway_view *view = &xdg_shell_v6_view->view; +	if (!container_is_floating(view->swayc)) { +		return; +	} +	struct wlr_xdg_toplevel_v6_resize_event *e = data; +	struct sway_seat *seat = e->seat->seat->data; +	if (e->serial == seat->last_button_serial) { +		seat_begin_resize(seat, view->swayc, seat->last_button, e->edges); +	} +} +  static void handle_unmap(struct wl_listener *listener, void *data) {  	struct sway_xdg_shell_v6_view *xdg_shell_v6_view =  		wl_container_of(listener, xdg_shell_v6_view, unmap); @@ -257,6 +297,8 @@ static void handle_unmap(struct wl_listener *listener, void *data) {  	wl_list_remove(&xdg_shell_v6_view->commit.link);  	wl_list_remove(&xdg_shell_v6_view->new_popup.link);  	wl_list_remove(&xdg_shell_v6_view->request_fullscreen.link); +	wl_list_remove(&xdg_shell_v6_view->request_move.link); +	wl_list_remove(&xdg_shell_v6_view->request_resize.link);  }  static void handle_map(struct wl_listener *listener, void *data) { @@ -294,6 +336,14 @@ static void handle_map(struct wl_listener *listener, void *data) {  	xdg_shell_v6_view->request_fullscreen.notify = handle_request_fullscreen;  	wl_signal_add(&xdg_surface->toplevel->events.request_fullscreen,  			&xdg_shell_v6_view->request_fullscreen); + +	xdg_shell_v6_view->request_move.notify = handle_request_move; +	wl_signal_add(&xdg_surface->toplevel->events.request_move, +			&xdg_shell_v6_view->request_move); + +	xdg_shell_v6_view->request_resize.notify = handle_request_resize; +	wl_signal_add(&xdg_surface->toplevel->events.request_resize, +			&xdg_shell_v6_view->request_resize);  }  static void handle_destroy(struct wl_listener *listener, void *data) { diff --git a/sway/desktop/xwayland.c b/sway/desktop/xwayland.c index bce0a37b..2546168b 100644 --- a/sway/desktop/xwayland.c +++ b/sway/desktop/xwayland.c @@ -305,6 +305,8 @@ static void handle_destroy(struct wl_listener *listener, void *data) {  	wl_list_remove(&xwayland_view->destroy.link);  	wl_list_remove(&xwayland_view->request_configure.link);  	wl_list_remove(&xwayland_view->request_fullscreen.link); +	wl_list_remove(&xwayland_view->request_move.link); +	wl_list_remove(&xwayland_view->request_resize.link);  	wl_list_remove(&xwayland_view->set_title.link);  	wl_list_remove(&xwayland_view->set_class.link);  	wl_list_remove(&xwayland_view->set_window_type.link); @@ -400,6 +402,37 @@ static void handle_request_fullscreen(struct wl_listener *listener, void *data)  	transaction_commit_dirty();  } +static void handle_request_move(struct wl_listener *listener, void *data) { +	struct sway_xwayland_view *xwayland_view = +		wl_container_of(listener, xwayland_view, request_move); +	struct sway_view *view = &xwayland_view->view; +	struct wlr_xwayland_surface *xsurface = view->wlr_xwayland_surface; +	if (!xsurface->mapped) { +		return; +	} +	if (!container_is_floating(view->swayc)) { +		return; +	} +	struct sway_seat *seat = input_manager_current_seat(input_manager); +	seat_begin_move(seat, view->swayc, seat->last_button); +} + +static void handle_request_resize(struct wl_listener *listener, void *data) { +	struct sway_xwayland_view *xwayland_view = +		wl_container_of(listener, xwayland_view, request_resize); +	struct sway_view *view = &xwayland_view->view; +	struct wlr_xwayland_surface *xsurface = view->wlr_xwayland_surface; +	if (!xsurface->mapped) { +		return; +	} +	if (!container_is_floating(view->swayc)) { +		return; +	} +	struct wlr_xwayland_resize_event *e = data; +	struct sway_seat *seat = input_manager_current_seat(input_manager); +	seat_begin_resize(seat, view->swayc, seat->last_button, e->edges); +} +  static void handle_set_title(struct wl_listener *listener, void *data) {  	struct sway_xwayland_view *xwayland_view =  		wl_container_of(listener, xwayland_view, set_title); @@ -495,6 +528,14 @@ void handle_xwayland_surface(struct wl_listener *listener, void *data) {  		&xwayland_view->request_fullscreen);  	xwayland_view->request_fullscreen.notify = handle_request_fullscreen; +	wl_signal_add(&xsurface->events.request_move, +		&xwayland_view->request_move); +	xwayland_view->request_move.notify = handle_request_move; + +	wl_signal_add(&xsurface->events.request_resize, +		&xwayland_view->request_resize); +	xwayland_view->request_resize.notify = handle_request_resize; +  	wl_signal_add(&xsurface->events.set_title, &xwayland_view->set_title);  	xwayland_view->set_title.notify = handle_set_title; | 
