-
Notifications
You must be signed in to change notification settings - Fork 802
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
Add parser recovery for unfinished interface implementation #10416
Conversation
86913cd
to
dd887b2
Compare
Yeah, this one is tricky. I think I would prefer the old behavior because out of the two following scenarios:
The second one feels more likely to happen. But neither is really "correct". |
OK, subsequent members are parsed properly now and belong to the type, and the indentation warning in this particular case is reported by the parser instead of The warning range is larger with this approach, but a similar range is used in some other places in the compiler already and is probably not that bad. We don't have the first token range info at this point anymore anyway. Technically this is a breaking change, since it was possible to implement interfaces without further indenting members, but I much prefer how it's handled now with an explicit error and properly parsing all type members around. |
@cartermp @vzarytovskii The test failures seem unrelated, have you seen this before? |
That is a weird one, looks like some agent hiccup, I'll take a look. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, this is approved pending tests passing. I like the adjustment!
39ef8c0
to
7a5ca77
Compare
This is ready. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me, awesome
…0416) * Add parser recovery for unfinished interface implementation * Report indentation problem via parser * Update public area
Adds recovery for unfinished
interface ... with
that contains no members but is already givenwith
keyword.Example 1: before (interface impl is not parsed at all, subsequent declarations are corrupted):
data:image/s3,"s3://crabby-images/f8dd7/f8dd78aa077d50ac6b075d67c095e81df8a8865c" alt="Screenshot 2020-11-09 at 22 39 23"
Example 1: after (everything is parsed, type check results are available for the next declaration):
data:image/s3,"s3://crabby-images/0f77d/0f77da661ba627fbf8268c06beccffff684cd644" alt="Screenshot 2020-11-09 at 22 42 36"
The main problem with the example above is when
with
is present without any members, it simply fails to parse, skips other declarations, and no error about missing members is reported at all (for a user or tooling to fix it).Example 2: before (subsequent member is considered to be interface part):
data:image/s3,"s3://crabby-images/3fe24/3fe2472e67f52a9ac885f683fe0f1d20d1f4cc59" alt="Screenshot 2020-11-09 at 22 40 30"
Example 2: after (subsequent member belongs to the type declaration):
data:image/s3,"s3://crabby-images/f2ab3/f2ab33b713b79907ca03c6d2bd07ed04730652f8" alt="Screenshot 2020-11-09 at 22 40 45"
The current behaviour in the second example may actually be an intended behaviour. I've initially thought that from my experience it usually did more harm than good, since subsequence members do have the correct offset for the type declaration, but now I'm thinking it shouldn't have been changed. This part can easily be reverted by using
<
in theLexFilter
change instead. @dsyme @cartermp What do you think about this change?