perf: caching#10954
Open
radoering wants to merge 1 commit into
Open
Conversation
There was a problem hiding this comment.
Hey - I've left some high level feedback:
- Wrapping
_find_packages_uncachedwithfunctools.cacheand assigning it toself._find_packagesat runtime will bypass any overrides of_find_packagesin subclasses; if subclassing is expected here, consider caching at the class/method level or providing an overridable hook instead.
Prompt for AI Agents
Please address the comments from this code review:
## Overall Comments
- Wrapping `_find_packages_uncached` with `functools.cache` and assigning it to `self._find_packages` at runtime will bypass any overrides of `_find_packages` in subclasses; if subclassing is expected here, consider caching at the class/method level or providing an overridable hook instead.Help me be more useful! Please click 👍 or 👎 on each comment and I'll use the feedback to improve your reviews.
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.
Two caching changes that improve performance for resolving large projects a bit:
Term.relationandTerm.intersectionis often not used and constructing the cache in__init__costs some time. The trick with thecached_propertyseems simple enough and effective. In case anyone is wondering if we should apply this trick in general: It only makes sense for classes if many instances of the class are created and the cached methods are not used in many instances. We do not create that many instances of other classes where instance methods are cached._find_packagesseems to be called with the same name and constraint multiple times, especially when resolving with overrides.