aboutsummaryrefslogtreecommitdiff
path: root/protocols
diff options
context:
space:
mode:
authorManuel Stoeckl <code@mstoeckl.com>2019-06-22 23:02:24 -0400
committerSimon Ser <contact@emersion.fr>2019-06-24 09:38:41 +0300
commit5becce8005e3c617afbdddda8f0da95f84540b27 (patch)
tree4f49cb1dff54c27e2160fd53705e834dcf5d936e /protocols
parenta18d1c55ced3aae973ff787eb5c12ef6bc23d6e7 (diff)
Replace meson generator with custom_target
This change mimics the wlroots protocol meson.build. It replaces meson generators with custom_targets, which will only run wayland-scanner once per output file. The idle protocol is not used by any clients, so its client protocol header is not generated. The check for the availability of the private-code scanner options has been removed, since the wlroots dependency requires wayland >= 1.16.
Diffstat (limited to 'protocols')
-rw-r--r--protocols/meson.build88
1 files changed, 41 insertions, 47 deletions
diff --git a/protocols/meson.build b/protocols/meson.build
index c438b078..2a6cea09 100644
--- a/protocols/meson.build
+++ b/protocols/meson.build
@@ -1,85 +1,79 @@
wl_protocol_dir = wayland_protos.get_pkgconfig_variable('pkgdatadir')
-wayland_scanner = find_program('wayland-scanner')
-
-# should check wayland_scanner's version, but it is hard to get
-if wayland_server.version().version_compare('>=1.14.91')
- code_type = 'private-code'
+wayland_scanner_dep = dependency('wayland-scanner', required: false, native: true)
+if wayland_scanner_dep.found()
+ wayland_scanner = find_program(
+ wayland_scanner_dep.get_pkgconfig_variable('wayland_scanner'),
+ native: true,
+ )
else
- code_type = 'code'
+ wayland_scanner = find_program('wayland-scanner', native: true)
endif
-wayland_scanner_code = generator(
- wayland_scanner,
- output: '@BASENAME@-protocol.c',
- arguments: [code_type, '@INPUT@', '@OUTPUT@'],
-)
-
-wayland_scanner_client = generator(
- wayland_scanner,
- output: '@BASENAME@-client-protocol.h',
- arguments: ['client-header', '@INPUT@', '@OUTPUT@'],
-)
-
-wayland_scanner_server = generator(
- wayland_scanner,
- output: '@BASENAME@-protocol.h',
- arguments: ['server-header', '@INPUT@', '@OUTPUT@'],
-)
-
-client_protocols = [
+protocols = [
[wl_protocol_dir, 'stable/xdg-shell/xdg-shell.xml'],
+ [wl_protocol_dir, 'unstable/xdg-shell/xdg-shell-unstable-v6.xml'],
[wl_protocol_dir, 'unstable/xdg-output/xdg-output-unstable-v1.xml'],
+ [wl_protocol_dir, 'unstable/pointer-constraints/pointer-constraints-unstable-v1.xml'],
['wlr-layer-shell-unstable-v1.xml'],
['idle.xml'],
['wlr-input-inhibitor-unstable-v1.xml'],
]
-server_protocols = [
+client_protocols = [
[wl_protocol_dir, 'stable/xdg-shell/xdg-shell.xml'],
- [wl_protocol_dir, 'unstable/xdg-shell/xdg-shell-unstable-v6.xml'],
[wl_protocol_dir, 'unstable/xdg-output/xdg-output-unstable-v1.xml'],
- [wl_protocol_dir, 'unstable/pointer-constraints/pointer-constraints-unstable-v1.xml'],
['wlr-layer-shell-unstable-v1.xml'],
['wlr-input-inhibitor-unstable-v1.xml'],
]
-client_protos_src = []
-client_protos_headers = []
-
-server_protos_src = []
-server_protos_headers = []
+wl_protos_src = []
+wl_protos_headers = []
-foreach p : client_protocols
+foreach p : protocols
xml = join_paths(p)
- client_protos_src += wayland_scanner_code.process(xml)
- client_protos_headers += wayland_scanner_client.process(xml)
+ wl_protos_src += custom_target(
+ xml.underscorify() + '_server_c',
+ input: xml,
+ output: '@BASENAME@-protocol.c',
+ command: [wayland_scanner, 'private-code', '@INPUT@', '@OUTPUT@'],
+ )
+ wl_protos_headers += custom_target(
+ xml.underscorify() + '_server_h',
+ input: xml,
+ output: '@BASENAME@-protocol.h',
+ command: [wayland_scanner, 'server-header', '@INPUT@', '@OUTPUT@'],
+ )
endforeach
-foreach p : server_protocols
+foreach p : client_protocols
xml = join_paths(p)
- server_protos_src += wayland_scanner_code.process(xml)
- server_protos_headers += wayland_scanner_server.process(xml)
+ wl_protos_headers += custom_target(
+ xml.underscorify() + '_client_h',
+ input: xml,
+ output: '@BASENAME@-client-protocol.h',
+ command: [wayland_scanner, 'client-header', '@INPUT@', '@OUTPUT@'],
+ )
endforeach
lib_client_protos = static_library(
'client_protos',
- client_protos_src + client_protos_headers,
- dependencies: [wayland_client]
-) # for the include directory
+ wl_protos_src + wl_protos_headers,
+ dependencies: wayland_client.partial_dependency(compile_args: true),
+)
client_protos = declare_dependency(
link_with: lib_client_protos,
- sources: client_protos_headers,
+ sources: wl_protos_headers,
)
lib_server_protos = static_library(
'server_protos',
- server_protos_src + server_protos_headers,
- dependencies: [wayland_client]
-) # for the include directory
+ wl_protos_src + wl_protos_headers,
+ dependencies: wayland_server.partial_dependency(compile_args: true),
+)
server_protos = declare_dependency(
link_with: lib_server_protos,
- sources: server_protos_headers,
+ sources: wl_protos_headers,
)