qubes/tools: add --verbose and --quiet to tools

This commit is contained in:
Wojtek Porczyk 2015-07-01 17:32:24 +02:00
parent ea9a984fa7
commit f536935632
4 changed files with 31 additions and 0 deletions

View File

@ -29,6 +29,8 @@ import argparse
import importlib import importlib
import os import os
import qubes.log
class PropertyAction(argparse.Action): class PropertyAction(argparse.Action):
'''Action for argument parser that stores a property.''' '''Action for argument parser that stores a property.'''
@ -98,11 +100,21 @@ def get_parser_base(want_force_root=False, **kwargs):
action='store', action='store',
help='Qubes OS store file') help='Qubes OS store file')
parser.add_argument('--verbose', '-v',
action='count',
help='increase verbosity')
parser.add_argument('--quiet', '-q',
action='count',
help='decrease verbosity')
if want_force_root: if want_force_root:
parser.add_argument('--force-root', parser.add_argument('--force-root',
action='store_true', default=False, action='store_true', default=False,
help='Force to run as root.') help='Force to run as root.')
parser.set_defaults(verbose=1, quiet=0)
return parser return parser
@ -145,3 +157,19 @@ def dont_run_as_root(parser, args):
if euid == 0 and not args.force_root: if euid == 0 and not args.force_root:
parser.error('refusing to run as root; add --force-root to override') parser.error('refusing to run as root; add --force-root to override')
def set_verbosity(parser, args):
'''Apply a verbosity setting.
This is done by configuring global logging.
:param argparse.ArgumentParser parser: command parser
:param argparse.Namespace args: args as parsed by parser
'''
verbose = args.verbose - args.quiet
if verbose >= 2:
qubes.log.enable_debug()
elif verbose >= 1:
qubes.log.enable()

View File

@ -40,6 +40,7 @@ def main(args=None):
''' '''
args = parser.parse_args(args) args = parser.parse_args(args)
qubes.tools.set_verbosity(parser, args)
app = qubes.Qubes.create_empty_store(args.xml) app = qubes.Qubes.create_empty_store(args.xml)
return True return True

View File

@ -72,6 +72,7 @@ parser.add_argument('name', metavar='VMNAME',
def main(): def main():
args = parser.parse_args() args = parser.parse_args()
qubes.tools.set_verbosity(parser, args)
qubes.tools.dont_run_as_root(parser, args) qubes.tools.dont_run_as_root(parser, args)
if 'label' not in args.properties: if 'label' not in args.properties:

View File

@ -607,6 +607,7 @@ def main(args=None):
parser = get_parser() parser = get_parser()
args = parser.parse_args(args) args = parser.parse_args(args)
qubes.tools.set_verbosity(parser, args)
app = qubes.Qubes(args.xml) app = qubes.Qubes(args.xml)
if args.fields: if args.fields: