mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-27 15:06:15 +01:00
osc ls -u -- same logic here as mls suggests for osc cat.
This commit is contained in:
parent
b4364bceff
commit
38c0621a90
2
NEWS
2
NEWS
@ -1,5 +1,5 @@
|
||||
- suggest git, svn, ... if indicated, after oscerr.NoWorkingCopy
|
||||
- "osc cat" now auto-expands through link.
|
||||
- "osc cat" & "osc ls" now auto-expands through link.
|
||||
- fixed "osc add" after "osc delete".
|
||||
|
||||
0.126
|
||||
|
@ -199,6 +199,8 @@ class Osc(cmdln.Cmdln):
|
||||
help='specify revision (only for sources)')
|
||||
@cmdln.option('-e', '--expand', action='store_true',
|
||||
help='expand linked package (only for sources)')
|
||||
@cmdln.option('-u', '--unexpand', action='store_true',
|
||||
help='always work with unexpanded (source) packages')
|
||||
@cmdln.option('-v', '--verbose', action='store_true',
|
||||
help='print extra information')
|
||||
@cmdln.option('-l', '--long', action='store_true', dest='verbose',
|
||||
@ -338,6 +340,9 @@ class Osc(cmdln.Cmdln):
|
||||
print '\n'.join(meta_get_packagelist(conf.config['apiurl'], project))
|
||||
|
||||
elif len(args) == 2 or len(args) == 3:
|
||||
link_seen = False
|
||||
print_not_found = True
|
||||
for i in [ 1, 2 ]:
|
||||
l = meta_get_filelist(conf.config['apiurl'],
|
||||
project,
|
||||
package,
|
||||
@ -345,21 +350,30 @@ class Osc(cmdln.Cmdln):
|
||||
expand=opts.expand,
|
||||
revision=opts.revision)
|
||||
if opts.verbose:
|
||||
for i in l:
|
||||
if i.name == '_link':
|
||||
link_seen = True
|
||||
out = [ '%s %7s %9d %s %s' % (i.md5, i.rev, i.size, shorttime(i.mtime), i.name) \
|
||||
for i in l if not fname or fname == i.name ]
|
||||
if len(out) == 0:
|
||||
if fname:
|
||||
print 'file \'%s\' does not exist' % fname
|
||||
else:
|
||||
if len(out) > 0:
|
||||
print_not_found = False
|
||||
print '\n'.join(out)
|
||||
else:
|
||||
if '_link' in l:
|
||||
link_seen = True
|
||||
if fname:
|
||||
if fname in l:
|
||||
print fname
|
||||
else:
|
||||
print 'file \'%s\' does not exist' % fname
|
||||
print_not_found = False
|
||||
else:
|
||||
print '\n'.join(l)
|
||||
if opts.expand or opts.unexpand or link_seen == 0: break
|
||||
m = show_files_meta(conf.config['apiurl'], project, package)
|
||||
xml = ET.fromstring(''.join(m)).find('linkinfo')
|
||||
print "# -> %s %s" % (xml.get('project'), xml.get('package'))
|
||||
opts.expand = True
|
||||
if fname and print_not_found:
|
||||
print 'file \'%s\' does not exist' % fname
|
||||
|
||||
|
||||
@cmdln.option('-f', '--force', action='store_true',
|
||||
|
Loading…
Reference in New Issue
Block a user