From 3b1d4defe35628f7e10054f2afc4fd371a77efe0 Mon Sep 17 00:00:00 2001 From: Markus Armbruster Date: Fri, 9 Mar 2018 08:49:25 -0500 Subject: [PATCH] qapi-gen: Convert from getopt to argparse argparse is nicer to use than getopt, and gives us --help almost for free. Backports commit 3b446a1817289d89844ad77c719bdc44bbcd1198 from qemu --- qemu/scripts/qapi-gen.py | 48 +++++++++++++++++++++++-------------- qemu/scripts/qapi/common.py | 43 --------------------------------- 2 files changed, 30 insertions(+), 61 deletions(-) diff --git a/qemu/scripts/qapi-gen.py b/qemu/scripts/qapi-gen.py index 24b4d8ff..51b04a07 100644 --- a/qemu/scripts/qapi-gen.py +++ b/qemu/scripts/qapi-gen.py @@ -4,8 +4,11 @@ # This work is licensed under the terms of the GNU GPL, version 2 or later. # See the COPYING file in the top-level directory. +from __future__ import print_function +import argparse +import re import sys -from qapi.common import parse_command_line, QAPISchema +from qapi.common import QAPISchema from qapi.types import gen_types from qapi.visit import gen_visit # Unicorn: commented out @@ -16,27 +19,36 @@ from qapi.visit import gen_visit def main(argv): - (input_file, output_dir, prefix, opts) = \ - parse_command_line('bu', ['builtins', 'unmask-non-abi-names']) + parser = argparse.ArgumentParser( + description='Generate code from a QAPI schema') + parser.add_argument('-b', '--builtins', action='store_true', + help="generate code for built-in types") + parser.add_argument('-o', '--output-dir', action='store', default='', + help="write output to directory OUTPUT_DIR") + parser.add_argument('-p', '--prefix', action='store', default='', + help="prefix for symbols") + parser.add_argument('-u', '--unmask-non-abi-names', action='store_true', + dest='unmask', + help="expose non-ABI names in introspection") + parser.add_argument('schema', action='store') + args = parser.parse_args() - opt_builtins = False - opt_unmask = False + match = re.match(r'([A-Za-z_.-][A-Za-z0-9_.-]*)?', args.prefix) + if match.end() != len(args.prefix): + print("%s: 'funny character '%s' in argument of --prefix" + % (sys.argv[0], args.prefix[match.end()]), + file=sys.stderr) + sys.exit(1) - for o, a in opts: - if o in ('-b', '--builtins'): - opt_builtins = True - if o in ('-u', '--unmask-non-abi-names'): - opt_unmask = True + schema = QAPISchema(args.schema) - schema = QAPISchema(input_file) - - gen_types(schema, output_dir, prefix, opt_builtins) - gen_visit(schema, output_dir, prefix, opt_builtins) + gen_types(schema, args.output_dir, args.prefix, args.builtins) + gen_visit(schema, args.output_dir, args.prefix, args.builtins) # Unicorn: commented out - #gen_commands(schema, output_dir, prefix) - #gen_events(schema, output_dir, prefix) - #gen_introspect(schema, output_dir, prefix, opt_unmask) - #gen_doc(schema, output_dir, prefix) + #gen_commands(schema, args.output_dir, args.prefix) + #gen_events(schema, args.output_dir, args.prefix) + #gen_introspect(schema, args.output_dir, args.prefix, args.unmask) + #gen_doc(schema, args.output_dir, args.prefix) if __name__ == '__main__': diff --git a/qemu/scripts/qapi/common.py b/qemu/scripts/qapi/common.py index a658f9d0..00746a9c 100644 --- a/qemu/scripts/qapi/common.py +++ b/qemu/scripts/qapi/common.py @@ -13,7 +13,6 @@ from __future__ import print_function import errno -import getopt import os import re import string @@ -1928,48 +1927,6 @@ def build_params(arg_type, boxed, extra): return ret -# -# Common command line parsing -# - - -def parse_command_line(extra_options='', extra_long_options=[]): - - try: - opts, args = getopt.gnu_getopt(sys.argv[1:], - 'p:o:' + extra_options, - ['prefix=', 'output-dir='] - + extra_long_options) - except getopt.GetoptError as err: - print("%s: %s" % (sys.argv[0], str(err)), file=sys.stderr) - sys.exit(1) - - output_dir = '' - prefix = '' - extra_opts = [] - - for oa in opts: - o, a = oa - if o in ('-p', '--prefix'): - match = re.match(r'([A-Za-z_.-][A-Za-z0-9_.-]*)?', a) - if match.end() != len(a): - print("%s: 'funny character '%s' in argument of --prefix" \ - % (sys.argv[0], a[match.end()]), file=sys.stderr) - sys.exit(1) - prefix = a - elif o in ('-o', '--output-dir'): - output_dir = a + '/' - else: - extra_opts.append(oa) - - if len(args) != 1: - print("%s: need exactly one argument" % sys.argv[0], file=sys.stderr) - sys.exit(1) - fname = args[0] - - return (fname, output_dir, prefix, extra_opts) - - # # Accumulate and write output #