Merge pull request #3353 from xclaesse/has-link-argument
Add has_link_argument() and friendspull/3372/head
commit
8ee1e49ae6
7 changed files with 166 additions and 80 deletions
@ -0,0 +1,9 @@ |
||||
## has_link_argument() and friends |
||||
|
||||
A new set of methods has been added on compiler objects to test if the linker |
||||
supports given arguments. |
||||
|
||||
- `has_link_argument()` |
||||
- `has_multi_link_arguments()` |
||||
- `get_supported_link_arguments()` |
||||
- `first_supported_link_argument()` |
@ -0,0 +1,42 @@ |
||||
project('has link arg', 'c', 'cpp') |
||||
|
||||
cc = meson.get_compiler('c') |
||||
cpp = meson.get_compiler('cpp') |
||||
|
||||
if cc.get_id() == 'msvc' |
||||
is_arg = '/OPT:REF' |
||||
useless = '/DEBUG' |
||||
isnt_arg = '/iambroken' |
||||
else |
||||
is_arg = '-Wl,-Lfoo' |
||||
useless = '-Wl,-Lbar' |
||||
isnt_arg = '-Wl,-iambroken' |
||||
endif |
||||
|
||||
assert(cc.has_link_argument(is_arg), 'Arg that should have worked does not work.') |
||||
assert(not cc.has_link_argument(isnt_arg), 'Arg that should be broken is not.') |
||||
|
||||
assert(cpp.has_link_argument(is_arg), 'Arg that should have worked does not work.') |
||||
assert(not cpp.has_link_argument(isnt_arg), 'Arg that should be broken is not.') |
||||
|
||||
assert(cc.get_supported_link_arguments([is_arg, isnt_arg, useless]) == [is_arg, useless], 'Arg filtering returned different result.') |
||||
assert(cpp.get_supported_link_arguments([is_arg, isnt_arg, useless]) == [is_arg, useless], 'Arg filtering returned different result.') |
||||
|
||||
# Have useless at the end to ensure that the search goes from front to back. |
||||
l1 = cc.first_supported_link_argument([isnt_arg, is_arg, isnt_arg, useless]) |
||||
l2 = cc.first_supported_link_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.') |
||||
|
||||
l1 = cpp.first_supported_link_argument([isnt_arg, is_arg, isnt_arg, useless]) |
||||
l2 = cpp.first_supported_link_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.') |
||||
|
||||
assert(not cc.has_multi_link_arguments([isnt_arg, is_arg]), 'Arg that should be broken is not.') |
||||
assert(cc.has_multi_link_arguments(is_arg), 'Arg that should have worked does not work.') |
||||
assert(cc.has_multi_link_arguments([useless, is_arg]), 'Arg that should have worked does not work.') |
Loading…
Reference in new issue