From 968e0fddb9d2e34936b80f91785e73a96249b195 Mon Sep 17 00:00:00 2001 From: Nirbheek Chauhan Date: Thu, 6 Jun 2024 14:52:41 +0530 Subject: [PATCH] meson: Fix plugin requirement checking and add logging We were silently skipping plugins that didn't find a required feature, even if the plugin option was enabled. Part-of: --- meson.build | 123 +++++++++++++++++++++++++++++----------------------- 1 file changed, 68 insertions(+), 55 deletions(-) diff --git a/meson.build b/meson.build index d86377878..a9584374f 100644 --- a/meson.build +++ b/meson.build @@ -394,63 +394,76 @@ endif foreach plugin_name, details: plugins plugin_opt = get_variable(f'@plugin_name@_option', get_option(plugin_name)) - if plugin_opt.allowed() - plugin_deps_found = true - foreach dep_name, dep_ver: details.get('extra-deps', {}) - if dep_ver.length() != 0 - dep = dependency(dep_name, version: dep_ver, required: plugin_opt) - else - dep = dependency(dep_name, required: plugin_opt) - endif - deps_cache += {dep_name: dep} - if not dep.found() - plugin_deps_found = false - break - endif - endforeach - plugin_features = details.get('features', []) - if plugin_deps_found - # Validate gst-plugin features - foreach feature: plugin_features - if feature.startswith('gst-plugin') and not packages.contains(feature) - plugin_deps_found = false - break - endif - endforeach - endif - if details.has_key('gst-version') - # Check if we have the required GStreamer version - gst_version = details.get('gst-version', '') - dep = dependency('gstreamer-1.0', required: false, version: gst_version) - if not dep.found() - opt = get_option(plugin_name) - if opt.enabled() - error('Required GStreamer version not found to build ' + plugin_name) - endif - plugin_deps_found = false - endif - endif - if plugin_deps_found - packages += f'gst-plugin-@plugin_name@' - features += plugin_features - extra_features = run_command('dependencies.py', meson.current_source_dir(), plugin_name, - '--feature', '--gst-version', gst_dep.version(), capture: true, check: true).stdout().strip() - if extra_features != '' - features += extra_features.split(',') - endif + if not plugin_opt.allowed() + debug(f'@plugin_name@ is disabled') + continue + endif + plugin_deps_found = true - lib = details.get('library') - # No 'lib' suffix with MSVC - if cc.get_argument_syntax() == 'msvc' - lib = lib.substring(3) - endif - if default_library in ['shared', 'both'] - output += [lib + '.' + ext_dynamic] - endif - if default_library in ['static', 'both'] - output += [lib + '.' + ext_static] - endif + # Check whether we have all needed deps + foreach dep_name, dep_ver: details.get('extra-deps', {}) + if dep_ver.length() != 0 + dep = dependency(dep_name, version: dep_ver, required: plugin_opt) + else + dep = dependency(dep_name, required: plugin_opt) endif + deps_cache += {dep_name: dep} + if not dep.found() + debug(f'@plugin_name@ dependency @dep_name@ @dep_ver@ not found, skipping') + plugin_deps_found = false + break + endif + endforeach + if not plugin_deps_found + continue + endif + + # Validate gst-plugin features + plugin_features = details.get('features', []) + foreach feature: plugin_features + if feature.startswith('gst-plugin') and not packages.contains(feature) + msg = f'@plugin_name@ required feature @feature@ not found' + if plugin_opt.enabled() + error(msg) + endif + message(msg + ', skipping') + plugin_deps_found = false + break + endif + endforeach + if not plugin_deps_found + continue + endif + + # Check if we have the required GStreamer version + if details.has_key('gst-version') and not \ + deps_cache['gstreamer-1.0'].version().version_compare(details['gst-version']) + msg = '@0@ requires gstreamer version @1@'.format(plugin_name, details['gst-version']) + if plugin_opt.enabled() + error(msg) + endif + message(msg + ', skipping') + continue + endif + + packages += f'gst-plugin-@plugin_name@' + features += plugin_features + extra_features = run_command('dependencies.py', meson.current_source_dir(), plugin_name, + '--feature', '--gst-version', gst_dep.version(), capture: true, check: true).stdout().strip() + if extra_features != '' + features += extra_features.split(',') + endif + + lib = details.get('library') + # No 'lib' suffix with MSVC + if cc.get_argument_syntax() == 'msvc' + lib = lib.substring(3) + endif + if default_library in ['shared', 'both'] + output += [lib + '.' + ext_dynamic] + endif + if default_library in ['static', 'both'] + output += [lib + '.' + ext_static] endif endforeach