-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
chore: reduce simple Map/Set ops #9761
Conversation
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.
this change is just variable name cleanup. This method is a mega hot-path. I previously benchmarked this multi-tier strategy working better overall than a single-tier strategy + there may later be gains made possible by it in terms of making remote operations flush lazily.
However, we should re-test this assumption at this point.
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.
for small arrays and sets, checking value directly is 30% faster (or more)
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.
the change here is that we use the callback function itself as the token, stashing a bit of info directly on it. This eliminates the double map lookup and simplifies iteration.
We also convert CacheOperations (a simple set) into a direct value comparison.
Performance Report for dbe4c43 Scenario - basic-record-materialization: ✅ Performance improved
Scenario - complex-record-materialization: ✅ Performance improved
Scenario - complex-record-materialization-with-relationship-materialization: ✅ Performance improved
Scenario - relationship-materialization-simple: ☑️ Performance is stable
Scenario - relationship-materialization-complex: ✅ Performance improved
Scenario - unload: ☑️ Performance is stable
Scenario - unload-all: ✅ Performance improved
Scenario - destroy: ☑️ Performance is stable
Scenario - add-children: ☑️ Performance is stable
Scenario - unused-relationships: ✅ Performance improved
Scenario - update-with-same-state: ✅ Performance improved
Scenario - update-with-same-state-m2m: ☑️ Performance is stable
|
* feat: schema type utils (#9757) * minor type improvements * chore: fixup types * add api docs * nice things * account for schema presence * cleanup test * chore: update contributing docs (#9758) * chore: Improve contributing experience (#9759) * chore: improve developing experience on local * more * temporarily deactivate some scenarios * deactivate more lints * deactivate more prod tests * another * chore: reduce simple Map/Set ops (#9761) * perf: faster iteration of relationship payloads (#9762) faster iteration of payloads * chore: restructure SchemaRecord test file layout to make it easier to navigate (#9763) * chore: simplify test file layout * chore: move polaris test files to new structure * docs: LinksMode and Polymorphic Relationship Guide, stubs out guide for LegacyMode vs PolarisMode (#9764) * docs: stub out guides for SchemaRecord, LinksMode, PolarisMode etc. * add linksmode guide * fix annotation * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * Update guides/relationships/features/links-mode.md Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * cleanup op * rewrite future thoughts * stub out more of the guide * add docs on polymorphism * stub out guide * add note on interop * add reactivity overview --------- Co-authored-by: Krystan HuffMenne <kmenne+github@gmail.com> * feat: improve debuggability of SchemaRecord, RecordArray and Identifier (#9766) * feat: improve debuggability of SchemaRecord, RecordArray and Identifier * fix configurability * fix keys * feat: persist runtime config (#9767) * feat: persist runtime config * ensure fastboot works * Don't set isDirty to true in diff callbacks (#9765) * More overnotification fixes * Fix DEPRECATE_RELATIONSHIP_REMOTE_UPDATE_CLEARING_LOCAL_STATE case * feat: ensure objects behave amazeballs (#9768) * feat: ensure objects behave amazeballs * add tests for record iteration * add more tests * fix(deps): update dependency @babel/runtime to v7.26.10 [security] (#9760) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore: remove restriction on new field kinds being used with legacy mode * improve types * Revert "improve types" This reverts commit 84daef7. * Revert "chore: remove restriction on new field kinds being used with legacy mode" This reverts commit 3fd81bf. * Widen Peer Range for ember-inflector (#9770) * chore: remove restriction on new field kinds being used with legacy mode (#9769) * chore: remove restriction on new field kinds being used with legacy mode * chore: cleanup types * fix * fix test * fix docs * chore: cleanup @ember/service deprecation from shipped library code (#9773) * Add: tests verify behavior mutating a record (#9754) * add: tests verify behavior mutating a related record from a checked-out record * fix: lint * fix: test * fix: lint * fix: better reordering detection when remoteClearsLocal is true (#9771) * Fix DEPRECATE_RELATIONSHIP_REMOTE_UPDATE_CLEARING_LOCAL_STATE reordering detection * add failing test * notification tests * implement fix * cleanup console logs * fix spurrious type issue --------- Co-authored-by: Chris Thoburn <runspired@users.noreply.github.com> * Fix some lint --------- Co-authored-by: Chris Thoburn <runspired@users.noreply.github.com> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Jon Johnson <jon.johnson@ucsf.edu> Co-authored-by: Mehul Kiran Chaudhari <55375534+MehulKChaudhari@users.noreply.github.com>
No description provided.