X-Git-Url: https://git.decadent.org.uk/gitweb/?p=dak.git;a=blobdiff_plain;f=dak%2Fmake_maintainers.py;h=30606e9a429a1fee4fbfb45776a42455895a7309;hp=2909a3574313d1dc4e946bc9a613ff615bc4e55b;hb=fdbef587c29814f97c192de5a8b7e9f09cc45fa4;hpb=da255f7aa512ef7f500c80ad41c48516d772306f diff --git a/dak/make_maintainers.py b/dak/make_maintainers.py index 2909a357..30606e9a 100755 --- a/dak/make_maintainers.py +++ b/dak/make_maintainers.py @@ -31,6 +31,7 @@ Generate Maintainers file used by e.g. the Debian Bug Tracking System ################################################################################ +from daklib import daklog from daklib import utils from daklib.config import Config from daklib.dbconn import * @@ -42,9 +43,10 @@ import sys ################################################################################ def usage (exit_code=0): - print """Usage: dak make-maintainers [OPTION] EXTRA_FILE[...] + print """Usage: dak make-maintainers [OPTION] -a ARCHIVE EXTRA_FILE[...] Generate an index of packages <=> Maintainers / Uploaders. + -a, --archive=ARCHIVE archive to take packages from -h, --help show this help and exit """ sys.exit(exit_code) @@ -66,40 +68,55 @@ def uploader_list(source): def main(): cnf = Config() - Arguments = [('h',"help","Make-Maintainers::Options::Help")] + Arguments = [('h',"help","Make-Maintainers::Options::Help"), + ('a','archive','Make-Maintainers::Options::Archive','HasArg')] if not cnf.has_key("Make-Maintainers::Options::Help"): cnf["Make-Maintainers::Options::Help"] = "" - extra_files = apt_pkg.ParseCommandLine(cnf.Cnf, Arguments, sys.argv) - Options = cnf.SubTree("Make-Maintainers::Options") + extra_files = apt_pkg.parse_commandline(cnf.Cnf, Arguments, sys.argv) + Options = cnf.subtree("Make-Maintainers::Options") - if Options["Help"]: + if Options["Help"] or not Options.get('Archive'): usage() + Logger = daklog.Logger('make-maintainers') session = DBConn().session() + archive = session.query(Archive).filter_by(archive_name=Options['Archive']).one() + # dictionary packages to maintainer names maintainers = dict() # dictionary packages to list of uploader names uploaders = dict() source_query = session.query(DBSource).from_statement(''' - select distinct on (source) * from source - order by source, version desc''') + select distinct on (source.source) source.* from source + join src_associations sa on source.id = sa.source + join suite on sa.suite = suite.id + where suite.archive_id = :archive_id + order by source.source, source.version desc''') \ + .params(archive_id=archive.archive_id) binary_query = session.query(DBBinary).from_statement(''' - select distinct on (package) * from binaries - order by package, version desc''') - + select distinct on (binaries.package) binaries.* from binaries + join bin_associations ba on binaries.id = ba.bin + join suite on ba.suite = suite.id + where suite.archive_id = :archive_id + order by binaries.package, binaries.version desc''') \ + .params(archive_id=archive.archive_id) + + Logger.log(['sources']) for source in source_query: maintainers[source.source] = source.maintainer.name uploaders[source.source] = uploader_list(source) + Logger.log(['binaries']) for binary in binary_query: if binary.package not in maintainers: maintainers[binary.package] = binary.maintainer.name uploaders[binary.package] = uploader_list(binary.source) + Logger.log(['files']) # Process any additional Maintainer files (e.g. from pseudo # packages) for filename in extra_files: @@ -120,6 +137,7 @@ def main(): uploader_file.write(format(package, uploader)) uploader_file.close() maintainer_file.close() + Logger.close() ################################################################################