diff options
| author | Drew DeVault <[email protected]> | 2017-12-20 11:56:39 -0500 | 
|---|---|---|
| committer | GitHub <[email protected]> | 2017-12-20 11:56:39 -0500 | 
| commit | 373def44468e0c919031a6ffe3049f91680e05ca (patch) | |
| tree | e40dfdcc9292a71fcc2160bc5d643a66996664dc /sway/tree | |
| parent | a51e74beb91a98181d6bc69137d377cd49e72d1f (diff) | |
| parent | 63f7fb95172a72436698a1562b4f7ea1e9100a7e (diff) | |
Merge pull request #1505 from acrisci/feature/input
input management and seat
Diffstat (limited to 'sway/tree')
| -rw-r--r-- | sway/tree/container.c | 67 | 
1 files changed, 67 insertions, 0 deletions
| diff --git a/sway/tree/container.c b/sway/tree/container.c index 5df10bcb..6f2a3abf 100644 --- a/sway/tree/container.c +++ b/sway/tree/container.c @@ -4,6 +4,7 @@  #include <string.h>  #include <strings.h>  #include <wlr/types/wlr_output_layout.h> +#include <wlr/types/wlr_wl_shell.h>  #include "sway/config.h"  #include "sway/container.h"  #include "sway/layout.h" @@ -42,6 +43,9 @@ static swayc_t *new_swayc(enum swayc_types type) {  	if (type != C_VIEW) {  		c->children = create_list();  	} + +	wl_signal_init(&c->events.destroy); +  	return c;  } @@ -140,6 +144,9 @@ static void free_swayc(swayc_t *cont) {  	if (!sway_assert(cont, "free_swayc passed NULL")) {  		return;  	} + +	wl_signal_emit(&cont->events.destroy, cont); +  	if (cont->children) {  		// remove children until there are no more, free_swayc calls  		// remove_child, which removes child from this container @@ -218,3 +225,63 @@ swayc_t *swayc_parent_by_type(swayc_t *container, enum swayc_types type) {  	} while (container && container->type != type);  	return container;  } + +swayc_t *swayc_at(swayc_t *parent, double lx, double ly, +		struct wlr_surface **surface, double *sx, double *sy) { +	list_t *queue = create_list(); +	list_add(queue, parent); + +	swayc_t *swayc = NULL; +	while (queue->length) { +		swayc = queue->items[0]; +		list_del(queue, 0); +		if (swayc->type == C_VIEW) { +			struct sway_view *sview = swayc->sway_view; +			swayc_t *soutput = swayc_parent_by_type(swayc, C_OUTPUT); +			struct wlr_box *output_box = +				wlr_output_layout_get_box( +					root_container.sway_root->output_layout, +					soutput->sway_output->wlr_output); +			double ox = lx - output_box->x; +			double oy = ly - output_box->y; +			double view_sx = ox - swayc->x; +			double view_sy = oy - swayc->y; +			int width = swayc->sway_view->surface->current->width; +			int height = swayc->sway_view->surface->current->height; + +			// TODO popups and subsurfaces +			switch (sview->type) { +				case SWAY_WL_SHELL_VIEW: +					break; +				case SWAY_XDG_SHELL_V6_VIEW: +					// the top left corner of the sway container is the +					// coordinate of the top left corner of the window geometry +					view_sx += sview->wlr_xdg_surface_v6->geometry->x; +					view_sy += sview->wlr_xdg_surface_v6->geometry->y; +					break; +				case SWAY_XWAYLAND_VIEW: +					break; +				default: +					break; +			} + +			if (view_sx > 0 && view_sx < width && +					view_sy > 0 && view_sy < height && +					pixman_region32_contains_point( +						&sview->surface->current->input, +						view_sx, view_sy, NULL)) { +				*sx = view_sx; +				*sy = view_sy; +				*surface = swayc->sway_view->surface; +				list_free(queue); +				return swayc; +			} +		} else { +			list_cat(queue, swayc->children); +		} +	} + +	list_free(queue); + +	return NULL; +} | 
