perf: optimize duplicate handler filtering#4003
Merged
pi0 merged 3 commits intonitrojs:mainfrom Feb 5, 2026
Merged
Conversation
|
@OskarLebuda is attempting to deploy a commit to the Nitro Team on Vercel. A member of the Team first needs to authorize it. |
📝 WalkthroughWalkthroughThe deduplication logic in scanHandlers is updated to use key-based deduplication with a Set instead of index-based deduplication. A composite key combining route, method, and env is created for each handler, ensuring only the first occurrence of each unique key is included in nitro.scannedHandlers. Changes
Estimated code review effort🎯 2 (Simple) | ⏱️ ~10 minutes 🚥 Pre-merge checks | ✅ 2 | ❌ 1❌ Failed checks (1 warning)
✅ Passed checks (2 passed)
✏️ Tip: You can configure your own custom pre-merge checks in the settings. ✨ Finishing touches
🧪 Generate unit tests (beta)
Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. Comment |
commit: |
8 tasks
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.
🔗 Linked issue
n/a
❓ Type of change
📚 Description
The current implementation uses
findIndexinsidefilter, which scans the entire array for each handler - resulting in O(n2) complexity.Replaced with a Set-based approach for O(1) lookups instead of repeatedly scanning the array. Behavior stays the same - keeps first occurrence, removes duplicates.
For large applications with many routes, this should provide noticeable performance improvement during startup.
📝 Checklist