aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/linkers.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2019-09-05 23:45:54 +0300
committerGitHub <noreply@github.com>2019-09-05 23:45:54 +0300
commitd67d5411bb7fa00226365ebcfc475af08a4ba721 (patch)
treef0636ff994401375e4e1d38cb7d4559e58462d67 /mesonbuild/linkers.py
parent7b765155347005e01bdd9ae8bfdad7182f27f852 (diff)
parentb9af8f8b6b394903d64e4886712b38a056cd876f (diff)
downloadmeson-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.py16
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 = {