From: Joerg Jaspert Date: Sun, 12 Aug 2012 17:16:15 +0000 (+0200) Subject: Merge remote-tracking branch 'ansgar/pu/multiarchive-2' X-Git-Url: https://git.decadent.org.uk/gitweb/?a=commitdiff_plain;h=1ed166930da5d00d035eac23fac5f3f576bf6827;hp=05c1887d078b9c6802046d8274aa21b9d8b70fa0;p=dak.git Merge remote-tracking branch 'ansgar/pu/multiarchive-2' * ansgar/pu/multiarchive-2: dak/make_changelog.py: update for multiarchive changes dak/make_maintainers.py: add archive option Signed-off-by: Joerg Jaspert --- diff --git a/dak/make_changelog.py b/dak/make_changelog.py index 2fe77fe6..d2b9ba7b 100755 --- a/dak/make_changelog.py +++ b/dak/make_changelog.py @@ -169,12 +169,14 @@ def export_files(session, pool, clpool): unpack = {} files = ('changelog', 'copyright', 'NEWS.Debian', 'README.Debian') stats = {'unpack': 0, 'created': 0, 'removed': 0, 'errors': 0, 'files': 0} - query = """SELECT DISTINCT s.source, su.suite_name AS suite, s.version, f.filename + query = """SELECT DISTINCT s.source, su.suite_name AS suite, s.version, c.name || '/' || f.filename FROM source s JOIN newest_source n ON n.source = s.source AND n.version = s.version JOIN src_associations sa ON sa.source = s.id JOIN suite su ON su.id = sa.suite JOIN files f ON f.id = s.file + JOIN files_archive_map fam ON f.id = fam.file_id AND fam.archive_id = su.id + JOIN component c ON fam.component_id = c.id ORDER BY s.source, suite""" for p in session.execute(query): diff --git a/dak/make_maintainers.py b/dak/make_maintainers.py index b7f72985..30606e9a 100755 --- a/dak/make_maintainers.py +++ b/dak/make_maintainers.py @@ -43,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) @@ -67,31 +68,42 @@ 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.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: