diff options
Diffstat (limited to '')
-rw-r--r-- | src/daemon/meson.build | 141 |
1 files changed, 141 insertions, 0 deletions
diff --git a/src/daemon/meson.build b/src/daemon/meson.build new file mode 100644 index 0000000..5d5914e --- /dev/null +++ b/src/daemon/meson.build @@ -0,0 +1,141 @@ +pipewire_daemon_sources = [ + 'pipewire.c', +] + +pipewire_c_args = [ + '-DG_LOG_DOMAIN=g_log_domain_pipewire', +] + +conf_config = configuration_data() +conf_config.set('VERSION', '"@0@"'.format(pipewire_version)) +conf_config.set('PIPEWIRE_CONFIG_DIR', pipewire_configdir) +conf_config.set('session_manager_path', pipewire_bindir / 'pipewire-media-session') +conf_config.set('session_manager_args', '') +conf_config.set('pipewire_path', pipewire_bindir / 'pipewire') +conf_config.set('pipewire_pulse_path', pipewire_bindir / 'pipewire-pulse') +conf_config.set('sm_comment', '#') +conf_config.set('pulse_comment', '#') + +conf_config_uninstalled = conf_config +conf_config_uninstalled.set('pipewire_path', + meson.project_build_root() / 'src' / 'daemon' / 'pipewire') +conf_config_uninstalled.set('pipewire_pulse_path', + meson.project_build_root() / 'src' / 'daemon' / 'pipewire-pulse') +conf_config_uninstalled.set('pulse_comment', '') + +build_ms = 'media-session' in get_option('session-managers') +build_wp = 'wireplumber' in get_option('session-managers') +default_sm = get_option('session-managers').get(0, '') + +summary({'Build media-session': build_ms, + 'Build wireplumber': build_wp, + 'Default session-manager': default_sm}, + section: 'Session managers', + bool_yn: true) + +if build_wp + wp_proj = subproject('wireplumber', required : true) +endif +if build_ms + ms_proj = subproject('media-session', required : true) +endif + +if default_sm == '' + summary({'No session manager': 'pw-uninstalled.sh will not work out of the box!'}) +elif default_sm == 'media-session' + ms_bindir = ms_proj.get_variable('media_session_bin_dir', pipewire_bindir) + conf_config.set('session_manager_path', ms_bindir / 'pipewire-media-session') + + ms_uninstalled = ms_proj.get_variable('media_session_uninstalled') + conf_config_uninstalled.set('session_manager_path', ms_uninstalled.full_path()) + conf_config_uninstalled.set('session_manager_args', 'pipewire-media-session') + conf_config_uninstalled.set('sm_comment', '') +elif default_sm == 'wireplumber' + wp_bindir = wp_proj.get_variable('wireplumber_bin_dir', pipewire_bindir) + conf_config.set('session_manager_path', wp_bindir / 'wireplumber') + + wp_uninstalled = wp_proj.get_variable('wireplumber_uninstalled') + conf_config_uninstalled.set('session_manager_path', wp_uninstalled.full_path()) + conf_config_uninstalled.set('session_manager_args', 'wireplumber') + conf_config_uninstalled.set('sm_comment', '') +else + conf_config_uninstalled.set('session_manager_path', default_sm) + conf_config_uninstalled.set('sm_comment', '') +endif + +conf_files = [ + 'pipewire.conf', + 'client.conf', + 'client-rt.conf', + 'filter-chain.conf', + 'jack.conf', + 'minimal.conf', + 'pipewire-pulse.conf', + 'pipewire-avb.conf', +] + +foreach c : conf_files + configure_file(input : '@0@.in'.format(c), + output : c, + configuration : conf_config, + install_dir : pipewire_confdatadir) +endforeach + +configure_file(input : 'pipewire.conf.in', + output : 'pipewire-uninstalled.conf', + configuration : conf_config_uninstalled) + +pipewire_exec = executable('pipewire', + pipewire_daemon_sources, + install: true, + c_args : pipewire_c_args, + include_directories : [ configinc ], + dependencies : [ spa_dep, pipewire_dep, ], +) + +executable('pipewire-pulse', + pipewire_daemon_sources, + install: true, + c_args : pipewire_c_args, + include_directories : [ configinc ], + dependencies : [ spa_dep, pipewire_dep, ], +) + +executable('pipewire-avb', + pipewire_daemon_sources, + install: true, + c_args : pipewire_c_args, + include_directories : [ configinc ], + dependencies : [ spa_dep, pipewire_dep, ], +) + +ln = find_program('ln') + +custom_target('pipewire-uninstalled', + build_by_default: true, + install: false, + input: pipewire_exec, + output: 'pipewire-uninstalled', + command: [ln, '-fs', meson.project_build_root() + '/@INPUT@', '@OUTPUT@'], +) + +#desktop_file = i18n.merge_file( +# input : 'pipewire.desktop.in', +# output : 'pipewire.desktop', +# po_dir : po_dir, +# type : 'desktop', +# install : true, +# install_dir : pipewire_sysconfdir / 'xdg' / 'autostart' +#) +# +#desktop_utils = find_program('desktop-file-validate', required: false) +#if desktop_utils.found() +# test('Validate desktop file', desktop_utils, +# args: [ desktop_file ], +# ) +#endif + +subdir('filter-chain') +if systemd.found() + subdir('systemd') +endif |