diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2019-09-05 23:45:54 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-09-05 23:45:54 +0300 |
commit | d67d5411bb7fa00226365ebcfc475af08a4ba721 (patch) | |
tree | f0636ff994401375e4e1d38cb7d4559e58462d67 /mesonbuild/linkers.py | |
parent | 7b765155347005e01bdd9ae8bfdad7182f27f852 (diff) | |
parent | b9af8f8b6b394903d64e4886712b38a056cd876f (diff) | |
download | meson-d67d5411bb7fa00226365ebcfc475af08a4ba721.zip meson-d67d5411bb7fa00226365ebcfc475af08a4ba721.tar.gz meson-d67d5411bb7fa00226365ebcfc475af08a4ba721.tar.bz2 |
Merge pull request #5823 from scivision/linker-pgi-linux
PGI compiler fixes
Diffstat (limited to 'mesonbuild/linkers.py')
-rw-r--r-- | mesonbuild/linkers.py | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/mesonbuild/linkers.py b/mesonbuild/linkers.py index 8de254b..795a0a2 100644 --- a/mesonbuild/linkers.py +++ b/mesonbuild/linkers.py @@ -739,18 +739,30 @@ class PGIDynamicLinker(PosixDynamicLinkerMixin, DynamicLinker): # PGI -shared is Linux only. if mesonlib.is_windows(): return ['-Bdynamic', '-Mmakedll'] - elif mesonlib.is_linux: + elif mesonlib.is_linux(): return ['-shared'] return [] def build_rpath_args(self, env: 'Environment', build_dir: str, from_dir: str, rpath_paths: str, build_rpath: str, install_rpath: str) -> typing.List[str]: - if env.machines[self.for_machine].is_windows(): + if not env.machines[self.for_machine].is_windows(): return ['-R' + os.path.join(build_dir, p) for p in rpath_paths] return [] +class PGIStaticLinker(StaticLinker): + def __init__(self, exelist: typing.List[str]): + super().__init__(exelist) + self.id = 'ar' + self.std_args = ['-r'] + + def get_std_link_args(self) -> typing.List[str]: + return self.std_args + + def get_output_args(self, target: str) -> typing.List[str]: + return [target] + class VisualStudioLikeLinkerMixin: _BUILDTYPE_ARGS = { |