diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2017-04-15 18:16:35 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-04-15 18:16:35 +0300 |
commit | 4e1249c920a6f64e2ca953334e9ec700f30693da (patch) | |
tree | 4ff1e03ac95c0827c6519b0fe684f41602bb47c3 /mesonbuild/backend/ninjabackend.py | |
parent | dcc95d7f705c5fbc036d7d6511f6df50beaac44a (diff) | |
parent | 62b86824f03d6b401f7bc8da6ce68b334726df44 (diff) | |
download | meson-4e1249c920a6f64e2ca953334e9ec700f30693da.zip meson-4e1249c920a6f64e2ca953334e9ec700f30693da.tar.gz meson-4e1249c920a6f64e2ca953334e9ec700f30693da.tar.bz2 |
Merge pull request #1549 from mesonbuild/linkwhole
Add option to link the entire contents of a static library to a target.
Diffstat (limited to 'mesonbuild/backend/ninjabackend.py')
-rw-r--r-- | mesonbuild/backend/ninjabackend.py | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/mesonbuild/backend/ninjabackend.py b/mesonbuild/backend/ninjabackend.py index 98a2110..dc05d34 100644 --- a/mesonbuild/backend/ninjabackend.py +++ b/mesonbuild/backend/ninjabackend.py @@ -2187,6 +2187,10 @@ rule FORTRAN_DEP_HACK raise RuntimeError('Unknown build target type.') return commands + def get_link_whole_args(self, linker, target): + target_args = self.build_target_link_arguments(linker, target.link_whole_targets) + return linker.get_link_whole_for(target_args) + def generate_link(self, target, outfile, outname, obj_list, linker, extra_args=[]): if isinstance(target, build.StaticLibrary): linker_base = 'STATIC' @@ -2226,6 +2230,11 @@ rule FORTRAN_DEP_HACK # Add link args specific to this BuildTarget type, such as soname args, # PIC, import library generation, etc. commands += self.get_target_type_link_args(target, linker) + # Archives that are copied wholesale in the result. Must be before any + # other link targets so missing symbols from whole archives are found in those. + if not isinstance(target, build.StaticLibrary): + commands += self.get_link_whole_args(linker, target) + if not isinstance(target, build.StaticLibrary): # Add link args added using add_project_link_arguments() commands += self.build.get_project_link_args(linker, target.subproject) |