summaryrefslogtreecommitdiffstats
path: root/waflib/extras/local_rpath.py
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-09-15 14:51:03 +0200
committerDavid Robillard <d@drobilla.net>2018-09-15 14:51:03 +0200
commit24baf7263b07558940a45be4a90928302e0a8afa (patch)
treee9c1d24888785541c29db8cb1267052933ef05fd /waflib/extras/local_rpath.py
parent570e04f26fffc6430ff6894da6a6e2f39b24efb7 (diff)
parentc2b0355b0de23f6ec83b5fa5be038bcce208e26f (diff)
downloadsuil-24baf7263b07558940a45be4a90928302e0a8afa.tar.gz
suil-24baf7263b07558940a45be4a90928302e0a8afa.tar.bz2
suil-24baf7263b07558940a45be4a90928302e0a8afa.zip
Merge commit 'c2b0355b0de23f6ec83b5fa5be038bcce208e26f' as 'waflib'
Diffstat (limited to 'waflib/extras/local_rpath.py')
-rw-r--r--waflib/extras/local_rpath.py19
1 files changed, 19 insertions, 0 deletions
diff --git a/waflib/extras/local_rpath.py b/waflib/extras/local_rpath.py
new file mode 100644
index 0000000..b2507e1
--- /dev/null
+++ b/waflib/extras/local_rpath.py
@@ -0,0 +1,19 @@
+#! /usr/bin/env python
+# encoding: utf-8
+# Thomas Nagy, 2011 (ita)
+
+from waflib.TaskGen import after_method, feature
+
+@after_method('propagate_uselib_vars')
+@feature('cprogram', 'cshlib', 'cxxprogram', 'cxxshlib', 'fcprogram', 'fcshlib')
+def add_rpath_stuff(self):
+ all = self.to_list(getattr(self, 'use', []))
+ while all:
+ name = all.pop()
+ try:
+ tg = self.bld.get_tgen_by_name(name)
+ except:
+ continue
+ self.env.append_value('RPATH', tg.link_task.outputs[0].parent.abspath())
+ all.extend(self.to_list(getattr(tg, 'use', [])))
+