diff options
author | Olivier Blin <oblin@mandriva.com> | 2006-09-27 13:45:38 +0000 |
---|---|---|
committer | Olivier Blin <oblin@mandriva.com> | 2006-09-27 13:45:38 +0000 |
commit | 3c632697bd604933d3284acdc79eb3178ddd77ef (patch) | |
tree | bb4d29e4d63ce2e876fdf2244ca238edd3b05533 /create-srpm | |
parent | c9cddb1f54760c5c3aabfd1b637ca07fa89bc91a (diff) | |
download | mgarepo-3c632697bd604933d3284acdc79eb3178ddd77ef.tar mgarepo-3c632697bd604933d3284acdc79eb3178ddd77ef.tar.gz mgarepo-3c632697bd604933d3284acdc79eb3178ddd77ef.tar.bz2 mgarepo-3c632697bd604933d3284acdc79eb3178ddd77ef.tar.xz mgarepo-3c632697bd604933d3284acdc79eb3178ddd77ef.zip |
merge 1.6.2b changes
Diffstat (limited to 'create-srpm')
-rwxr-xr-x | create-srpm | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/create-srpm b/create-srpm index 000afd2..ee98ccd 100755 --- a/create-srpm +++ b/create-srpm @@ -3,7 +3,7 @@ from RepSys import Error, config from RepSys.rpmutil import get_srpm from RepSys.cgiutil import get_targets -from RepSys.util import mapurl +from RepSys.util import mapurl, execcmd, get_helper import sys import os import pwd @@ -16,7 +16,7 @@ class CmdIface: return config.get("users", author) def submit_package(self, packageurl, packagerev, targetname, - dontmapurl_=0): + dontmapurl_=0, define=[]): pw = pwd.getpwuid(os.getuid()) username = pw[0] packager = config.get("users", username) or pw[4] @@ -46,13 +46,26 @@ class CmdIface: newurl = packageurl if not dontmapurl_: newurl = mapurl(packageurl) - get_srpm(newurl, + targetsrpms = get_srpm(newurl, revision=packagerev, targetdirs=target.target, packager=packager, revname=1, svnlog=1, scripts=target.scripts) + + uploadsrpm = config.get("helper", "upload-srpm", None) + if uploadsrpm: + upload_command = [ uploadsrpm ] + if define: + for x in define: + upload_command.append("--define") + upload_command.append(x) + upload_command.append(targetname) + upload_command.append(targetsrpms[0]) + status, output = execcmd(" ".join(upload_command)) + if status != 0: + raise CmdError, "Failed to upload %s:\n%s" % (targetsrpms[0], output) return 1 def submit_targets(self): @@ -69,6 +82,7 @@ def parse_options(): parser.add_option("-M", "--nomapping", action="store_true", dest="urlmap", default=False, help="disable url mapping") + parser.add_option("--define", action="append") opts, args = parser.parse_args() if not args: parser.error("you must supply a package url") @@ -78,7 +92,7 @@ def parse_options(): def main(): iface = CmdIface() opts, args = parse_options() - iface.submit_package(args[0], opts.revision, opts.target, opts.urlmap) + iface.submit_package(args[0], opts.revision, opts.target, opts.urlmap, opts.define) if __name__ == "__main__": |