[3.9] bpo-44050: Extension modules can share state when they don't support sub-interpreters. (GH-27794)#28741
Uh oh!
There was an error while loading. Please reload this page.
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.
(cherry picked from commit b9bb748)
Co-authored-by: Hai Shi shihai1992@gmail.com
Note: this is a little different from 3.10 and 3.11 because in 3.10+
_Py_IsMainInterpretertakesPyInterpreterStateinstead of the entirePyThreadStateas an argument (see GH-24577 for that).Also, the new test uses
PyModule_AddObjectRefwhich was only added in Python 3.10 (see GH-23122). I replaced this usage with the oldPyModule_AddObjectwith additional increfs and decrefs per what BPO-42327 prescribes.https://bugs.python.org/issue44050