From: Greg Price Date: Thu, 31 Jul 2008 01:12:34 +0000 (-0400) Subject: add --ls/-l to invirt-getconf X-Git-Tag: sipb-xen-base/8.12~9 X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-base.git/commitdiff_plain/ba4dab8a5295fda3f93676459a890b0d3332569a?ds=sidebyside add --ls/-l to invirt-getconf svn path=/trunk/packages/sipb-xen-base/; revision=787 --- diff --git a/files/usr/sbin/invirt-getconf b/files/usr/sbin/invirt-getconf index ce0dfa6..bac6596 100755 --- a/files/usr/sbin/invirt-getconf +++ b/files/usr/sbin/invirt-getconf @@ -35,6 +35,9 @@ def main(argv): parser.add_option('-r', '--refresh', action = 'store_true', help = 'force the cache to be regenerated') + parser.add_option('-l', '--ls', + action = 'store_true', + help = 'list node\'s children') opts, args = parser.parse_args() try: [key] = args @@ -57,7 +60,18 @@ def main(argv): '%s: key "%s" not found' % (progress, component)) except IndexError: raise invirt_exception( '%s: index %s out of range' % (progress, component)) - print conf + if opts.ls: + if type(conf) not in [dict, list]: + raise invirt_exception( + '%s: node has no children (atomic datum)' % progress) + if type(conf) == list: + for i in xrange(len(conf)): + print i + else: + for k in conf.iterkeys(): + print k + else: + print conf except invirt_exception, ex: print >> stderr, ex return 1