X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Ftools%2Fvppapigen%2Fvppapigen.py;fp=src%2Ftools%2Fvppapigen%2Fvppapigen.py;h=b828706f814b499b7518d70ed5ec4c18bff730ef;hb=9046e44c8493354d51237a92706a830a9db1872e;hp=5219bfd9ece3b29ef23841fb4df689978dec2647;hpb=79b3f8ce33849fd789c8fc31b219373749ad9678;p=vpp.git diff --git a/src/tools/vppapigen/vppapigen.py b/src/tools/vppapigen/vppapigen.py index 5219bfd9ece..b828706f814 100755 --- a/src/tools/vppapigen/vppapigen.py +++ b/src/tools/vppapigen/vppapigen.py @@ -1401,43 +1401,6 @@ def main(): else: logging.basicConfig() - parser = VPPAPI(debug=args.debug, filename=filename, logger=log, - revision=args.git_revision) - - try: - if not args.input: - parsed_objects = parser.parse_fd(sys.stdin, log) - else: - parsed_objects = parser.parse_filename(args.input, log) - except ParseError as e: - print('Parse error: ', e, file=sys.stderr) - sys.exit(1) - - # Build a list of objects. Hash of lists. - result = [] - - if args.output_module == 'C': - s = parser.process(parsed_objects) - else: - result = parser.process_imports(parsed_objects, False, result) - s = parser.process(result) - - # Add msg_id field - s['Define'] = add_msg_id(s['Define']) - - # Fold up CRCs - foldup_crcs(s['Define']) - - # - # Debug - if args.debug: - import pprint - pp = pprint.PrettyPrinter(indent=4, stream=sys.stderr) - for t in s['Define']: - pp.pprint([t.name, t.flags, t.block]) - for t in s['types']: - pp.pprint([t.name, t.block]) - # # Generate representation # @@ -1472,6 +1435,49 @@ def main(): .format(module_path, err)) return 1 + parser = VPPAPI(debug=args.debug, filename=filename, logger=log, + revision=args.git_revision) + + try: + if not args.input: + parsed_objects = parser.parse_fd(sys.stdin, log) + else: + parsed_objects = parser.parse_filename(args.input, log) + except ParseError as e: + print('Parse error: ', e, file=sys.stderr) + sys.exit(1) + + # Build a list of objects. Hash of lists. + result = [] + + # if the variable is not set in the plugin, assume it to be false. + try: + plugin.process_imports + except AttributeError: + plugin.process_imports = False + + if plugin.process_imports: + result = parser.process_imports(parsed_objects, False, result) + s = parser.process(result) + else: + s = parser.process(parsed_objects) + + # Add msg_id field + s['Define'] = add_msg_id(s['Define']) + + # Fold up CRCs + foldup_crcs(s['Define']) + + # + # Debug + if args.debug: + import pprint + pp = pprint.PrettyPrinter(indent=4, stream=sys.stderr) + for t in s['Define']: + pp.pprint([t.name, t.flags, t.block]) + for t in s['types']: + pp.pprint([t.name, t.block]) + result = plugin.run(args, filename, s) if result: print(result, file=args.output)