[3.15] gh-148587: Make sys.lazy_modules match PEP and keep internal lazy submodules tra…#150014
Open
DinoV wants to merge 2 commits into
Open
[3.15] gh-148587: Make sys.lazy_modules match PEP and keep internal lazy submodules tra…#150014DinoV wants to merge 2 commits into
DinoV wants to merge 2 commits into
Conversation
Yhg1s
approved these changes
May 18, 2026
Member
Yhg1s
left a comment
There was a problem hiding this comment.
I think this approach makes sense...
| PyObject *lazy_importing_modules; | ||
| // The set stored in sys.lazy_modules if values that have been | ||
| // lazily imported. This value is only for debugging/introspection | ||
| // purposes and is not used at runtime. |
Member
There was a problem hiding this comment.
Suggested change
| // purposes and is not used at runtime. | |
| // purposes and is not used by the runtime. |
Comment on lines
+356
to
+358
| // Submodules that have been imported lazily from modules which have | ||
| // been imported lazily. When the module is imported we need to add | ||
| // a LazyImportObject which refers to the submodule on the module. |
Member
There was a problem hiding this comment.
Suggested change
| // Submodules that have been imported lazily from modules which have | |
| // been imported lazily. When the module is imported we need to add | |
| // a LazyImportObject which refers to the submodule on the module. | |
| // A dict mapping package names to a set of submodule names that | |
| // have been imported lazily from packages which have been imported | |
| // lazily. When the package is reified we need to add a | |
| // LazyImportObject which refers to the submodule on the module. | |
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.
The PEP initially set
sys.lazy_moduleswas to be a set of the lazily imported things. At some point it seemed that having our internal tracking for publishing submodules to parent modules when they're imported could be combined with this. But this means that data the interpreter is making decisions on is now immutable. This goes back to having a separate set for the lazy modules which is user visible but has no impact on how lazy imports are evaluated or executed.This is one possible approach - another one would be to make it a function and calculate the set and return it per-call. Then it would be backed by our normal internal data.
We could also make it a function and keep tracking both sets of data as this PR does and then that'd give us the ability in the future to lazily calculate the data.
sys.lazy_modules#148587