Caustic's parsing framework
Project description
Caustic's Parser -- uses grammar specification to compile Caustic source code into a CST (Caustic AST)
Uses ParGlare for parsing, meant to work with CausticGrammar to create a CST (Caustic AST)
CLI usage
See cap --help
Example module usage
import sys
import parglare
from pathlib import Path
from caustic.parser import CausticParser
from caustic.parser.error import format_exc
# CausticParser.from_file() loads the grammar using ParGlare,
# then invokes CausticParser.from_grammar(), which creates a ParGlare
# parser instance and uses that to finally create the parser
p = CausticParser.from_file(Path('<your-grammar-file>'))
try:
print(p.parse(input()))
except parglare.ParseError as e:
# custom error formatting (optional)
print(format_exc(e), file=sys.stderr)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
caustic.parser-2.1.1.tar.gz
(9.3 kB
view hashes)
Built Distribution
Close
Hashes for caustic.parser-2.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7b7c49d76036272ade5514c29fe986bf3bb60c3331d79f42b18cca64bfe9ed0 |
|
MD5 | eef47e2df57edfa3aede951b6c0f5f10 |
|
BLAKE2b-256 | 6c6303e667cd3d6bcde5cb456dc94add9a8a7400687761622be39884a97a3bbe |