X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=dak%2Foverride.py;h=1d43a62579fe08012426cb5dcd1fc2d435c50883;hb=17c5cab4eb8d5181ec7a81267a4e2e6b43c0fc65;hp=ce5d12ff41348c1f4c929fd7f5374554eafd13e3;hpb=6b3c8ccbd61325e2b833ed252b5545a190bff92f;p=dak.git diff --git a/dak/override.py b/dak/override.py index ce5d12ff..1d43a625 100755 --- a/dak/override.py +++ b/dak/override.py @@ -56,27 +56,27 @@ Make microchanges or microqueries of the binary overrides """ sys.exit(exit_code) -def check_override_compliance(package, priority, suite, cnf, session): +def check_override_compliance(package, priority, archive_path, suite_name, cnf, session): print "Checking compliance with related overrides..." depends = set() rdepends = set() components = get_component_names(session) - arches = set([x.arch_string for x in get_suite_architectures(suite)]) + arches = set([x.arch_string for x in get_suite_architectures(suite_name)]) arches -= set(["source", "all"]) for arch in arches: for component in components: - Packages = utils.get_packages_from_ftp(cnf['Dir::Root'], suite, component, arch) - while Packages.Step(): - package_name = Packages.Section.Find("Package") - dep_list = Packages.Section.Find("Depends") + Packages = utils.get_packages_from_ftp(archive_path, suite_name, component, arch) + while Packages.step(): + package_name = Packages.section.find("Package") + dep_list = Packages.section.find("Depends") if dep_list: if package_name == package: - for d in apt_pkg.ParseDepends(dep_list): + for d in apt_pkg.parse_depends(dep_list): for i in d: depends.add(i[0]) else: - for d in apt_pkg.ParseDepends(dep_list): + for d in apt_pkg.parse_depends(dep_list): for i in d: if i[0] == package: rdepends.add(package_name) @@ -87,7 +87,7 @@ def check_override_compliance(package, priority, suite, cnf, session): JOIN priority p ON p.id = o.priority WHERE s.suite_name = '%s' AND o.package in ('%s')""" \ - % (suite, "', '".join(depends.union(rdepends))) + % (suite_name, "', '".join(depends.union(rdepends))) packages = session.execute(query) excuses = [] @@ -136,10 +136,14 @@ def main (): utils.fubar("package name is a required argument.") package = arguments.pop(0) - suite = Options["Suite"] + suite_name = Options["Suite"] if arguments and len(arguments) > 2: utils.fubar("Too many arguments") + suite = get_suite(suite_name, session) + if suite is None: + utils.fubar("Unknown suite '{0}'".format(suite_name)) + if arguments and len(arguments) == 1: # Determine if the argument is a priority or a section... arg = arguments.pop() @@ -170,8 +174,8 @@ def main (): AND override.section = section.id AND override.package = :package AND override.suite = suite.id - AND suite.suite_name = :suite - """ % (eqdsc), {'package': package, 'suite': suite}) + AND suite.suite_name = :suite_name + """ % (eqdsc), {'package': package, 'suite_name': suite_name}) if q.rowcount == 0: continue @@ -227,7 +231,7 @@ def main (): utils.fubar("Trying to change priority of a source-only package") if Options["Check"] and newpriority != oldpriority: - check_override_compliance(package, p, suite, cnf, session) + check_override_compliance(package, p, suite.archive.path, suite_name, cnf, session) # If we're in no-action mode if Options["No-Action"]: @@ -266,9 +270,9 @@ def main (): SET priority = :newprioid WHERE package = :package AND override.type != :otypedsc - AND suite = (SELECT id FROM suite WHERE suite_name = :suite)""", + AND suite = (SELECT id FROM suite WHERE suite_name = :suite_name)""", {'newprioid': newprioid, 'package': package, - 'otypedsc': dsc_otype_id, 'suite': suite}) + 'otypedsc': dsc_otype_id, 'suite_name': suite_name}) Logger.log(["changed priority", package, oldpriority, newpriority]) @@ -277,9 +281,9 @@ def main (): UPDATE override SET section = :newsecid WHERE package = :package - AND suite = (SELECT id FROM suite WHERE suite_name = :suite)""", + AND suite = (SELECT id FROM suite WHERE suite_name = :suite_name)""", {'newsecid': newsecid, 'package': package, - 'suite': suite}) + 'suite_name': suite_name}) Logger.log(["changed section", package, oldsection, newsection]) @@ -311,7 +315,7 @@ def main (): Subst["__SOURCE__"] = package summary = "Concerning package %s...\n" % (package) - summary += "Operating on the %s suite\n" % (suite) + summary += "Operating on the %s suite\n" % (suite_name) if newpriority != oldpriority: summary += "Changed priority from %s to %s\n" % (oldpriority,newpriority) if newsection != oldsection: