Skip to content
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

Avoid Lists of MapEntries. #3807

Merged
merged 1 commit into from
Jul 1, 2024
Merged

Conversation

srawlins
Copy link
Member

@srawlins srawlins commented Jul 1, 2024

In the existing code, a few APIs like CommentReferableEntryGenerators.generateEntries and Container.extraReferenceChildren used List<MapEntry<...>> which I've found super confusing.

They are pretty hard to reason about, and also some "put all if absent" code was employed to wrangle them. But it turns out that given Map a and Map b, a.putAllIfAbsent(b) is the same as b.addAll(a). So this code can be simplified all around by just using Maps as they are meant to be used.

This code is a no-op; same results, just simpler.


  • I’ve reviewed the contributor guide and applied the relevant portions to this PR.
Contribution guidelines:

Note that many Dart repos have a weekly cadence for reviewing PRs - please allow for some latency before initial review feedback.

In the existing code, a few APIs like
`CommentReferableEntryGenerators.generateEntries` and
`Container.extraReferenceChildren` used `List<MapEntry<...>>` which I've found
super confusing.

They are pretty hard to reason about, and also some "put all if absent" code
was employed to wrangle them. But it turns out that given Map `a` and Map `b`,
`a.putAllIfAbsent(b)` is the same as `b.addAll(a)`. So this code can be
simplified all around by just using Maps as they are meant to be used.

This code is a no-op; same results, just simpler.
@srawlins
Copy link
Member Author

srawlins commented Jul 1, 2024

CC @dart-lang/analyzer-team

@srawlins srawlins merged commit 6a02ffb into dart-lang:main Jul 1, 2024
9 checks passed
@srawlins srawlins deleted the no-map-entries branch July 1, 2024 19:02
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants