project('agl-compositor',
'c','cpp',
- version: '0.0.18',
+ version: '0.0.24',
default_options: [
'warning_level=3',
'c_std=gnu99',
+ 'werror=true',
],
- meson_version: '>= 0.47',
+ meson_version: '>= 0.53',
license: 'MIT/Expat',
)
config_h = configuration_data()
-agl_compositor_version = '0.0.18'
-libweston_version = 'libweston-8'
+libweston_version = 'libweston-13'
pkgconfig = import('pkgconfig')
+fs = import('fs')
cc = meson.get_compiler('c')
cxx = meson.get_compiler('cpp')
cc.get_supported_arguments([
'-Wno-unused-parameter',
'-Wno-pedantic',
- '-Wextra',
- '-Werror'
+ '-Wno-deprecated-declarations'
]),
language: 'c'
)
endforeach
dep_libsystemd = dependency('libsystemd', required: false)
-dep_libsmack = dependency('libsmack', required: false)
dep_scanner = dependency('wayland-scanner', native: true)
prog_scanner = find_program(dep_scanner.get_pkgconfig_variable('wayland_scanner'))
dep_wp = dependency('wayland-protocols', version: '>= 1.18')
deps_remoting += dep
endforeach
-
-# the transmitter plug-in requires waltham but we don't have a cflags or libs
-# for it so we add waltham depends here. Further more, the output is being
-# handled by remoting plug-in
-depnames_waltham = [
- 'waltham'
-]
-
-deps_waltham = []
-foreach depname : depnames_waltham
- dep = dependency(depname, required: false)
- if dep.found()
- deps_waltham += dep
- else
- message('Waltham requires @0@ which was not found. '.format(depname))
- endif
-endforeach
-
-deps_waltham += deps_remoting
-
agl_shell_xml = files('protocol/agl-shell.xml')
agl_shell_desktop_xml = files('protocol/agl-shell-desktop.xml')
-agl_screenshooter = files('protocol/agl-screenshooter.xml')
xdg_shell_xml = join_paths(dir_wp_base, 'stable', 'xdg-shell', 'xdg-shell.xml')
+dep_libweston_protocols = dependency('libweston-13-protocols', version: '>= 13')
+dir_protocol_libweston = dep_libweston_protocols.get_pkgconfig_variable('pkgdatadir')
protocols = [
{ 'name': 'agl-shell', 'source': 'internal' },
{ 'name': 'agl-shell-desktop', 'source': 'internal' },
- { 'name': 'agl-screenshooter', 'source': 'internal' },
{ 'name': 'xdg-shell', 'source': 'wp-stable' },
{ 'name': 'xdg-output', 'source': 'unstable', 'version': 'v1' },
+ { 'name': 'weston-output-capture', 'source': 'libweston-protocols' },
]
foreach proto: protocols
proto_name = proto['name']
if proto['source'] == 'internal'
base_file = proto_name
- xml_path = join_paths('protocol', '@0@.xml'.format(base_file))
+ xml_path = join_paths('protocol', '@0@.xml'.format(base_file))
+ elif proto['source'] == 'libweston-protocols'
+ base_file = proto_name
+ xml_path = join_paths(dir_protocol_libweston, '@0@.xml'.format(base_file))
elif proto['source'] == 'wp-stable'
base_file = proto_name
- xml_path = join_paths(dir_wp_base, 'stable', proto_name, '@0@.xml'.format(base_file))
+ xml_path = join_paths(dir_wp_base, 'stable', proto_name, '@0@.xml'.format(base_file))
else
base_file = '@0@-unstable-@1@'.format(proto_name, proto['version'])
- xml_path = join_paths(dir_wp_base, 'unstable', proto_name, '@0@.xml'.format(base_file))
+ xml_path = join_paths(dir_wp_base, 'unstable', proto_name, '@0@.xml'.format(base_file))
endif
foreach output_type: [ 'client-header', 'server-header', 'private-code' ]
endforeach
endforeach
-# libweston-6 pkg-config file already has 'libweston-6' as prefix but
-# agl-compositor uses 'libweston-6' also. This makes use of the prefix
-# path as to allow building and installing the compositor locally
prefix_path = get_option('prefix')
-message('prefix_path ' + prefix_path)
-if not prefix_path.contains('/usr')
- additional_include_dir = include_directories(prefix_path + '/' + 'include')
- local_dep = declare_dependency(include_directories: additional_include_dir)
-else
- local_dep = []
-endif
-
dir_data = join_paths(prefix_path, get_option('datadir'))
dir_data_agl_compositor = join_paths('agl-compositor', 'protocols')
dir_data_pc = join_paths(dir_data, 'pkgconfig')
deps_libweston = [
dependency('wayland-server'),
+ dependency('weston'),
libweston_dep,
- dependency('libweston-desktop-8'),
- local_dep,
]
+weston_module_dir = libweston_dep.get_pkgconfig_variable('libdir')
+config_h.set_quoted('WESTON_MODULEDIR', join_paths(weston_module_dir, 'weston'))
+config_h.set_quoted('LIBWESTON_MODULEDIR', join_paths(weston_module_dir, libweston_version))
+
srcs_agl_compositor = [
- 'src/main.c',
+ 'src/compositor.c',
'src/desktop.c',
'src/layout.c',
'src/policy.c',
'src/shell.c',
- 'src/screenshooter.c',
'src/input.c',
'shared/option-parser.c',
'shared/os-compatibility.c',
+ 'shared/process-util.c',
agl_shell_server_protocol_h,
agl_shell_desktop_server_protocol_h,
- agl_screenshooter_server_protocol_h,
agl_shell_protocol_c,
agl_shell_desktop_protocol_c,
- agl_screenshooter_protocol_c,
xdg_shell_protocol_c,
]
message('Installing rba policy')
endif
-
# From meson documentation:
# In order to look for headers in a specific directory you can use args :
# '-I/extra/include/dir, but this should only be used in exceptional cases for
if not meson.is_cross_build()
if not prefix_path.contains('/usr')
dir_path_x11_backend = join_paths(prefix_path, 'include', libweston_version, 'libweston', 'backend-x11.h')
+ dir_path_wayland_backend = join_paths(prefix_path, 'include', libweston_version, 'libweston', 'backend-wayland.h')
+ dir_path_rdp_backend = join_paths(prefix_path, 'include', libweston_version, 'libweston', 'backend-rdp.h')
else
dir_path_x11_backend = join_paths(libweston_version, 'libweston', 'backend-x11.h')
+ dir_path_wayland_backend = join_paths(libweston_version, 'libweston', 'backend-wayland.h')
+ dir_path_rdp_backend = join_paths(libweston_version, 'libweston', 'backend-rdp.h')
endif
else
message('Building with cross environment')
dir_path_x11_backend = join_paths(libweston_version, 'libweston', 'backend-x11.h')
+ dir_path_wayland_backend = join_paths(libweston_version, 'libweston', 'backend-wayland.h')
+ dir_path_rdp_backend = join_paths(libweston_version, 'libweston', 'backend-rdp.h')
endif
# do the test
if cc.has_header(dir_path_x11_backend)
config_h.set('HAVE_BACKEND_X11', 1)
+ message('Building with X11 backend')
+ endif
+
+ if cc.has_header(dir_path_wayland_backend)
+ config_h.set('HAVE_BACKEND_WAYLAND', 1)
+ message('Building with Wayland backend')
+ endif
+
+ if cc.has_header(dir_path_rdp_backend)
+ config_h.set('HAVE_BACKEND_RDP', 1)
+ message('Building with RDP backend')
endif
endif
message('Found remoting depends, enabling remoting')
endif
-if deps_waltham.length() == depnames_waltham.length() + depnames.length()
- config_h.set('HAVE_WALTHAM', 1)
- message('Found waltham depends, enabling waltham')
-endif
+if get_option('xwayland')
+ config_h.set('BUILD_XWAYLAND', '1')
-if dep_libsmack.found()
- config_h.set('HAVE_SMACK', 1)
- deps_libweston += dep_libsmack
+ srcs_agl_compositor += 'src/xwayland.c'
+ srcs_agl_compositor += 'shared/xalloc.c'
+ srcs_agl_compositor += 'shared/process-util.c'
+ config_h.set_quoted('XSERVER_PATH', get_option('xwayland-path'))
endif
+dir_module_agl_compositor = join_paths(join_paths(prefix_path, get_option('libdir')), 'agl-compositor')
+
+libexec_compositor = shared_library(
+ 'exec_compositor',
+ sources: srcs_agl_compositor,
+ dependencies: deps_libweston,
+ install_dir: dir_module_agl_compositor,
+ install: true,
+ version: meson.project_version(),
+ soversion: 0
+)
+
+dep_libexec_compositor = declare_dependency(
+ link_with: libexec_compositor,
+ include_directories: [ include_directories('.') ],
+ dependencies: deps_libweston,
+)
+
configure_file(output: 'config.h', configuration: config_h)
exe_agl_compositor = executable(
'agl-compositor',
- srcs_agl_compositor,
- dependencies: deps_libweston,
+ 'src/main.c',
+ dependencies: dep_libexec_compositor,
+ install_rpath: dir_module_agl_compositor,
install: true
)
pkgconfig.generate(
- filebase: 'agl-compositor-@0@-protocols'.format(agl_compositor_version),
+ filebase: 'agl-compositor-@0@-protocols'.format(meson.project_version()),
name: 'agl-compositor private protocols',
- version: agl_compositor_version,
+ version: meson.project_version(),
description: 'agl-compositor protocol files',
variables: [
'datarootdir=' + join_paths('${prefix}', get_option('datadir')),
common_inc = [ include_directories('src'), include_directories('.') ]
subdir('clients')
+
+if get_option('grpc-proxy')
+ subdir('grpc-proxy')
+endif