X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=dak%2Fclean_suites.py;h=e571ae0e8c585aee24e2b3f9dc8ee2721d2705a6;hb=e69060c1cca5a08ee5ae4ad7232a9eb51d3d09c5;hp=caa69709b2561333c1e95d61878d8fc29cf297c0;hpb=43011db2d8a3b7a4508637cab3fe224a8ee79123;p=dak.git diff --git a/dak/clean_suites.py b/dak/clean_suites.py index caa69709..e571ae0e 100755 --- a/dak/clean_suites.py +++ b/dak/clean_suites.py @@ -214,7 +214,7 @@ def clean_binaries(now_date, session): AND NOT EXISTS (SELECT 1 FROM files_archive_map af JOIN archive_delete_date ad ON af.archive_id = ad.archive_id WHERE af.file_id = b.file - AND (af.last_used IS NULL OR af.last_used >= ad.delete_date)) + AND (af.last_used IS NULL OR af.last_used > ad.delete_date)) RETURNING f.filename """) for b in q: @@ -222,7 +222,7 @@ def clean_binaries(now_date, session): ######################################## -def clean(now_date, max_delete, session): +def clean(now_date, archives, max_delete, session): cnf = Config() count = 0 @@ -254,7 +254,7 @@ def clean(now_date, max_delete, session): AND NOT EXISTS (SELECT 1 FROM files_archive_map af JOIN archive_delete_date ad ON af.archive_id = ad.archive_id WHERE af.file_id = source.file - AND (af.last_used IS NULL OR af.last_used >= ad.delete_date)) + AND (af.last_used IS NULL OR af.last_used > ad.delete_date)) RETURNING source.id AS id, f.filename AS filename ), deleted_dsc_files AS ( @@ -280,6 +280,10 @@ def clean(now_date, max_delete, session): old_files = old_files.limit(max_delete) print "Limiting removals to %d" % max_delete + if archives is not None: + archive_ids = [ a.archive_id for a in archives ] + old_files = old_files.filter(ArchiveFile.archive_id.in_(archive_ids)) + for af in old_files: filename = af.path if not os.path.exists(filename): @@ -445,6 +449,7 @@ def main(): cnf["Clean-Suites::Options::%s" % (i)] = "" Arguments = [('h',"help","Clean-Suites::Options::Help"), + ('a','archive','Clean-Suites::Options::Archive','HasArg'), ('n',"no-action","Clean-Suites::Options::No-Action"), ('m',"maximum","Clean-Suites::Options::Maximum", "HasArg")] @@ -469,6 +474,13 @@ def main(): session = DBConn().session() + archives = None + if 'Archive' in Options: + archive_names = Options['Archive'].split(',') + archives = session.query(Archive).filter(Archive.archive_name.in_(archive_names)).all() + if len(archives) == 0: + utils.fubar('Unknown archive.') + now_date = datetime.now() set_archive_delete_dates(now_date, session) @@ -477,7 +489,7 @@ def main(): clean_binaries(now_date, session) check_sources(now_date, session) check_files(now_date, session) - clean(now_date, max_delete, session) + clean(now_date, archives, max_delete, session) clean_maintainers(now_date, session) clean_fingerprints(now_date, session) clean_empty_directories(session)