diff options
| author | Leonardo Hernández Hernández <leohdz172@protonmail.com> | 2022-03-18 01:31:28 -0600 | 
|---|---|---|
| committer | Leonardo Hernández Hernández <leohdz172@protonmail.com> | 2022-03-18 01:31:28 -0600 | 
| commit | d50bb97f56394cb998b96b6624342c3589828c10 (patch) | |
| tree | 49fbeab145724f81832eac48b07bc3e3ef2df668 | |
| parent | 475c13414479d1013c83309fcc4bb8a8707aa721 (diff) | |
| parent | 1dfd867d9caa61d9f3fabf695a72b2fea35b6193 (diff) | |
Merge branch 'main' into scenegraph
| -rw-r--r-- | client.h | 21 | ||||
| -rw-r--r-- | dwl.c | 7 | 
2 files changed, 28 insertions, 0 deletions
@@ -199,3 +199,24 @@ client_min_size(Client *c, int *width, int *height)  	*width = state->min_width;  	*height = state->min_height;  } + +static inline Client * +client_from_popup(struct wlr_xdg_popup *popup) +{ +	struct wlr_xdg_surface *surface = popup->base; + +	while (1) { +		switch (surface->role) { +		case WLR_XDG_SURFACE_ROLE_POPUP: +			if (!wlr_surface_is_xdg_surface(surface->popup->parent)) +				return NULL; + +			surface = wlr_xdg_surface_from_wlr_surface(surface->popup->parent); +			break; +		case WLR_XDG_SURFACE_ROLE_TOPLEVEL: +				return surface->data; +		case WLR_XDG_SURFACE_ROLE_NONE: +			return NULL; +		} +	} +} @@ -874,8 +874,15 @@ createnotify(struct wl_listener *listener, void *data)  	Client *c;  	if (xdg_surface->role == WLR_XDG_SURFACE_ROLE_POPUP) { +		struct wlr_box box;  		xdg_surface->surface->data = wlr_scene_xdg_surface_create(  				xdg_surface->popup->parent->data, xdg_surface); +		if (!(c = client_from_popup(xdg_surface->popup)) || !c->mon) +			return; +		box = c->mon->m; +		box.x -= c->geom.x; +		box.y -= c->geom.y; +		wlr_xdg_popup_unconstrain_from_box(xdg_surface->popup, &box);  		return;  	} else if (xdg_surface->role == WLR_XDG_SURFACE_ROLE_NONE)  		return;  | 
