This repo contains code to mirror other repos. It also contains the code that is getting mirrored.
No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.
 
 

39 líneas
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()