File: gsi_util.py

package info (click to toggle)
android-platform-tools 29.0.6-28
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 365,224 kB
  • sloc: cpp: 1,049,638; java: 460,532; ansic: 375,452; asm: 301,257; xml: 134,509; python: 92,731; perl: 62,008; sh: 26,753; makefile: 3,210; javascript: 3,172; yacc: 1,403; lex: 455; awk: 368; ruby: 183; sql: 140
file content (75 lines) | stat: -rwxr-xr-x 2,269 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#!/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)
      if args.debug:
        logging.exception(e)
      sys.exit(1)


if __name__ == '__main__':
  tool = GsiUtil()
  tool.run(sys.argv)