-
Notifications
You must be signed in to change notification settings - Fork 4.1k
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
Support long chains of else if
statements
#74317
Merged
Merged
Changes from all commits
Commits
Show all changes
24 commits
Select commit
Hold shift + click to select a range
3a22e73
Nested if/else if
cston 86a1bf8
BindIfStatement
cston b705b76
Fix tests
cston f362bb2
Merge 'main' into 72393
AlekseyTs e7d2673
Simplify logic in ControlFlowGraph builder and Binder
AlekseyTs ac712a1
Fix a couple of visitors
AlekseyTs aa4fdc8
Formatting
AlekseyTs e64b418
Fixup ParseIfStatement
AlekseyTs 61dd4c5
Move new test
AlekseyTs c8578eb
Don't run new test in IOperation leg
AlekseyTs f795071
Revert using chnages
AlekseyTs 5ac1691
Adjust nesting depth expectations
AlekseyTs 771e406
Add IL verification
AlekseyTs 17dfd90
Adjust LocalRewriter.VisitIfStatement
AlekseyTs 3253943
Revert remaining changes in CodeGenerator.cs
AlekseyTs e54179e
Move VisitIfStatement override to base
AlekseyTs 2b7c88b
Change base for EmptyRewriter
AlekseyTs b337684
Remove obsolete PROTOTYPE comments
AlekseyTs 2dfbfeb
Simplify CreateBoundIfStatementOperation
AlekseyTs 3331985
Revert unintended change
AlekseyTs 77cf5f9
Remove PROTOTYPE comment on ParseMisplacedElse
AlekseyTs 90f043b
Adjust supported depth of nesting
AlekseyTs 487db6e
Seal an override
AlekseyTs 0811e7e
PR feedback
AlekseyTs File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
I thought about making this change for my BinaryPatterns change, but I don't think it's actually desirable; rather, this is why I updated StackGuard to handle binary patterns as well as expressions, so that it would throw a
CancelledByStackGuard
exception and enter the catch above. #ResolvedThere 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.
This visitor and its usage were added in #65398. It looks there was no specific motivation around verifying stack guard behavior. Rather it looks like it was about asserting that
Update
implementations are working for all possible nodes. The purpose is still preserved, in my opinion.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.
By the way, the change made to
BoundTreeRewriterWithStackGuard
around binary patterns probably makes sense since they are used in expression context. However, it is probably not that useful because patterns do not survive the very first rewrite phase (lowering).