]> err.no Git - dak/commitdiff
add function to clean fingerprints table
authorJames Troup <james@nocrew.org>
Mon, 22 Apr 2002 11:06:49 +0000 (11:06 +0000)
committerJames Troup <james@nocrew.org>
Mon, 22 Apr 2002 11:06:49 +0000 (11:06 +0000)
rhona

diff --git a/rhona b/rhona
index 9aa3215f5ed8a3b1a0a3f96b0c2ac636211af0a1..c5e63df0cad7d0be6a6bc67eec947b5e3ccb2278 100755 (executable)
--- a/rhona
+++ b/rhona
@@ -2,7 +2,7 @@
 
 # rhona, cleans up unassociated binary and source packages
 # Copyright (C) 2000, 2001  James Troup <james@nocrew.org>
-# $Id: rhona,v 1.20 2002-02-12 22:14:38 troup Exp $
+# $Id: rhona,v 1.21 2002-04-22 11:06:49 troup Exp $
 
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -237,6 +237,8 @@ def clean():
     if count > 0:
         sys.stderr.write("Cleaned %d files, %s.\n" % (count, utils.size_type(size)));
 
+################################################################################
+
 def clean_maintainers():
     print "Cleaning out unused Maintainer entries..."
 
@@ -260,6 +262,29 @@ SELECT m.id FROM maintainer m
 
 ################################################################################
 
+def clean_fingerprints():
+    print "Cleaning out unused fingerprint entries..."
+
+    q = projectB.query("""
+SELECT f.id FROM fingerprint f
+  WHERE NOT EXISTS (SELECT id FROM binaries b WHERE b.sig_fpr = f.id)
+    AND NOT EXISTS (SELECT id FROM source s WHERE s.sig_fpr = f.id)""");
+    ql = q.getresult();
+
+    count = 0;
+    projectB.query("BEGIN WORK");
+    for i in ql:
+        fingerprint_id = i[0];
+        if not Options["No-Action"]:
+            projectB.query("DELETE FROM fingerprint WHERE id = %s" % (fingerprint_id));
+            count = count + 1;
+    projectB.query("COMMIT WORK");
+
+    if count > 0:
+        sys.stderr.write("Cleared out %d fingerprint entries.\n" % (count));
+
+################################################################################
+
 def main():
     global Cnf, Options, projectB, delete_date, now_date;
 
@@ -288,6 +313,7 @@ def main():
     check_files();
     clean();
     clean_maintainers();
+    clean_fingerprints();
 
 ################################################################################