mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-26 22:56:15 +01:00
osc/core: parseRevisionOption(): cleanup and make logic consistent.
Handle multiple revisions the same as a single revision in terms of what is allowed (digit, or 32 character string [md5]). Additionally, support either blank or "latest" to mean latest revision (None). This allows for new revision to be specified without old revision like the following example: osc rdiff ... -r :17
This commit is contained in:
parent
dbed74a13f
commit
6a3976dc22
@ -6841,7 +6841,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
project = args[0]
|
project = args[0]
|
||||||
package = args[1]
|
package = args[1]
|
||||||
|
|
||||||
rev, rev_upper = parseRevisionOption(opts.revision)
|
rev, rev_upper = parseRevisionOption(opts.revision, allow_md5=False)
|
||||||
if rev and not checkRevision(project, package, rev, apiurl, opts.meta):
|
if rev and not checkRevision(project, package, rev, apiurl, opts.meta):
|
||||||
print('Revision \'%s\' does not exist' % rev, file=sys.stderr)
|
print('Revision \'%s\' does not exist' % rev, file=sys.stderr)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
28
osc/core.py
28
osc/core.py
@ -6603,32 +6603,22 @@ def cmdbuild(apiurl, cmd, project, package=None, arch=None, repo=None, code=None
|
|||||||
return root.get('code')
|
return root.get('code')
|
||||||
|
|
||||||
|
|
||||||
def parseRevisionOption(string):
|
def parseRevisionOption(string, allow_md5=True):
|
||||||
"""
|
"""
|
||||||
returns a tuple which contains the revisions
|
returns a tuple which contains the revisions
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
revisions = [None, None]
|
||||||
if string:
|
if string:
|
||||||
if ':' in string:
|
parts = string.split(':')
|
||||||
splitted_rev = string.split(':')
|
for i, revision in enumerate(parts[0:2], 0):
|
||||||
try:
|
if revision.isdigit() or (allow_md5 and revision.isalnum() and len(revision) == 32):
|
||||||
for i in splitted_rev:
|
revisions[i] = revision
|
||||||
int(i)
|
elif revision != '' and revision != 'latest':
|
||||||
return splitted_rev
|
|
||||||
except ValueError:
|
|
||||||
print('your revision \'%s\' will be ignored' % string, file=sys.stderr)
|
print('your revision \'%s\' will be ignored' % string, file=sys.stderr)
|
||||||
return None, None
|
return None, None
|
||||||
else:
|
|
||||||
if string.isdigit():
|
return tuple(revisions)
|
||||||
return string, None
|
|
||||||
elif string.isalnum() and len(string) == 32:
|
|
||||||
# could be an md5sum
|
|
||||||
return string, None
|
|
||||||
else:
|
|
||||||
print('your revision \'%s\' will be ignored' % string, file=sys.stderr)
|
|
||||||
return None, None
|
|
||||||
else:
|
|
||||||
return None, None
|
|
||||||
|
|
||||||
def checkRevision(prj, pac, revision, apiurl=None, meta=False):
|
def checkRevision(prj, pac, revision, apiurl=None, meta=False):
|
||||||
"""
|
"""
|
||||||
|
Loading…
Reference in New Issue
Block a user