This repo contains code to mirror other repos. It also contains the code that is getting mirrored.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

39 lines
1.5 KiB

  1. import codecs
  2. import sys
  3. import json
  4. from lark import Lark
  5. from lark.grammar import RuleOptions, Rule
  6. from lark.lexer import TerminalDef
  7. import argparse
  8. argparser = argparse.ArgumentParser(prog='python -m lark.tools.serialize') #description='''Lark Serialization Tool -- Stores Lark's internal state & LALR analysis as a convenient JSON file''')
  9. argparser.add_argument('grammar_file', type=argparse.FileType('r'), help='A valid .lark file')
  10. argparser.add_argument('-o', '--out', type=argparse.FileType('w'), default=sys.stdout, help='json file path to create (default=stdout)')
  11. argparser.add_argument('-s', '--start', default='start', help='start symbol (default="start")', nargs='+')
  12. argparser.add_argument('-l', '--lexer', default='standard', choices=['standard', 'contextual'], help='lexer type (default="standard")')
  13. def serialize(infile, outfile, lexer, start):
  14. lark_inst = Lark(infile, parser="lalr", lexer=lexer, start=start) # TODO contextual
  15. data, memo = lark_inst.memo_serialize([TerminalDef, Rule])
  16. outfile.write('{\n')
  17. outfile.write(' "data": %s,\n' % json.dumps(data))
  18. outfile.write(' "memo": %s\n' % json.dumps(memo))
  19. outfile.write('}\n')
  20. def main():
  21. if len(sys.argv) == 1 or '-h' in sys.argv or '--help' in sys.argv:
  22. print("Lark Serialization Tool - Stores Lark's internal state & LALR analysis as a JSON file")
  23. print("")
  24. argparser.print_help()
  25. else:
  26. args = argparser.parse_args()
  27. serialize(args.grammar_file, args.out, args.lexer, args.start)
  28. if __name__ == '__main__':
  29. main()