qubes-lvm: do not import 'qubes' module
This script should run as fast as possible, so avoid importing large module. In fact the only used thing was argparse wrapper, so switch to the standard one and drop aliases. QubesOS/qubes-issues#2256
This commit is contained in:
parent
de5d420331
commit
6bdc82b3a6
@ -22,14 +22,13 @@
|
|||||||
|
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import argparse
|
||||||
import logging
|
import logging
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
import lvm # pylint: disable=import-error
|
import lvm # pylint: disable=import-error
|
||||||
|
|
||||||
import qubes
|
|
||||||
|
|
||||||
log = logging.getLogger('qubes.storage.lvm')
|
log = logging.getLogger('qubes.storage.lvm')
|
||||||
|
|
||||||
|
|
||||||
@ -131,7 +130,7 @@ def rename_volume(old_name, new_name):
|
|||||||
def init_pool_parser(sub_parsers):
|
def init_pool_parser(sub_parsers):
|
||||||
''' Initialize pool subparser '''
|
''' Initialize pool subparser '''
|
||||||
pool_parser = sub_parsers.add_parser(
|
pool_parser = sub_parsers.add_parser(
|
||||||
'pool', aliases=('p', 'pl'),
|
'pool',
|
||||||
help="Exit with exit code 0 if pool exists")
|
help="Exit with exit code 0 if pool exists")
|
||||||
pool_parser.add_argument('pool_id', metavar='VG/POOL',
|
pool_parser.add_argument('pool_id', metavar='VG/POOL',
|
||||||
help="volume_group/pool_name")
|
help="volume_group/pool_name")
|
||||||
@ -141,7 +140,7 @@ def init_pool_parser(sub_parsers):
|
|||||||
def init_new_parser(sub_parsers):
|
def init_new_parser(sub_parsers):
|
||||||
''' Initialize the 'new' subparser '''
|
''' Initialize the 'new' subparser '''
|
||||||
new_parser = sub_parsers.add_parser(
|
new_parser = sub_parsers.add_parser(
|
||||||
'new', aliases=('n', 'create'),
|
'create',
|
||||||
help='Creates a new thin ThinPoolLogicalVolume')
|
help='Creates a new thin ThinPoolLogicalVolume')
|
||||||
new_parser.add_argument('pool_id', metavar='VG/POOL',
|
new_parser.add_argument('pool_id', metavar='VG/POOL',
|
||||||
help="volume_group/pool_name")
|
help="volume_group/pool_name")
|
||||||
@ -157,7 +156,7 @@ def init_new_parser(sub_parsers):
|
|||||||
def init_import_parser(sub_parsers):
|
def init_import_parser(sub_parsers):
|
||||||
''' Initialize import subparser '''
|
''' Initialize import subparser '''
|
||||||
import_parser = sub_parsers.add_parser(
|
import_parser = sub_parsers.add_parser(
|
||||||
'import', aliases=('imp', 'i'),
|
'import',
|
||||||
help='sparse copy data from stdin to a thin volume')
|
help='sparse copy data from stdin to a thin volume')
|
||||||
import_parser.add_argument('name', metavar='VG/VID',
|
import_parser.add_argument('name', metavar='VG/VID',
|
||||||
help='volume_group/volume_name')
|
help='volume_group/volume_name')
|
||||||
@ -166,7 +165,7 @@ def init_import_parser(sub_parsers):
|
|||||||
def init_clone_parser(sub_parsers):
|
def init_clone_parser(sub_parsers):
|
||||||
''' Initialize clone subparser '''
|
''' Initialize clone subparser '''
|
||||||
clone_parser = sub_parsers.add_parser(
|
clone_parser = sub_parsers.add_parser(
|
||||||
'clone', aliases=('cln', 'c'),
|
'clone',
|
||||||
help='sparse copy data from stdin to a thin volume')
|
help='sparse copy data from stdin to a thin volume')
|
||||||
clone_parser.add_argument('source', metavar='VG/VID',
|
clone_parser.add_argument('source', metavar='VG/VID',
|
||||||
help='volume_group/volume_name')
|
help='volume_group/volume_name')
|
||||||
@ -204,7 +203,7 @@ def list_volumes(args):
|
|||||||
|
|
||||||
def init_volumes_parser(sub_parsers):
|
def init_volumes_parser(sub_parsers):
|
||||||
''' Initialize volumes subparser '''
|
''' Initialize volumes subparser '''
|
||||||
parser = sub_parsers.add_parser('volumes', aliases=('v', 'vol'),
|
parser = sub_parsers.add_parser('volumes',
|
||||||
help='list volumes in a pool')
|
help='list volumes in a pool')
|
||||||
parser.add_argument('name', metavar='VG/THIN_POOL',
|
parser.add_argument('name', metavar='VG/THIN_POOL',
|
||||||
help='volume_group/thin_pool_name')
|
help='volume_group/thin_pool_name')
|
||||||
@ -213,7 +212,7 @@ def init_volumes_parser(sub_parsers):
|
|||||||
|
|
||||||
def init_remove_parser(sub_parsers):
|
def init_remove_parser(sub_parsers):
|
||||||
''' Initialize remove subparser '''
|
''' Initialize remove subparser '''
|
||||||
remove_parser = sub_parsers.add_parser('remove', aliases=('rm', 'r'),
|
remove_parser = sub_parsers.add_parser('remove',
|
||||||
help='Removes a LogicalVolume')
|
help='Removes a LogicalVolume')
|
||||||
remove_parser.add_argument('name', metavar='VG/VID',
|
remove_parser.add_argument('name', metavar='VG/VID',
|
||||||
help='volume_group/volume_name')
|
help='volume_group/volume_name')
|
||||||
@ -224,8 +223,9 @@ def get_parser():
|
|||||||
'''Create :py:class:`argparse.ArgumentParser` suitable for
|
'''Create :py:class:`argparse.ArgumentParser` suitable for
|
||||||
:program:`qubes-lvm`.
|
:program:`qubes-lvm`.
|
||||||
'''
|
'''
|
||||||
parser = qubes.tools.QubesArgumentParser(description=__doc__, want_app=True)
|
parser = argparse.ArgumentParser(description=__doc__)
|
||||||
parser.register('action', 'parsers', qubes.tools.AliasedSubParsersAction)
|
# pylint: disable=protected-access
|
||||||
|
parser.register('action', 'parsers', argparse._SubParsersAction)
|
||||||
sub_parsers = parser.add_subparsers(
|
sub_parsers = parser.add_subparsers(
|
||||||
title='commands',
|
title='commands',
|
||||||
description="For more information see qubes-lvm command -h",
|
description="For more information see qubes-lvm command -h",
|
||||||
|
Loading…
Reference in New Issue
Block a user