1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-23 05:26:16 +01:00

- support link or branch from not-yet-existing-packages to pre-define the later submit target

This commit is contained in:
Adrian Schröter 2011-12-15 15:12:13 +01:00
parent 2950d89be4
commit 2e2deb3ec8
3 changed files with 25 additions and 13 deletions

1
NEWS
View File

@ -12,6 +12,7 @@
- support updateing _patchinfo file with new issues just by calling "osc patchinfo" again - support updateing _patchinfo file with new issues just by calling "osc patchinfo" again
- branch --add-repositories can be used to add repos from source project to target project - branch --add-repositories can be used to add repos from source project to target project
- branch --extend-package-names can be used to do mbranch like branch of a single package - branch --extend-package-names can be used to do mbranch like branch of a single package
- branch --new-package can be used to do branch from a not yet existing package (to define later submit target)
0.132 0.132
- rdelete and undelete command requesting now a comment - rdelete and undelete command requesting now a comment

View File

@ -2289,6 +2289,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
help='overwrite an existing link file if it is there.') help='overwrite an existing link file if it is there.')
@cmdln.option('-d', '--disable-publish', action='store_true', @cmdln.option('-d', '--disable-publish', action='store_true',
help='disable publishing of the linked package') help='disable publishing of the linked package')
@cmdln.option('-N', '--new-package', action='store_true',
help='create a link to a not yet existing package')
def do_linkpac(self, subcmd, opts, *args): def do_linkpac(self, subcmd, opts, *args):
"""${cmd_name}: "Link" a package to another package """${cmd_name}: "Link" a package to another package
@ -2339,14 +2341,14 @@ Please submit there instead, or use --nodevelproject to force direct submission.
# files from the same source # files from the same source
opts.cicount = "copy" opts.cicount = "copy"
if opts.current: if opts.current and not opts.new_package:
rev = show_upstream_rev(apiurl, src_project, src_package) rev = show_upstream_rev(apiurl, src_project, src_package)
if rev and not checkRevision(src_project, src_package, rev): if rev and not checkRevision(src_project, src_package, rev):
print >>sys.stderr, 'Revision \'%s\' does not exist' % rev print >>sys.stderr, 'Revision \'%s\' does not exist' % rev
sys.exit(1) sys.exit(1)
link_pac(src_project, src_package, dst_project, dst_package, opts.force, rev, opts.cicount, opts.disable_publish) link_pac(src_project, src_package, dst_project, dst_package, opts.force, rev, opts.cicount, opts.disable_publish, opts.new_package)
@cmdln.option('--nosources', action='store_true', @cmdln.option('--nosources', action='store_true',
help='ignore source packages when copying build results to destination project') help='ignore source packages when copying build results to destination project')
@ -2739,6 +2741,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
help='Create a hidden project') help='Create a hidden project')
@cmdln.option('-m', '--message', metavar='TEXT', @cmdln.option('-m', '--message', metavar='TEXT',
help='specify message TEXT') help='specify message TEXT')
@cmdln.option('-N', '--new-package', action='store_true',
help='create a branch pointing to a not yet existing package')
@cmdln.option('-r', '--revision', metavar='rev', @cmdln.option('-r', '--revision', metavar='rev',
help='branch against a specific revision') help='branch against a specific revision')
def do_branch(self, subcmd, opts, *args): def do_branch(self, subcmd, opts, *args):
@ -2800,7 +2804,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
return_existing=opts.checkout, msg=opts.message or '', return_existing=opts.checkout, msg=opts.message or '',
force=opts.force, noaccess=opts.noaccess, force=opts.force, noaccess=opts.noaccess,
add_repositories=opts.add_repositories, add_repositories=opts.add_repositories,
extend_package_names=opts.extend_package_names) extend_package_names=opts.extend_package_names, missingok=opts.new_package)
if exists: if exists:
print >>sys.stderr, 'Using existing branch project: %s' % targetprj print >>sys.stderr, 'Using existing branch project: %s' % targetprj

View File

@ -4131,7 +4131,7 @@ def link_to_branch(apiurl, project, package):
else: else:
raise oscerr.OscIOError(None, 'no _link file inside project \'%s\' package \'%s\'' % (project, package)) raise oscerr.OscIOError(None, 'no _link file inside project \'%s\' package \'%s\'' % (project, package))
def link_pac(src_project, src_package, dst_project, dst_package, force, rev='', cicount='', disable_publish = False): def link_pac(src_project, src_package, dst_project, dst_package, force, rev='', cicount='', disable_publish = False, missing_target = False):
""" """
create a linked package create a linked package
- "src" is the original package - "src" is the original package
@ -4153,6 +4153,9 @@ def link_pac(src_project, src_package, dst_project, dst_package, force, rev='',
meta_change = True meta_change = True
if meta_change: if meta_change:
if missing_target:
dst_meta = '<package name="%s"><title/><description/></package>' % dst_package
else:
src_meta = show_package_meta(apiurl, src_project, src_package) src_meta = show_package_meta(apiurl, src_project, src_package)
dst_meta = replace_pkg_meta(src_meta, dst_package, dst_project) dst_meta = replace_pkg_meta(src_meta, dst_package, dst_project)
@ -4180,15 +4183,17 @@ def link_pac(src_project, src_package, dst_project, dst_package, force, rev='',
print >>sys.stderr, '_link file already exists...! Aborting' print >>sys.stderr, '_link file already exists...! Aborting'
sys.exit(1) sys.exit(1)
rev = ''
if rev: if rev:
rev = 'rev="%s"' % rev rev = 'rev="%s"' % rev
else:
rev = ''
missingok = ''
if missing_target:
missingok = 'missingok="true"'
cicount = ''
if cicount: if cicount:
cicount = 'cicount="%s"' % cicount cicount = 'cicount="%s"' % cicount
else:
cicount = ''
print 'Creating _link...', print 'Creating _link...',
@ -4197,7 +4202,7 @@ def link_pac(src_project, src_package, dst_project, dst_package, force, rev='',
project = 'project="%s"' % src_project project = 'project="%s"' % src_project
link_template = """\ link_template = """\
<link %s package="%s" %s %s> <link %s package="%s" %s %s %s>
<patches> <patches>
<!-- <apply name="patch" /> apply a patch on the source directory --> <!-- <apply name="patch" /> apply a patch on the source directory -->
<!-- <topadd>%%define build_with_feature_x 1</topadd> add a line on the top (spec file only) --> <!-- <topadd>%%define build_with_feature_x 1</topadd> add a line on the top (spec file only) -->
@ -4205,7 +4210,7 @@ def link_pac(src_project, src_package, dst_project, dst_package, force, rev='',
<!-- <delete>filename</delete> delete a file --> <!-- <delete>filename</delete> delete a file -->
</patches> </patches>
</link> </link>
""" % (project, src_package, rev, cicount) """ % (project, src_package, missingok, rev, cicount)
u = makeurl(apiurl, ['source', dst_project, dst_package, '_link']) u = makeurl(apiurl, ['source', dst_project, dst_package, '_link'])
http_PUT(u, data=link_template) http_PUT(u, data=link_template)
@ -4323,7 +4328,7 @@ def attribute_branch_pkg(apiurl, attribute, maintained_update_project_attribute,
return r return r
def branch_pkg(apiurl, src_project, src_package, nodevelproject=False, rev=None, target_project=None, target_package=None, return_existing=False, msg='', force=False, noaccess=False, add_repositories=False, extend_package_names=False): def branch_pkg(apiurl, src_project, src_package, nodevelproject=False, rev=None, target_project=None, target_package=None, return_existing=False, msg='', force=False, noaccess=False, add_repositories=False, extend_package_names=False, missingok=False):
""" """
Branch a package (via API call) Branch a package (via API call)
""" """
@ -4336,6 +4341,8 @@ def branch_pkg(apiurl, src_project, src_package, nodevelproject=False, rev=None,
query['noaccess'] = '1' query['noaccess'] = '1'
if add_repositories: if add_repositories:
query['add_repositories'] = "1" query['add_repositories'] = "1"
if missingok:
query['missingok'] = "1"
if extend_package_names: if extend_package_names:
query['extend_package_names'] = "1" query['extend_package_names'] = "1"
if rev: if rev: