Handle xwayland configure requests for unmanaged surfaces

This commit is contained in:
emersion 2018-04-05 17:22:39 -04:00
parent a528aea2ee
commit 07f3bb3ad1
No known key found for this signature in database
GPG key ID: 0FDE7BE0E88F5E48
2 changed files with 14 additions and 0 deletions

View file

@ -87,6 +87,7 @@ struct sway_xwayland_unmanaged {
struct wlr_xwayland_surface *wlr_xwayland_surface; struct wlr_xwayland_surface *wlr_xwayland_surface;
struct wl_list link; struct wl_list link;
struct wl_listener request_configure;
struct wl_listener commit; struct wl_listener commit;
struct wl_listener map; struct wl_listener map;
struct wl_listener unmap; struct wl_listener unmap;

View file

@ -14,6 +14,16 @@
#include "sway/input/input-manager.h" #include "sway/input/input-manager.h"
#include "log.h" #include "log.h"
static void unmanaged_handle_request_configure(struct wl_listener *listener,
void *data) {
struct sway_xwayland_unmanaged *surface =
wl_container_of(listener, surface, request_configure);
struct wlr_xwayland_surface *xsurface = surface->wlr_xwayland_surface;
struct wlr_xwayland_surface_configure_event *ev = data;
wlr_xwayland_surface_configure(xsurface, ev->x, ev->y,
ev->width, ev->height);
}
static void unmanaged_handle_commit(struct wl_listener *listener, void *data) { static void unmanaged_handle_commit(struct wl_listener *listener, void *data) {
struct sway_xwayland_unmanaged *surface = struct sway_xwayland_unmanaged *surface =
wl_container_of(listener, surface, commit); wl_container_of(listener, surface, commit);
@ -63,6 +73,9 @@ static struct sway_xwayland_unmanaged *create_unmanaged(
surface->wlr_xwayland_surface = xsurface; surface->wlr_xwayland_surface = xsurface;
wl_signal_add(&xsurface->events.request_configure,
&surface->request_configure);
surface->request_configure.notify = unmanaged_handle_request_configure;
wl_signal_add(&xsurface->events.map, &surface->map); wl_signal_add(&xsurface->events.map, &surface->map);
surface->map.notify = unmanaged_handle_map; surface->map.notify = unmanaged_handle_map;
wl_signal_add(&xsurface->events.unmap, &surface->unmap); wl_signal_add(&xsurface->events.unmap, &surface->unmap);