macOS: Remove more unused linkerlike args

`-L` and `-headerpad_max_install_names` are both linker arguments that
are commonly passed in CFLAGS too.

Closes https://github.com/mesonbuild/meson/issues/6294
pull/6668/head
Nirbheek Chauhan 4 years ago
parent 090eaac918
commit 36b4dec262
  1. 20
      mesonbuild/compilers/compilers.py
  2. 5
      run_unittests.py

@ -1059,7 +1059,25 @@ class Compiler:
return self.linker.get_undefined_link_args()
def remove_linkerlike_args(self, args):
return [x for x in args if not x.startswith('-Wl')]
rm_exact = ('-headerpad_max_install_names',)
rm_prefixes = ('-Wl,', '-L',)
rm_next = ('-L',)
ret = []
iargs = iter(args)
for arg in iargs:
# Remove this argument
if arg in rm_exact:
continue
# If the argument starts with this, but is not *exactly* this
# f.ex., '-L' should match ['-Lfoo'] but not ['-L', 'foo']
if arg.startswith(rm_prefixes) and arg not in rm_prefixes:
continue
# Ignore this argument and the one after it
if arg in rm_next:
next(iargs)
continue
ret.append(arg)
return ret
def get_lto_compile_args(self) -> T.List[str]:
return []

@ -4896,6 +4896,11 @@ class DarwinTests(BasePlatformTests):
self.build()
self.install()
def test_removing_unused_linker_args(self):
testdir = os.path.join(self.common_test_dir, '108 has arg')
env = {'CFLAGS': '-L/tmp -L /var/tmp -headerpad_max_install_names -Wl,-export_dynamic'}
self.init(testdir, override_envvars=env)
@unittest.skipUnless(not is_windows(), "requires something Unix-like")
class LinuxlikeTests(BasePlatformTests):

Loading…
Cancel
Save