diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:47:04 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:47:04 +0000 |
commit | e05fb7b3e36c052baf0dd607ddeb22c0a2b5cbde (patch) | |
tree | 7a27d70e96502edf2b5576d3ca403f1b8512f55b /meson.build | |
parent | Initial commit. (diff) | |
download | gnome-initial-setup-e05fb7b3e36c052baf0dd607ddeb22c0a2b5cbde.tar.xz gnome-initial-setup-e05fb7b3e36c052baf0dd607ddeb22c0a2b5cbde.zip |
Adding upstream version 43.2.upstream/43.2upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | meson.build | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/meson.build b/meson.build new file mode 100644 index 0000000..f1de4ab --- /dev/null +++ b/meson.build @@ -0,0 +1,108 @@ +project('gnome-initial-setup', + ['c'], + version: '43.2', + license: 'GPL-2.0-or-later', + meson_version: '>= 0.53.0', +) + +cc = meson.get_compiler('c') +gnome = import('gnome') +i18n = import('i18n') + +prefix = get_option('prefix') +po_dir = join_paths(meson.current_source_dir(), 'po') +bin_dir = join_paths(prefix, get_option('bindir')) +data_dir = join_paths(prefix, get_option('datadir')) +locale_dir = join_paths(prefix, get_option('localedir')) +libexec_dir = join_paths(prefix, get_option('libexecdir')) +sysconf_dir = join_paths(prefix, get_option('sysconfdir')) +pkgdata_dir = join_paths(data_dir, meson.project_name()) +pkgsysconf_dir = join_paths(sysconf_dir, meson.project_name()) + +conf = configuration_data() +conf.set_quoted('GETTEXT_PACKAGE', meson.project_name()) +conf.set_quoted('GNOMELOCALEDIR', locale_dir) +conf.set_quoted('PKGDATADIR', pkgdata_dir) +conf.set_quoted('DATADIR', data_dir) +conf.set_quoted('PKGSYSCONFDIR', pkgsysconf_dir) +conf.set_quoted('SYSCONFDIR', sysconf_dir) +conf.set_quoted('LIBEXECDIR', libexec_dir) +conf.set('SECRET_API_SUBJECT_TO_CHANGE', true) +conf.set_quoted('G_LOG_DOMAIN', 'InitialSetup') +conf.set('G_LOG_USE_STRUCTURED', true) +conf.set('GLIB_VERSION_MIN_REQUIRED', 'GLIB_VERSION_2_64') +conf.set('GLIB_VERSION_MAX_ALLOWED', 'GLIB_VERSION_2_64') + +enable_systemd = get_option('systemd') +if enable_systemd + systemd_dep = dependency('systemd', version: '>= 242', required: false) + assert(systemd_dep.found(), 'Systemd support explicitly required, but systemd not found') + + systemd_userunitdir = systemd_dep.get_variable(pkgconfig: 'systemduserunitdir', + pkgconfig_define: ['prefix', prefix]) + systemd_sysusersdir = systemd_dep.get_variable(pkgconfig: 'sysusersdir', + pkgconfig_define: ['prefix', prefix]) +endif + +vendor_conf_file = get_option('vendor-conf-file') +if vendor_conf_file != '' + conf.set_quoted('VENDOR_CONF_FILE', vendor_conf_file) +endif + +# Needed for the 'keyboard' page +ibus_dep = dependency ('ibus-1.0', + version: '>= 1.4.99', + required: get_option('ibus')) +have_ibus = ibus_dep.found() +conf.set('HAVE_IBUS', have_ibus) + +# Check for libadwaita before malcontent-ui, otherwise Meson may search and +# find an older version of libadwaita in the host system, cache it, and fail +# to fallback to a submodule. +libadwaita_dep = dependency( + 'libadwaita-1', + version: '>= 1.2.alpha', + fallback: ['libadwaita', 'libadwaita_dep'], + default_options: ['examples=false', 'introspection=disabled', 'tests=false', 'vapi=false'], +) + +# Needed for the parental controls pages +libmalcontent_dep = dependency ('malcontent-0', + version: '>= 0.6.0', + required: get_option('parental_controls')) +libmalcontent_ui_dep = dependency ('malcontent-ui-1', + version: '>= 0.11.0', + required: get_option('parental_controls'), + fallback: ['malcontent-ui', 'libmalcontent_ui_dep']) +have_parental_controls = libmalcontent_dep.found() and libmalcontent_ui_dep.found() +conf.set('HAVE_PARENTAL_CONTROLS', have_parental_controls) + +webkitgtk_dep = dependency('webkitgtk-6.0', required: false) +if webkitgtk_dep.found() + conf.set10('HAVE_WEBKITGTK_6_0', true) +else + webkitgtk_dep = dependency('webkit2gtk-5.0') +endif + +configure_file(output: 'config.h', + configuration: conf) +config_h_dir = include_directories('.') + +subdir('data') +subdir('gnome-initial-setup') +subdir('po') +subdir('build-aux') + +summary( + { + 'systemd support': enable_systemd, + 'IBus': have_ibus, + 'Parental Controls': have_parental_controls, + 'Vendor Configuration File': + vendor_conf_file == '' + ? '(default search path)' + : vendor_conf_file, + }, + section: 'Options', + bool_yn: true, +) |