-
Notifications
You must be signed in to change notification settings - Fork 19
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
Does not support ! pegjs operator #9
Comments
Yeah, that's a negative lookahead. I represent it as a branch with two slashes before it (as you can see on the diagram). The idea is to indicate it is there, but you cannot go through it so it is not part of the parsed result. Do you have a better way to represent it in mind? |
Hmm, I guess I slightly prefer the first arrangement, since it indicates that parser checks the lookahead first and then continues with the rest. But I like the idea of the cross symbol, I might try to use that since it is distinguishable from the start/end symbols. |
@Pyrolistical What do you think of this? |
I don't see the value of having the X in the front nor having it connect back to the beginning of Expression. Yes this is describing more closely to what the parser is doing, but this is a railroad diagram. I feel my version is more in the spirit of a railroad diagram. Every line you follow is a valid syntax, except we are adding a concept of an invalid path with the X |
Thanks for the suggestions @iology. I like the dashed variant in fig.1. However, it still feels a bit inconclusive for me to implement it. |
I like fig.4 the most, but I may need to modify the railroad-diagram package. (looking into it) fig.1 and fig.2 do not work quite nice when there is no branching and when there are nested lookaheads. fig.3 is a bit verbose and we have to find the corresponding start&end markers. |
On your example site if you load the JavaScript grammar we have
and the diagram looks like
data:image/s3,"s3://crabby-images/1d8c0/1d8c010dcd641833e6c2ff7d7381002ddd35ac89" alt="screen shot 2017-09-10 at 8 16 34 pm"
As far as I understand, that is an invalid railroad diagram.
The text was updated successfully, but these errors were encountered: