summarylogtreecommitdiffstats
path: root/find-deps.py
diff options
context:
space:
mode:
authorsolaraquarion2016-09-30 14:49:56 -0400
committersolaraquarion2016-09-30 14:49:56 -0400
commiteaac7f33a74b110546168fade514bfbd992c6411 (patch)
tree34e500b66a20aa669e4343b740e516f50e694346 /find-deps.py
parent826755c4d32303c1ac703e875f49a90f30491cbf (diff)
downloadaur-eaac7f33a74b110546168fade514bfbd992c6411.tar.gz
updating
Diffstat (limited to 'find-deps.py')
-rwxr-xr-xfind-deps.py48
1 files changed, 48 insertions, 0 deletions
diff --git a/find-deps.py b/find-deps.py
new file mode 100755
index 00000000000..d6761f0a40f
--- /dev/null
+++ b/find-deps.py
@@ -0,0 +1,48 @@
+#!/usr/bin/env python3
+
+"""
+Usage: find-deps.py <binary> [<binary> ...]
+
+Finds (pacman/ALPM) dependencies for a binary or set of binaries based
+on dynamically linked libraries.
+
+"""
+
+import sys
+import os
+import subprocess
+import re
+
+def subprocess_get_lines(args, fail_okay=False):
+ try:
+ output = subprocess.check_output(args)
+ except subprocess.CalledProcessError as e:
+ if fail_okay:
+ output = e.output
+ else:
+ raise
+ return output.decode().splitlines()
+
+# Get the filenames of the libs we need
+del os.environ['LD_LIBRARY_PATH'], os.environ['LD_PRELOAD'] # otherwise fakeroot will interfere
+ldd_output = subprocess_get_lines(['ldd'] + sys.argv[1:])
+regex = re.compile(r' => (.*) \(0x[0-9a-f]+\)$')
+libs = set(match.group(1) for match in map(regex.search, ldd_output) if match)
+
+# Figure out which packages own them
+deps = set(subprocess_get_lines(
+ ['pacman', '--query', '--owns', '--quiet'] + list(libs),
+ fail_okay=True
+))
+
+# Remove redundant dependencies
+needed = set(deps)
+for pkg in deps:
+ if pkg not in needed:
+ continue # this subtree has already been pruned
+ redundant = subprocess_get_lines(
+ ['pactree', '--unique', pkg]
+ )[1:] # first line is pkg itself
+ needed.difference_update(redundant)
+
+print(' '.join(sorted(needed)))