a thrift parser (antlr4)
Project description
thrift-parser
pip install thrift-parser
Thrift.g4
is from https://github.com/antlr/grammars-v4
parse
from thrift_parser import parse_file
lexer, tokens, parser, document = parse_file('tutorial.thrift')
or smiple
from thrift_parser import ThriftData
thrift_data = ThriftData.from_file('tutorial.thrift')
print(thrift_data.tokens[0].text)
print(thrift_data.document.children)
or you can try antlr's way
from antlr4 import FileStream
from antlr4 import CommonTokenStream
from antlr4 import ParserRuleContext
from thrift_parser.ThriftLexer import ThriftLexer
from thrift_parser.ThriftParser import ThriftParser
def main(file):
input_stream = FileStream(file, encoding='utf8')
lexer = ThriftLexer(input_stream)
stream = CommonTokenStream(lexer)
parser = ThriftParser(stream)
ctx = ParserRuleContext()
parser.enterRule(ctx, 0, 0)
document = parser.document()
return document
Why ?
python thrift parser --> thrift-fmt --> auto format my thrift files in one style
TODO
- more ast operate, fake_token, fake_context
- other language?
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
thrift-parser-1.0.6.tar.gz
(27.3 kB
view hashes)
Built Distribution
Close
Hashes for thrift_parser-1.0.6-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 980c3e699f726cf1592a54e5a0fa942bd05f067fc9a2ad70afcf48ff9330be2e |
|
MD5 | a81cda83bdb8bfbc8c1dfb3ee295372a |
|
BLAKE2b-256 | faa617d7f6cefecdcbb6e5a8de7f7534aaf57b1a737bc0230cabb20894e7cd52 |