-
Notifications
You must be signed in to change notification settings - Fork 132
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Raise an exception from the grammar? #222
Comments
I never got around to adding fine-grained error reporting to Parsimonious, but the design in my head involved annotated PEG-style cuts. Semantically, they might have been similar to what you suggest here, if I guess the behavior right. In the meantime, you could define a visitor method called visit_RAISE_ERROR (in this case) and raise an exception from there. |
I don't think that would work since you'd end up with failed parsing where it doesn't consume all the input. E.g. you could define from parsimonious import *
g = Grammar(r"""
parenthesized = "(" addition_expr ")"
addition_expr = (number "+" number) / RAISE_ERROR
number = ~"\d+"
RAISE_ERROR = ~".+"m
""")
g.parse("(...)") # parsimonious.exceptions.ParseError: Rule 'number' didn't match at '...)' (line 1, column 2). There the It's a bit clunky, but one option would be to define your own custom expression type that just raises an error: from parsimonious.expressions import Expression
class RAISE_ERROR(Expression):
def _uncached_match(self, text, pos, cache, error):
raise Exception(f"You messed up at {pos}, 🤦♂️.")
g = Grammar(r"""
parenthesized = "(" addition_expr ")"
addition_expr = (number "+" number) / RAISE_ERROR
number = ~"\d+"
""", RAISE_ERROR=RAISE_ERROR())
g.parse("(...)") # Exception: You messed up at 1, 🤦♂️. |
Good point. So yes, I think your workaround is the best bet for the moment. |
Hi all
Is there an ability to raise an exception straight from the grammar?
If not, what is the best sort of way to accomplish the same behaviour? I'm coming from PEGTL.
The text was updated successfully, but these errors were encountered: