diff options
author | Marvin W <git@larma.de> | 2025-01-03 21:55:20 +0100 |
---|---|---|
committer | Marvin W <git@larma.de> | 2025-01-18 19:39:13 +0100 |
commit | 73e28e6c61285c78e38a76f93a0c5171c7846c3b (patch) | |
tree | 519842a3af0177fb9d539f5951997997f671e124 | |
parent | b98b597c92ad9d2372af1672a5efe5166005d039 (diff) | |
download | dino-73e28e6c61285c78e38a76f93a0c5171c7846c3b.tar.gz dino-73e28e6c61285c78e38a76f93a0c5171c7846c3b.zip |
Meson: Add all defines to handle dependency versions
-rw-r--r-- | libdino/meson.build | 6 | ||||
-rw-r--r-- | main/meson.build | 21 | ||||
-rw-r--r-- | plugins/http-files/meson.build | 2 | ||||
-rw-r--r-- | plugins/openpgp/meson.build | 3 | ||||
-rw-r--r-- | plugins/rtp/meson.build | 22 | ||||
-rw-r--r-- | xmpp-vala/meson.build | 4 |
6 files changed, 50 insertions, 8 deletions
diff --git a/libdino/meson.build b/libdino/meson.build index 801c61c0..22e44372 100644 --- a/libdino/meson.build +++ b/libdino/meson.build @@ -81,7 +81,11 @@ c_args = [ '-DDINO_SYSTEM_PLUGIN_DIR="@0@"'.format(get_option('prefix') / get_option('plugindir')), '-DG_LOG_DOMAIN="libdino"', ] -lib_dino = library('libdino', sources, c_args: c_args, include_directories: include_directories('src'), dependencies: dependencies, name_prefix: '', version: '0.0', install: true, install_dir: [true, true, true]) +vala_args = [] +if meson.get_compiler('vala').version().version_compare('=0.56.11') + vala_args += ['-D', 'VALA_0_56_11'] +endif +lib_dino = library('libdino', sources, c_args: c_args, vala_args: vala_args, include_directories: include_directories('src'), dependencies: dependencies, name_prefix: '', version: '0.0', install: true, install_dir: [true, true, true]) dep_dino = declare_dependency(link_with: lib_dino, include_directories: include_directories('.', 'src')) install_data('dino.deps', install_dir: get_option('datadir') / 'vala/vapi') # TODO: workaround for https://github.com/mesonbuild/meson/issues/9756 diff --git a/main/meson.build b/main/meson.build index 48022b21..8096551f 100644 --- a/main/meson.build +++ b/main/meson.build @@ -121,6 +121,27 @@ endif if dep_gtk4.version() == 'unknown' or dep_gtk4.version().version_compare('>=4.8') vala_args += ['-D', 'GTK_4_8'] endif +if dep_gtk4.version() == 'unknown' or dep_gtk4.version().version_compare('>=4.12') + vala_args += ['-D', 'GTK_4_12'] +endif +if dep_libadwaita.version() == 'unknown' or dep_libadwaita.version().version_compare('>=1.3') + vala_args += ['-D', 'Adw_1_3'] +endif +if dep_libadwaita.version() == 'unknown' or dep_libadwaita.version().version_compare('>=1.4') + vala_args += ['-D', 'Adw_1_4'] +endif +if meson.get_compiler('vala').version().version_compare('>=0.56.5') and meson.get_compiler('vala').version().version_compare('<0.58') + vala_args += ['-D', 'VALA_0_56_GREATER_5'] +endif +if meson.get_compiler('vala').version().version_compare('>=0.56.11') and meson.get_compiler('vala').version().version_compare('<0.58') + vala_args += ['-D', 'VALA_0_56_GREATER_11'] +endif +if meson.get_compiler('vala').version().version_compare('=0.56.11') + vala_args += ['-D', 'VALA_0_56_11'] +endif +if meson.get_compiler('vala').version().version_compare('=0.56.12') + vala_args += ['-D', 'VALA_0_56_12'] +endif exe_dino = executable('dino', sources, c_args: c_args, vala_args: vala_args, dependencies: dependencies, install: true) install_data('data/icons/scalable/apps/im.dino.Dino-symbolic.svg', install_dir: get_option('datadir') / 'icons/hicolor/symbolic/apps') diff --git a/plugins/http-files/meson.build b/plugins/http-files/meson.build index 6b0f3820..edad5767 100644 --- a/plugins/http-files/meson.build +++ b/plugins/http-files/meson.build @@ -16,7 +16,7 @@ sources = files( ) vala_args = [ - '--define=SOUP_3_0', + '-D', 'SOUP_3_0', ] lib_http_files = shared_library('http-files', sources, name_prefix: '', vala_args: vala_args, dependencies: dependencies, install: true, install_dir: get_option('libdir') / 'dino/plugins') dep_http_files = declare_dependency(link_with: lib_http_files, include_directories: include_directories('.')) diff --git a/plugins/openpgp/meson.build b/plugins/openpgp/meson.build index ad1614d6..52833b5d 100644 --- a/plugins/openpgp/meson.build +++ b/plugins/openpgp/meson.build @@ -40,5 +40,8 @@ c_args = [ vala_args = [ '--vapidir', meson.current_source_dir() / 'vapi', ] +if dep_libadwaita.version() == 'unknown' or dep_libadwaita.version().version_compare('>=1.4') + vala_args += ['-D', 'Adw_1_4'] +endif lib_openpgp = shared_library('openpgp', sources, name_prefix: '', c_args: c_args, vala_args: vala_args, include_directories: include_directories('src'), dependencies: dependencies, install: true, install_dir: get_option('libdir') / 'dino/plugins') dep_openpgp = declare_dependency(link_with: lib_openpgp, include_directories: include_directories('.')) diff --git a/plugins/rtp/meson.build b/plugins/rtp/meson.build index a222a05a..a8cadeaf 100644 --- a/plugins/rtp/meson.build +++ b/plugins/rtp/meson.build @@ -27,16 +27,22 @@ sources = files( c_args = [ '-DG_LOG_DOMAIN="rtp"', ] -vala_args = [ - '--vapidir', meson.current_source_dir() / 'vapi', -] +vala_args = [] if dep_webrtc_audio_processing.found() - dependencies += [dep_webrtc_audio_processing] - sources += files( - 'src/voice_processor.vala', + voice_dependencies = [ + dep_gstreamer_audio, + dep_webrtc_audio_processing, + ] + voice_sources = files( 'src/voice_processor_native.cpp', ) + lib_rtp_voice_processor = static_library('rtp-voice-processor', voice_sources, c_args: c_args, dependencies: voice_dependencies, install: false) + dep_rtp_voice_processor = declare_dependency(link_with: lib_rtp_voice_processor) vala_args += ['-D', 'WITH_VOICE_PROCESSOR'] + dependencies += [dep_rtp_voice_processor] + sources += files( + 'src/voice_processor.vala', + ) endif if dep_gstreamer_rtp.version() == 'unknown' or dep_gstreamer_rtp.version().version_compare('>=1.16') vala_args += ['-D', 'GST_1_16'] @@ -47,6 +53,9 @@ endif if dep_gstreamer_rtp.version() == 'unknown' or dep_gstreamer_rtp.version().version_compare('>=1.20') vala_args += ['-D', 'GST_1_20'] endif +if meson.get_compiler('vala').version().version_compare('<0.56.1') + vala_args += ['--vapidir', meson.current_source_dir() / 'vapi'] +endif if get_option('plugin-rtp-h264').allowed() vala_args += ['-D', 'ENABLE_H264'] endif @@ -59,5 +68,6 @@ endif if get_option('plugin-rtp-vp9').allowed() vala_args += ['-D', 'ENABLE_VP9'] endif + lib_rtp = shared_library('rtp', sources, name_prefix: '', c_args: c_args, vala_args: vala_args, include_directories: include_directories('src'), dependencies: dependencies, install: true, install_dir: get_option('libdir') / 'dino/plugins') dep_rtp = declare_dependency(link_with: lib_rtp, include_directories: include_directories('.')) diff --git a/xmpp-vala/meson.build b/xmpp-vala/meson.build index a79ec982..7237891b 100644 --- a/xmpp-vala/meson.build +++ b/xmpp-vala/meson.build @@ -139,6 +139,10 @@ c_args = [ vala_args = [ '--vapidir', meson.current_source_dir() / 'vapi', ] +if meson.get_compiler('vala').version().version_compare('=0.56.11') + vala_args += ['-D', 'VALA_0_56_11'] +endif + lib_xmpp_vala = library('xmpp-vala', sources, c_args: c_args, vala_args: vala_args, dependencies: dependencies, version: '0.1', install: true, install_dir: [true, true, true]) dep_xmpp_vala = declare_dependency(link_with: lib_xmpp_vala, include_directories: include_directories('.')) |