aboutsummaryrefslogtreecommitdiff
path: root/xwayland
diff options
context:
space:
mode:
Diffstat (limited to 'xwayland')
-rw-r--r--xwayland/meson.build31
-rw-r--r--xwayland/server.c2
2 files changed, 28 insertions, 5 deletions
diff --git a/xwayland/meson.build b/xwayland/meson.build
index 0e36b61e..5a8c732d 100644
--- a/xwayland/meson.build
+++ b/xwayland/meson.build
@@ -62,6 +62,32 @@ foreach lib, desc : xwayland_optional
xwayland_libs += dep
endforeach
+xwayland_feature_names = [
+ 'listenfd',
+ 'no_touch_pointer_emulation',
+ 'force_xrandr_emulation',
+ 'terminate_delay',
+]
+
+xwayland_features = {}
+if xwayland.found()
+ xwayland_path = xwayland.get_variable('xwayland')
+ foreach name : xwayland_feature_names
+ have = xwayland.get_variable('have_' + name, default_value: 'false') == 'true'
+ xwayland_features += { name: have }
+ endforeach
+else
+ xwayland_path = xwayland_prog.full_path()
+ foreach name : xwayland_feature_names
+ xwayland_features += { name: false }
+ endforeach
+endif
+
+internal_config.set_quoted('XWAYLAND_PATH', xwayland_path)
+foreach name, have : xwayland_features
+ internal_config.set10('HAVE_XWAYLAND_' + name.to_upper(), have)
+endforeach
+
wlr_files += files(
'selection/dnd.c',
'selection/incoming.c',
@@ -77,7 +103,4 @@ wlr_deps += xwayland_libs
features += { 'xwayland': true }
have = cc.has_function('xcb_xfixes_set_client_disconnect_mode', dependencies: xwayland_libs)
-add_project_arguments(
- '-DHAS_XCB_XFIXES_SET_CLIENT_DISCONNECT_MODE=@0@'.format(have.to_int()),
- language: 'c',
-)
+internal_config.set10('HAS_XCB_XFIXES_SET_CLIENT_DISCONNECT_MODE', have)
diff --git a/xwayland/server.c b/xwayland/server.c
index 3b34bd57..aee15002 100644
--- a/xwayland/server.c
+++ b/xwayland/server.c
@@ -15,8 +15,8 @@
#include <wayland-server-core.h>
#include <wlr/util/log.h>
#include <wlr/xwayland.h>
+#include "config.h"
#include "sockets.h"
-#include "xwayland/config.h"
static void safe_close(int fd) {
if (fd >= 0) {