Fix bug in match
ing struct patterns
#8350
Closed
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.
Code that collects fields in struct-like patterns used to ignore
wildcard patterns like
Foo{_}
. Butenter_defaults
consideredstruct-like patterns as default in order to overcome this
(accoring to my understanding of situation).
However such behaviour caused code like this:
consider pattern
Foo{f: _f}
as default. That caused inproper behaviourand even segfaults while trying to destruct
Bar
asFoo{f: _f}
.Issues: #5625 , #5530.
This patch fixes
collect_record_or_struct_fields
to split cases ofsingle wildcard struct-like pattern and no struct-like pattern at all.
Former case resolved with
enter_rec_or_struct
(and not withenter_defaults
).Closes #5625.
Closes #5530.