#!/usr/bin/env python # # Copyright 2017 - The Android Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. """gsi_util command-line utility.""" import argparse import logging import sys class GsiUtil(object): """Object for gsi_util command line tool.""" _GSI_UTIL_VERSION = '1.0' # Adds gsi_util COMMAND here. # TODO(bowgotsai): auto collect from gsi_util/commands/*.py _COMMANDS = ['flash_gsi', 'pull', 'dump', 'check_compat'] _LOGGING_FORMAT = '%(message)s' _LOGGING_LEVEL = logging.WARNING @staticmethod def _get_module_name(command): return 'gsi_util.commands.' + command def run(self, argv): """Command-line processor.""" # Sets up default logging. logging.basicConfig(format=self._LOGGING_FORMAT, level=self._LOGGING_LEVEL) # Adds top-level --version/--debug argument. parser = argparse.ArgumentParser() parser.add_argument('-v', '--version', action='version', version='%(prog)s {}'.format(self._GSI_UTIL_VERSION)) parser.add_argument( '-d', '--debug', help='debug mode.', action='store_true') # Adds subparsers for each COMMAND. subparsers = parser.add_subparsers(title='COMMAND') for command in self._COMMANDS: module_name = self._get_module_name(command) mod = __import__(module_name, globals(), locals(), ['setup_command_args']) mod.setup_command_args(subparsers) args = parser.parse_args(argv[1:]) if args.debug: logging.getLogger().setLevel(logging.DEBUG) try: args.func(args) except Exception as e: logging.error('%s: %s', argv[0], e.message) logging.exception(e) sys.exit(1) if __name__ == '__main__': tool = GsiUtil() tool.run(sys.argv)