X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=dak%2Fgenerate_releases.py;h=213ad49bdf70b7183d8f361c506ddfaca8e9fbb8;hb=1673e4fd9f62822a1df8eca7dd6b9cfd46408942;hp=094c05644c8fde9a9932f225d10c8de7dc507d5c;hpb=73831e60bebce3aff8f61003b830438e5fa19448;p=dak.git diff --git a/dak/generate_releases.py b/dak/generate_releases.py index 094c0564..213ad49b 100755 --- a/dak/generate_releases.py +++ b/dak/generate_releases.py @@ -22,7 +22,7 @@ ################################################################################ -import sys, os, popen2, tempfile, stat, time +import sys, os, popen2, tempfile, stat, time, pg import apt_pkg import daklib.utils @@ -40,6 +40,8 @@ def usage (exit_code=0): Generate Release files (for SUITE). -h, --help show this help and exit + -a, --apt-conf FILE use FILE instead of default apt.conf + -f, --force-touch ignore Untouchable directives in dak.conf If no SUITE is given Release files are generated for all suites.""" @@ -129,8 +131,11 @@ def main (): Cnf = daklib.utils.get_conf() - Arguments = [('h',"help","Generate-Releases::Options::Help")] - for i in [ "help" ]: + Arguments = [('h',"help","Generate-Releases::Options::Help"), + ('a',"apt-conf","Generate-Releases::Options::Apt-Conf", "HasArg"), + ('f',"force-touch","Generate-Releases::Options::Force-Touch"), + ] + for i in [ "help", "apt-conf", "force-touch" ]: if not Cnf.has_key("Generate-Releases::Options::%s" % (i)): Cnf["Generate-Releases::Options::%s" % (i)] = "" @@ -140,8 +145,13 @@ def main (): if Options["Help"]: usage() + if not Options["Apt-Conf"]: + Options["Apt-Conf"] = daklib.utils.which_apt_conf_file() + AptCnf = apt_pkg.newConfiguration() - apt_pkg.ReadConfigFileISC(AptCnf,daklib.utils.which_apt_conf_file()) + apt_pkg.ReadConfigFileISC(AptCnf, Options["Apt-Conf"]) + + projectB = pg.connect(Cnf["DB::Name"], Cnf["DB::Host"], int(Cnf["DB::Port"])) if not suites: suites = Cnf.SubTree("Suite").List() @@ -150,7 +160,7 @@ def main (): print "Processing: " + suite SuiteBlock = Cnf.SubTree("Suite::" + suite) - if SuiteBlock.has_key("Untouchable"): + if SuiteBlock.has_key("Untouchable") and not Options["Force-Touch"]: print "Skipping: " + suite + " (untouchable)" continue @@ -158,9 +168,17 @@ def main (): origin = SuiteBlock["Origin"] label = SuiteBlock.get("Label", origin) - version = SuiteBlock.get("Version", "") codename = SuiteBlock.get("CodeName", "") + version = "" + description = "" + + q = projectB.query("SELECT version, description FROM suite WHERE suite_name = '%s'" % (suite)) + qs = q.getresult() + if len(qs) == 1: + if qs[0][0] != "-": version = qs[0][0] + if qs[0][1]: description = qs[0][1] + if SuiteBlock.has_key("NotAutomatic"): notautomatic = "yes" else: @@ -205,7 +223,8 @@ def main (): if components: out.write("Components: %s\n" % (" ".join(components))) - out.write("Description: %s\n" % (SuiteBlock["Description"])) + if description: + out.write("Description: %s\n" % (description)) files = [] @@ -237,6 +256,9 @@ def main (): relpath = Cnf["Dir::Root"]+tree+"/"+rel try: + if os.access(relpath, os.F_OK): + if os.stat(relpath).st_nlink > 1: + os.unlink(relpath) release = open(relpath, "w") #release = open(longsuite.replace("/","_") + "_" + arch + "_" + sec + "_Release", "w") except IOError: