aboutsummaryrefslogtreecommitdiff
path: root/xwayland/xwm.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2017-10-24 08:22:13 -0400
committerGitHub <noreply@github.com>2017-10-24 08:22:13 -0400
commitbbf08f3ef9cf831c6af49060871995eaa0963bca (patch)
tree005f9540a0d68f827eb0024a1fb4bf53f48a4f20 /xwayland/xwm.c
parent93042e844be026e05a3120385af530c406bb695e (diff)
parent1dbe31493708790f6fafb4c9da8d24cbb3fa07b9 (diff)
Merge pull request #262 from acrisci/feature/data-device-selection
wlr-data-device
Diffstat (limited to 'xwayland/xwm.c')
-rw-r--r--xwayland/xwm.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/xwayland/xwm.c b/xwayland/xwm.c
index f58acb73..935fcd96 100644
--- a/xwayland/xwm.c
+++ b/xwayland/xwm.c
@@ -3,6 +3,7 @@
#endif
#include <stdlib.h>
#include <xcb/composite.h>
+#include <xcb/xfixes.h>
#include "wlr/util/log.h"
#include "wlr/types/wlr_surface.h"
#include "wlr/xwayland.h"
@@ -825,9 +826,30 @@ struct wlr_xwm *xwm_create(struct wlr_xwayland *wlr_xwayland) {
// TODO more xcb init
// xcb_prefetch_extension_data(xwm->xcb_conn, &xcb_composite_id);
+ xcb_prefetch_extension_data(xwm->xcb_conn, &xcb_xfixes_id);
+
xcb_get_resources(xwm);
xcb_init_wm(xwm);
+ xwm->xfixes = xcb_get_extension_data(xwm->xcb_conn, &xcb_xfixes_id);
+
+ if (!xwm->xfixes || !xwm->xfixes->present) {
+ wlr_log(L_DEBUG, "xfixes not available");
+ }
+
+ xcb_xfixes_query_version_cookie_t xfixes_cookie;
+ xcb_xfixes_query_version_reply_t *xfixes_reply;
+ xfixes_cookie =
+ xcb_xfixes_query_version(xwm->xcb_conn, XCB_XFIXES_MAJOR_VERSION,
+ XCB_XFIXES_MINOR_VERSION);
+ xfixes_reply =
+ xcb_xfixes_query_version_reply(xwm->xcb_conn, xfixes_cookie, NULL);
+
+ wlr_log(L_DEBUG, "xfixes version: %d.%d",
+ xfixes_reply->major_version, xfixes_reply->minor_version);
+
+ free(xfixes_reply);
+
xwm->surface_create_listener.notify = create_surface_handler;
wl_signal_add(&wlr_xwayland->compositor->events.create_surface,
&xwm->surface_create_listener);