aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--mesonbuild/compilers.py4
-rw-r--r--mesonbuild/interpreter.py21
-rw-r--r--test cases/common/112 has arg/meson.build14
3 files changed, 32 insertions, 7 deletions
diff --git a/mesonbuild/compilers.py b/mesonbuild/compilers.py
index 325b611..5b68eaa 100644
--- a/mesonbuild/compilers.py
+++ b/mesonbuild/compilers.py
@@ -293,7 +293,7 @@ class Compiler():
def get_library_dirs(self):
return []
- def has_arg(self, arg):
+ def has_argument(self, arg):
raise EnvironmentException('Language {} does not support has_arg.'.format(self.language))
class CCompiler(Compiler):
@@ -824,7 +824,7 @@ void bar() {
def thread_link_flags(self):
return ['-pthread']
- def has_arg(self, arg):
+ def has_argument(self, arg):
return self.compiles('int i;\n', extra_args=arg)
class CPPCompiler(CCompiler):
diff --git a/mesonbuild/interpreter.py b/mesonbuild/interpreter.py
index fc5620f..e6b7406 100644
--- a/mesonbuild/interpreter.py
+++ b/mesonbuild/interpreter.py
@@ -583,7 +583,8 @@ class CompilerHolder(InterpreterObject):
'version' : self.version_method,
'cmd_array' : self.cmd_array_method,
'find_library': self.find_library_method,
- 'has_arg' : self.has_arg_method,
+ 'has_argument' : self.has_argument_method,
+ 'first_supported_argument' : self.first_supported_argument_method,
})
def version_method(self, args, kwargs):
@@ -790,11 +791,25 @@ class CompilerHolder(InterpreterObject):
lib = dependencies.ExternalLibrary(libname, linkargs)
return ExternalLibraryHolder(lib)
- def has_arg_method(self, args, kwargs):
+ def has_argument_method(self, args, kwargs):
args = mesonlib.stringlistify(args)
if len(args) != 1:
raise InterpreterException('Has_arg takes exactly one argument.')
- return self.compiler.has_arg(args[0])
+ result = self.compiler.has_argument(args[0])
+ if result:
+ h = mlog.green('YES')
+ else:
+ h = mlog.red('NO')
+ mlog.log('Compiler for {} supports argument {}:'.format(self.compiler.language, args[0]), h)
+ return result
+
+ def first_supported_argument_method(self, args, kwargs):
+ for i in mesonlib.stringlistify(args):
+ if self.compiler.has_argument(i):
+ mlog.log('First supported argument:', mlog.bold(i))
+ return [i]
+ mlog.log('First supported argument:', mlog.red('None'))
+ return []
class ModuleState:
pass
diff --git a/test cases/common/112 has arg/meson.build b/test cases/common/112 has arg/meson.build
index 75c78e4..8a1d0f7 100644
--- a/test cases/common/112 has arg/meson.build
+++ b/test cases/common/112 has arg/meson.build
@@ -4,11 +4,21 @@ cc = meson.get_compiler('c')
if cc.get_id() == 'msvc'
is_arg = '/O2'
+ useless = '/DFOO'
else
is_arg = '-O2'
+ useless = '-DFOO'
endif
isnt_arg = '-fiambroken'
-assert(cc.has_arg(is_arg), 'Arg that should have worked does not work.')
-assert(not cc.has_arg(isnt_arg), 'Arg that should be broken is not.')
+assert(cc.has_argument(is_arg), 'Arg that should have worked does not work.')
+assert(not cc.has_argument(isnt_arg), 'Arg that should be broken is not.')
+
+# Have useless at the end to ensure that the search goes from front to back.
+l1 = cc.first_supported_argument([isnt_arg, is_arg, isnt_arg, useless])
+l2 = cc.first_supported_argument(isnt_arg, isnt_arg, isnt_arg)
+
+assert(l1.length() == 1, 'First supported returned wrong result.')
+assert(l1.get(0) == is_arg, 'First supported returned wrong argument.')
+assert(l2.length() == 0, 'First supported did not return empty array.')