aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--protocols/meson.build147
1 files changed, 70 insertions, 77 deletions
diff --git a/protocols/meson.build b/protocols/meson.build
index de650230..d686bacd 100644
--- a/protocols/meson.build
+++ b/protocols/meson.build
@@ -1,77 +1,75 @@
-wayland_protos = dependency('wayland-protocols',
+wayland_protos = dependency(
+ 'wayland-protocols',
version: '>=1.32',
fallback: 'wayland-protocols',
default_options: ['tests=false'],
)
-hyprland_protos = dependency('hyprland-protocols',
+hyprland_protos = dependency(
+ 'hyprland-protocols',
version: '>=0.2',
- fallback: 'hyprland-protocols',
+ fallback: 'hyprland-protocols',
)
-wl_protocol_dir = wayland_protos.get_variable('pkgdatadir')
-hl_protocol_dir = hyprland_protos.get_variable('pkgdatadir')
+wayland_protocol_dir = wayland_protos.get_variable('pkgdatadir')
+hyprland_protocol_dir = hyprland_protos.get_variable('pkgdatadir')
-hyprwayland_scanner_dep = dependency('hyprwayland-scanner', version: '>=0.3.8', native: true)
+hyprwayland_scanner_dep = dependency('hyprwayland-scanner', version: '>=0.3.10', native: true)
hyprwayland_scanner = find_program(
hyprwayland_scanner_dep.get_variable('hyprwayland_scanner'),
native: true,
)
-new_protocols = [
- ['wlr-gamma-control-unstable-v1.xml'],
- ['wlr-foreign-toplevel-management-unstable-v1.xml'],
- ['wlr-output-power-management-unstable-v1.xml'],
- ['input-method-unstable-v2.xml'],
- ['virtual-keyboard-unstable-v1.xml'],
- ['wlr-virtual-pointer-unstable-v1.xml'],
- ['wlr-output-management-unstable-v1.xml'],
- ['kde-server-decoration.xml'],
- ['wlr-layer-shell-unstable-v1.xml'],
- ['wayland-drm.xml'],
- ['wlr-data-control-unstable-v1.xml'],
- ['wlr-screencopy-unstable-v1.xml'],
- [hl_protocol_dir, 'protocols/hyprland-global-shortcuts-v1.xml'],
- [hl_protocol_dir, 'protocols/hyprland-toplevel-export-v1.xml'],
- [hl_protocol_dir, 'protocols/hyprland-focus-grab-v1.xml'],
- [wl_protocol_dir, 'staging/tearing-control/tearing-control-v1.xml'],
- [wl_protocol_dir, 'staging/fractional-scale/fractional-scale-v1.xml'],
- [wl_protocol_dir, 'unstable/xdg-output/xdg-output-unstable-v1.xml'],
- [wl_protocol_dir, 'staging/cursor-shape/cursor-shape-v1.xml'],
- [wl_protocol_dir, 'unstable/idle-inhibit/idle-inhibit-unstable-v1.xml'],
- [wl_protocol_dir, 'unstable/relative-pointer/relative-pointer-unstable-v1.xml'],
- [wl_protocol_dir, 'unstable/xdg-decoration/xdg-decoration-unstable-v1.xml'],
- [wl_protocol_dir, 'staging/alpha-modifier/alpha-modifier-v1.xml'],
- [wl_protocol_dir, 'staging/ext-foreign-toplevel-list/ext-foreign-toplevel-list-v1.xml'],
- [wl_protocol_dir, 'unstable/pointer-gestures/pointer-gestures-unstable-v1.xml'],
- [wl_protocol_dir, 'unstable/keyboard-shortcuts-inhibit/keyboard-shortcuts-inhibit-unstable-v1.xml'],
- [wl_protocol_dir, 'unstable/text-input/text-input-unstable-v3.xml'],
- [wl_protocol_dir, 'unstable/text-input/text-input-unstable-v1.xml'],
- [wl_protocol_dir, 'unstable/pointer-constraints/pointer-constraints-unstable-v1.xml'],
- [wl_protocol_dir, 'staging/xdg-activation/xdg-activation-v1.xml'],
- [wl_protocol_dir, 'staging/ext-idle-notify/ext-idle-notify-v1.xml'],
- [wl_protocol_dir, 'staging/ext-session-lock/ext-session-lock-v1.xml'],
- [wl_protocol_dir, 'stable/tablet/tablet-v2.xml'],
- [wl_protocol_dir, 'stable/presentation-time/presentation-time.xml'],
- [wl_protocol_dir, 'stable/xdg-shell/xdg-shell.xml'],
- [wl_protocol_dir, 'unstable/primary-selection/primary-selection-unstable-v1.xml'],
- [wl_protocol_dir, 'staging/xwayland-shell/xwayland-shell-v1.xml'],
- [wl_protocol_dir, 'stable/viewporter/viewporter.xml'],
- [wl_protocol_dir, 'stable/linux-dmabuf/linux-dmabuf-v1.xml'],
- [wl_protocol_dir, 'staging/drm-lease/drm-lease-v1.xml'],
- [wl_protocol_dir, 'staging/linux-drm-syncobj/linux-drm-syncobj-v1.xml'],
- [wl_protocol_dir, 'staging/xdg-dialog/xdg-dialog-v1.xml'],
+protocols = [
+ 'wlr-gamma-control-unstable-v1.xml',
+ 'wlr-foreign-toplevel-management-unstable-v1.xml',
+ 'wlr-output-power-management-unstable-v1.xml',
+ 'input-method-unstable-v2.xml',
+ 'virtual-keyboard-unstable-v1.xml',
+ 'wlr-virtual-pointer-unstable-v1.xml',
+ 'wlr-output-management-unstable-v1.xml',
+ 'kde-server-decoration.xml',
+ 'wlr-layer-shell-unstable-v1.xml',
+ 'wayland-drm.xml',
+ 'wlr-data-control-unstable-v1.xml',
+ 'wlr-screencopy-unstable-v1.xml',
+ hyprland_protocol_dir / 'protocols/hyprland-global-shortcuts-v1.xml',
+ hyprland_protocol_dir / 'protocols/hyprland-toplevel-export-v1.xml',
+ hyprland_protocol_dir / 'protocols/hyprland-focus-grab-v1.xml',
+ wayland_protocol_dir / 'staging/tearing-control/tearing-control-v1.xml',
+ wayland_protocol_dir / 'staging/fractional-scale/fractional-scale-v1.xml',
+ wayland_protocol_dir / 'unstable/xdg-output/xdg-output-unstable-v1.xml',
+ wayland_protocol_dir / 'staging/cursor-shape/cursor-shape-v1.xml',
+ wayland_protocol_dir / 'unstable/idle-inhibit/idle-inhibit-unstable-v1.xml',
+ wayland_protocol_dir / 'unstable/relative-pointer/relative-pointer-unstable-v1.xml',
+ wayland_protocol_dir / 'unstable/xdg-decoration/xdg-decoration-unstable-v1.xml',
+ wayland_protocol_dir / 'staging/alpha-modifier/alpha-modifier-v1.xml',
+ wayland_protocol_dir / 'staging/ext-foreign-toplevel-list/ext-foreign-toplevel-list-v1.xml',
+ wayland_protocol_dir / 'unstable/pointer-gestures/pointer-gestures-unstable-v1.xml',
+ wayland_protocol_dir / 'unstable/keyboard-shortcuts-inhibit/keyboard-shortcuts-inhibit-unstable-v1.xml',
+ wayland_protocol_dir / 'unstable/text-input/text-input-unstable-v3.xml',
+ wayland_protocol_dir / 'unstable/text-input/text-input-unstable-v1.xml',
+ wayland_protocol_dir / 'unstable/pointer-constraints/pointer-constraints-unstable-v1.xml',
+ wayland_protocol_dir / 'staging/xdg-activation/xdg-activation-v1.xml',
+ wayland_protocol_dir / 'staging/ext-idle-notify/ext-idle-notify-v1.xml',
+ wayland_protocol_dir / 'staging/ext-session-lock/ext-session-lock-v1.xml',
+ wayland_protocol_dir / 'stable/tablet/tablet-v2.xml',
+ wayland_protocol_dir / 'stable/presentation-time/presentation-time.xml',
+ wayland_protocol_dir / 'stable/xdg-shell/xdg-shell.xml',
+ wayland_protocol_dir / 'unstable/primary-selection/primary-selection-unstable-v1.xml',
+ wayland_protocol_dir / 'staging/xwayland-shell/xwayland-shell-v1.xml',
+ wayland_protocol_dir / 'stable/viewporter/viewporter.xml',
+ wayland_protocol_dir / 'stable/linux-dmabuf/linux-dmabuf-v1.xml',
+ wayland_protocol_dir / 'staging/drm-lease/drm-lease-v1.xml',
+ wayland_protocol_dir / 'staging/linux-drm-syncobj/linux-drm-syncobj-v1.xml',
+ wayland_protocol_dir / 'staging/xdg-dialog/xdg-dialog-v1.xml',
]
-wl_protos_src = []
-wl_protos_headers = []
-
-new_wl_protos = []
-foreach p : new_protocols
- xml = join_paths(p)
- new_wl_protos += custom_target(
- xml.underscorify(),
- input: xml,
+wl_protocols = []
+foreach protocol : protocols
+ wl_protocols += custom_target(
+ protocol.underscorify(),
+ input: protocol,
install: true,
install_dir: [false, join_paths(get_option('includedir'), 'hyprland/protocols')],
@@ -79,31 +77,26 @@ foreach p : new_protocols
)
endforeach
-wayland_server_dep = dependency('wayland-server', version: '>=1.20.0')
-wayland_server_dir = wayland_server_dep.get_variable('pkgdatadir')
+# wayland.xml generation
+wayland_scanner = dependency('wayland-scanner')
+wayland_scanner_datadir = wayland_scanner.get_variable('pkgdatadir')
-wl_server_protos = [
- wayland_server_dir / 'wayland.xml'
-]
-wl_server_protos_gen = []
-foreach p : wl_server_protos
- wl_server_protos_gen += custom_target(
- p.underscorify(),
- input: p,
- install: true,
- install_dir: [false, join_paths(get_option('includedir'), 'hyprland/protocols')],
- command: [hyprwayland_scanner, '--wayland-enums', '@INPUT@', '@OUTDIR@'],
- )
-endforeach
+wayland_xml = wayland_scanner_datadir / 'wayland.xml'
+wayland_protocol = custom_target(
+ wayland_xml.underscorify(),
+ input: wayland_xml,
+ install: true,
+ install_dir: [false, join_paths(get_option('includedir'), 'hyprland/protocols')],
+ command: [hyprwayland_scanner, '--wayland-enums', '@INPUT@', '@OUTDIR@'],
+)
lib_server_protos = static_library(
'server_protos',
- wl_protos_src + wl_protos_headers + new_wl_protos + wl_server_protos_gen,
- dependencies: wayland_server_dep.partial_dependency(compile_args: true),
+ wl_protocols + wayland_protocol,
)
server_protos = declare_dependency(
link_with: lib_server_protos,
- sources: wl_protos_headers + new_wl_protos,
+ sources: wl_protocols + wayland_protocol,
)