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-0.0.3.tar.gz
(29.1 kB
view hashes)
Built Distribution
Close
Hashes for thrift_parser-0.0.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 73347ae0c909a8e6e62e8b7e61cd98c92b8984c88100d71d5b72baef1dcde9ff |
|
MD5 | 834392fef83012fca08bf2c8a6606205 |
|
BLAKE2b-256 | 54275d12a71dfcaf893db5c37538fccc86452bb9a043a592b962b26210a824c0 |