0001-Prefer-ext-static-libs-when-default-library-static.patch 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. From c1359a49b61016031287d62f44a363cb76242c91 Mon Sep 17 00:00:00 2001
  2. From: Matt Weber <matthew.weber@rockwellcollins.com>
  3. Date: Sat, 26 Oct 2019 09:17:29 -0500
  4. Subject: [PATCH] Prefer ext static libs when --default-library=static
  5. This patch adds a case in the library pattern logic to prefer static
  6. libraries when the Meson Core option for "default_library" is set to
  7. solely static.
  8. The existing library search order makes sense for cases of shared and
  9. shared / static mixed. However if using a prebuilt cross-toolchain,
  10. they usually provide both a static and shared version of sysroot
  11. libraries. This presents a problem in a complete static build where
  12. there won't be shared libraries at runtime and during build time there
  13. are failures like "ld: attempted static link of dynamic object".
  14. Bug:
  15. https://github.com/mesonbuild/meson/issues/6108
  16. Fixes:
  17. http://autobuild.buildroot.net/results/db1740b4777f436324218c52bc7b08e5c21b667d/
  18. http://autobuild.buildroot.net/results/c17/c17bbb12d9deadd64a441b36e324cfbbe8aba5be/
  19. Signed-off-by: Matthew Weber <matthew.weber@rockwellcollins.com>
  20. [Updated for 0.57.1 - get_builtin_option() vs. get_option(OptionKey())]
  21. Signed-off-by: Peter Seiderer <ps.report@gmx.net>
  22. ---
  23. mesonbuild/compilers/mixins/clike.py | 3 +++
  24. 1 file changed, 3 insertions(+)
  25. diff --git a/mesonbuild/compilers/mixins/clike.py b/mesonbuild/compilers/mixins/clike.py
  26. index 09ad837b1..b7f6b9f22 100644
  27. --- a/mesonbuild/compilers/mixins/clike.py
  28. +++ b/mesonbuild/compilers/mixins/clike.py
  29. @@ -978,6 +978,9 @@ class CLikeCompiler(Compiler):
  30. elif env.machines[self.for_machine].is_cygwin():
  31. shlibext = ['dll', 'dll.a']
  32. prefixes = ['cyg'] + prefixes
  33. + elif env.coredata.get_option(OptionKey('default_library')) == 'static':
  34. + # Linux/BSDs
  35. + shlibext = ['a']
  36. else:
  37. # Linux/BSDs
  38. shlibext = ['so']
  39. --
  40. 2.25.1