This repo contains code to mirror other repos. It also contains the code that is getting mirrored.
Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

39 rindas
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()