diff options
Diffstat (limited to 'sway/desktop')
| -rw-r--r-- | sway/desktop/wl_shell.c | 4 | ||||
| -rw-r--r-- | sway/desktop/xdg_shell_v6.c | 4 | ||||
| -rw-r--r-- | sway/desktop/xwayland.c | 69 | 
3 files changed, 70 insertions, 7 deletions
| diff --git a/sway/desktop/wl_shell.c b/sway/desktop/wl_shell.c index 99e8947b..cb3774f7 100644 --- a/sway/desktop/wl_shell.c +++ b/sway/desktop/wl_shell.c @@ -20,7 +20,7 @@ static struct sway_wl_shell_view *wl_shell_view_from_view(  	return (struct sway_wl_shell_view *)view;  } -static const char *get_prop(struct sway_view *view, enum sway_view_prop prop) { +static const char *get_string_prop(struct sway_view *view, enum sway_view_prop prop) {  	if (wl_shell_view_from_view(view) == NULL) {  		return NULL;  	} @@ -70,7 +70,7 @@ static void set_fullscreen(struct sway_view *view, bool fullscreen) {  }  static const struct sway_view_impl view_impl = { -	.get_prop = get_prop, +	.get_string_prop = get_string_prop,  	.configure = configure,  	.close = _close,  	.destroy = destroy, diff --git a/sway/desktop/xdg_shell_v6.c b/sway/desktop/xdg_shell_v6.c index 8ecb330d..f685ef71 100644 --- a/sway/desktop/xdg_shell_v6.c +++ b/sway/desktop/xdg_shell_v6.c @@ -80,7 +80,7 @@ static struct sway_xdg_shell_v6_view *xdg_shell_v6_view_from_view(  	return (struct sway_xdg_shell_v6_view *)view;  } -static const char *get_prop(struct sway_view *view, enum sway_view_prop prop) { +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;  	} @@ -158,7 +158,7 @@ static void destroy(struct sway_view *view) {  }  static const struct sway_view_impl view_impl = { -	.get_prop = get_prop, +	.get_string_prop = get_string_prop,  	.configure = configure,  	.set_activated = set_activated,  	.set_fullscreen = set_fullscreen, diff --git a/sway/desktop/xwayland.c b/sway/desktop/xwayland.c index 8f935760..554c070e 100644 --- a/sway/desktop/xwayland.c +++ b/sway/desktop/xwayland.c @@ -126,7 +126,7 @@ static struct sway_xwayland_view *xwayland_view_from_view(  	return (struct sway_xwayland_view *)view;  } -static const char *get_prop(struct sway_view *view, enum sway_view_prop prop) { +static const char *get_string_prop(struct sway_view *view, enum sway_view_prop prop) {  	if (xwayland_view_from_view(view) == NULL) {  		return NULL;  	} @@ -135,11 +135,27 @@ static const char *get_prop(struct sway_view *view, enum sway_view_prop prop) {  		return view->wlr_xwayland_surface->title;  	case VIEW_PROP_CLASS:  		return view->wlr_xwayland_surface->class; +	case VIEW_PROP_INSTANCE: +		return view->wlr_xwayland_surface->instance;  	default:  		return NULL;  	}  } +static uint32_t get_int_prop(struct sway_view *view, enum sway_view_prop prop) { +	if (xwayland_view_from_view(view) == NULL) { +		return 0; +	} +	switch (prop) { +	case VIEW_PROP_X11_WINDOW_ID: +		return view->wlr_xwayland_surface->window_id; +	case VIEW_PROP_WINDOW_TYPE: +		return *view->wlr_xwayland_surface->window_type; +	default: +		return 0; +	} +} +  static void configure(struct sway_view *view, double ox, double oy, int width,  		int height) {  	struct sway_xwayland_view *xwayland_view = xwayland_view_from_view(view); @@ -200,13 +216,17 @@ static void destroy(struct sway_view *view) {  	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->set_title.link); +	wl_list_remove(&xwayland_view->set_class.link); +	wl_list_remove(&xwayland_view->set_window_type.link);  	wl_list_remove(&xwayland_view->map.link);  	wl_list_remove(&xwayland_view->unmap.link);  	free(xwayland_view);  }  static const struct sway_view_impl view_impl = { -	.get_prop = get_prop, +	.get_string_prop = get_string_prop, +	.get_int_prop = get_int_prop,  	.configure = configure,  	.set_activated = set_activated,  	.set_fullscreen = set_fullscreen, @@ -223,7 +243,6 @@ static void handle_commit(struct wl_listener *listener, void *data) {  	view_update_size(view, xwayland_view->pending_width,  		xwayland_view->pending_height);  	view_damage_from(view); -	view_update_title(view, false);  }  static void handle_unmap(struct wl_listener *listener, void *data) { @@ -285,6 +304,40 @@ static void handle_request_fullscreen(struct wl_listener *listener, void *data)  	view_set_fullscreen(view, xsurface->fullscreen);  } +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); +	struct sway_view *view = &xwayland_view->view; +	struct wlr_xwayland_surface *xsurface = view->wlr_xwayland_surface; +	if (!xsurface->mapped) { +		return; +	} +	view_update_title(view, false); +	view_execute_criteria(view); +} + +static void handle_set_class(struct wl_listener *listener, void *data) { +	struct sway_xwayland_view *xwayland_view = +		wl_container_of(listener, xwayland_view, set_class); +	struct sway_view *view = &xwayland_view->view; +	struct wlr_xwayland_surface *xsurface = view->wlr_xwayland_surface; +	if (!xsurface->mapped) { +		return; +	} +	view_execute_criteria(view); +} + +static void handle_set_window_type(struct wl_listener *listener, void *data) { +	struct sway_xwayland_view *xwayland_view = +		wl_container_of(listener, xwayland_view, set_window_type); +	struct sway_view *view = &xwayland_view->view; +	struct wlr_xwayland_surface *xsurface = view->wlr_xwayland_surface; +	if (!xsurface->mapped) { +		return; +	} +	view_execute_criteria(view); +} +  void handle_xwayland_surface(struct wl_listener *listener, void *data) {  	struct sway_server *server = wl_container_of(listener, server,  		xwayland_surface); @@ -323,6 +376,16 @@ 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.set_title, &xwayland_view->set_title); +	xwayland_view->set_title.notify = handle_set_title; + +	wl_signal_add(&xsurface->events.set_class, &xwayland_view->set_class); +	xwayland_view->set_class.notify = handle_set_class; + +	wl_signal_add(&xsurface->events.set_window_type, +			&xwayland_view->set_window_type); +	xwayland_view->set_window_type.notify = handle_set_window_type; +  	wl_signal_add(&xsurface->events.unmap, &xwayland_view->unmap);  	xwayland_view->unmap.notify = handle_unmap; | 
