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

- ls: add verbose option to print extra information for packages

- for ls, co, meta, editmeta, linkpac, copypac, rebuildpac, and wipebinaries
  (basically all the server-side commands), allow arguments "foo/bar" instead
  of "foo bar"
- add show_project_conf()
This commit is contained in:
Dr. Peter Poeml 2007-06-26 13:17:38 +00:00
parent b832d0f1c2
commit a7158af067
2 changed files with 113 additions and 21 deletions

View File

@ -85,29 +85,51 @@ class Osc(cmdln.Cmdln):
@cmdln.alias('ls')
#@cmdln.option('-l', '--long', action='store_true',
# help='print extra information')
@cmdln.option('-v', '--verbose', action='store_true',
help='print extra information')
def do_list(self, subcmd, opts, *args):
"""${cmd_name}: List existing content on the server
Examples:
ls # list all projects
ls Apache # list packages in a project
ls Apache subversion # list files of package of a project
ls Apache apache2 # list files of package of a project
ls -v Apache apache2 # verbosely list files of package of a project
With --verbose, the following fields will be shown for each item:
MD5 hash of file
Revision number of the last commit
Size (in bytes)
Date and time of the last commit
${cmd_usage}
${cmd_option_list}
"""
args = slash_split(args)
if not args:
print '\n'.join(meta_get_project_list(conf.config['apiurl']))
elif len(args) == 1:
project = args[0]
if opts.verbose:
sys.exit('The verbose option is not implemented for projects.')
print '\n'.join(meta_get_packagelist(conf.config['apiurl'], project))
elif len(args) == 2:
project = args[0]
package = args[1]
print '\n'.join(meta_get_filelist(conf.config['apiurl'], project, package))
l = meta_get_filelist(conf.config['apiurl'],
project,
package,
verbose=opts.verbose)
if opts.verbose:
for i in l:
print '%s %7d %9d %s %s' \
% (i.md5, i.rev, i.size, shorttime(i.mtime), i.name)
else:
print '\n'.join(l)
def do_meta(self, subcmd, opts, *args):
@ -168,16 +190,18 @@ class Osc(cmdln.Cmdln):
If the named project or package does not exist, it will be created.
Examples:
osc editmeta FooPrj # edit meta of project 'FooPrj'
osc editmeta FooPrj barpackage # edit meta of package 'barpackage'
osc editmeta Apache # edit meta of project 'Apache'
osc editmeta Apache apache2 # edit meta of package 'apache2'
${cmd_usage}
${cmd_option_list}
"""
args = slash_split(args)
if not args:
print >>sys.stderr, 'Missing argument.'
self.do_help(['foo', 'editmeta'])
self.do_help([None, 'editmeta'])
return 2
if len(args) == 2:
@ -227,9 +251,11 @@ class Osc(cmdln.Cmdln):
${cmd_option_list}
"""
args = slash_split(args)
if not args or len(args) < 3:
print >>sys.stderr, 'Incorrect number of argument.'
self.do_help(['foo', 'linkpac'])
self.do_help([None, 'linkpac'])
return 2
src_project = args[0]
@ -251,7 +277,8 @@ class Osc(cmdln.Cmdln):
def do_copypac(self, subcmd, opts, *args):
"""${cmd_name}: Copy a package
A client-side copy implementation. It can be cross-project.
A client-side copy implementation. It can be done cross-project, or even
across buildservice instances, if the -t option is used.
The DESTPAC name is optional; the source packages' name will be used if
DESTPAC is omitted.
@ -261,9 +288,11 @@ class Osc(cmdln.Cmdln):
${cmd_option_list}
"""
args = slash_split(args)
if not args or len(args) < 3:
print >>sys.stderr, 'Incorrect number of argument.'
self.do_help(['foo', 'copypac'])
self.do_help([None, 'copypac'])
return 2
src_project = args[0]
@ -410,14 +439,15 @@ class Osc(cmdln.Cmdln):
examples:
osc co Apache # entire project
osc co Apache subversion # a package
osc co Apache subversion foo # single file -> to current dir
osc co Apache apache2 # a package
osc co Apache apache2 foo # single file -> to current dir
usage:
osc co PROJECT [PACKAGE] [FILE]
${cmd_option_list}
"""
args = slash_split(args)
project = package = filename = None
try:
project = args[0]
@ -438,7 +468,7 @@ class Osc(cmdln.Cmdln):
checkout_package(conf.config['apiurl'], project, package)
else:
print >>sys.stderr, 'Missing argument.'
self.do_help(['foo', 'checkout'])
self.do_help([None, 'checkout'])
return 2
@ -526,7 +556,7 @@ class Osc(cmdln.Cmdln):
if not args:
print >>sys.stderr, 'Missing argument.'
self.do_help(['foo', 'add'])
self.do_help([None, 'add'])
return 2
filenames = parseargs(args)
@ -752,7 +782,7 @@ class Osc(cmdln.Cmdln):
if not args:
print >>sys.stderr, 'Missing argument.'
self.do_help(['foo', 'delete'])
self.do_help([None, 'delete'])
return 2
args = parseargs(args)
@ -792,7 +822,7 @@ class Osc(cmdln.Cmdln):
if not args:
print >>sys.stderr, 'Missing argument.'
self.do_help(['foo', 'resolved'])
self.do_help([None, 'resolved'])
return 2
args = parseargs(args)
@ -1187,9 +1217,11 @@ class Osc(cmdln.Cmdln):
${cmd_option_list}
"""
args = slash_split(args)
if len(args) < 1:
print >>sys.stderr, 'Missing argument.'
#self.do_help(['foo', 'rebuildpac'])
#self.do_help([None, 'rebuildpac'])
return 2
package = repo = arch = code = None
@ -1267,6 +1299,8 @@ class Osc(cmdln.Cmdln):
${cmd_option_list}
"""
args = slash_split(args)
if len(args) < 1:
print >>sys.stderr, 'Missing <project> argument'
return 2

View File

@ -542,6 +542,18 @@ rev: %s
os.unlink(filename)
def shorttime(t):
"""format time as Apr 02 18:19
or Apr 02 2005
depending on whether it is in the current year
"""
import time
if time.localtime()[0] == time.localtime(t)[0]:
# same year
return time.strftime('%b %d %H:%M',time.localtime(t))
else:
return time.strftime('%b %d %Y',time.localtime(t))
def is_project_dir(d):
@ -554,6 +566,16 @@ def is_package_dir(d):
os.path.exists(os.path.join(d, store, '_package'))
def slash_split(l):
"""Split command line arguments like 'foo/bar' into 'foo' 'bar'.
This is handy to allow copy/paste a project/package combination in this form.
"""
r = []
for i in l:
r += i.split('/')
return r
def findpacs(files):
pacs = []
for f in files:
@ -766,13 +788,29 @@ def meta_get_packagelist(apiurl, prj):
return [ node.get('name') for node in root.findall('entry') ]
def meta_get_filelist(apiurl, prj, package):
def meta_get_filelist(apiurl, prj, package, verbose=False):
"""return a list of file names,
or a list File() instances if verbose=True"""
u = makeurl(apiurl, ['source', prj, package])
f = http_GET(u)
root = ET.parse(f).getroot()
if not verbose:
return [ node.get('name') for node in root ]
else:
l = []
rev = int(root.get('rev'))
for node in root:
f = File(node.get('name'),
node.get('md5'),
int(node.get('size')),
int(node.get('mtime')))
f.rev = rev
l.append(f)
return l
def meta_get_project_list(apiurl):
u = makeurl(apiurl, ['source'])
@ -787,6 +825,12 @@ def show_project_meta(apiurl, prj):
return f.readlines()
def show_project_conf(apiurl, prj):
url = makeurl(apiurl, ['source', prj, '_config'])
f = http_GET(url)
return f.readlines()
def show_package_meta(apiurl, prj, pac):
try:
url = makeurl(apiurl, ['source', prj, pac, '_meta'])
@ -871,6 +915,20 @@ class metafile:
print >> sys.stderr, 'cannot save meta data - an unexpected error occured'
return False
#metatypes = { 'prj': { 'url': ['source', prj, '_meta'],
# 'template': new_project_templ,
# },
# 'pkg': { 'url' : ['source', prj, pac, '_meta'],
# 'template': new_package_templ,
# },
# 'prjconf': { 'url': ['source', prj, '_config'],
# 'template': None,
# },
# 'user': { 'url': ['person', quote_plus(user)],
# 'template': new_user_template,
# },
# }
def edit_meta(prj, pac, template=new_package_templ, change_is_required=True):
f=metafile(prj, pac, template, change_is_required)
@ -887,6 +945,7 @@ def edit_meta(prj, pac, template=new_package_templ, change_is_required=True):
else:
break
def edit_user_meta(user, change_is_required=True):
import tempfile
@ -1101,7 +1160,6 @@ def link_pac(src_project, src_package, dst_project, dst_package):
tree.write(buf)
src_meta = buf.getvalue()
edit_meta(dst_project, dst_package, template=src_meta, change_is_required=False)
# create the _link file