summaryrefslogtreecommitdiff
path: root/multiarchanalyze.py
diff options
context:
space:
mode:
Diffstat (limited to 'multiarchanalyze.py')
-rwxr-xr-xmultiarchanalyze.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/multiarchanalyze.py b/multiarchanalyze.py
index 201ffc3..f00c66a 100755
--- a/multiarchanalyze.py
+++ b/multiarchanalyze.py
@@ -2,6 +2,7 @@
import argparse
import os.path
+import re
import sqlite3
import sys
@@ -77,6 +78,9 @@ def show_files(filenames):
return "%d files starting with %s" % (len(filenames), prefix)
return "%d files" % len(filenames)
+def sqlite_regexp(pattern, value):
+ return re.match(pattern, value) is not None
+
def main():
parser = argparse.ArgumentParser()
parser.add_argument("-d", "--database", action="store",
@@ -85,6 +89,7 @@ def main():
args = parser.parse_args()
hints = []
db = sqlite3.connect(args.database)
+ db.create_function("REGEXP", 2, sqlite_regexp)
cur = db.cursor()
cur.execute("SELECT name1, architecture1, architecture2, filename FROM masame_conflict;")
same_conflicts = {}
@@ -146,6 +151,14 @@ def main():
link="https://wiki.debian.org/MultiArch/Hints#dep-any",
severity="normal"))
+ cur.execute("SELECT name FROM maforeign_library ORDER BY name;")
+ for name, in fetchiter(cur):
+ hints.append(dict(
+ binary=name,
+ description="%s is wrongly marked Multi-Arch: foreign" % name,
+ link="https://wiki.debian.org/MultiArch/Hints#ma-foreign-library",
+ severity="high"))
+
for hint in hints:
if "source" not in hint:
cur.execute("SELECT distinct(source) FROM package WHERE name = ?;",