- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 33.2k
gh-70764: inspect.getclosurevars now identifies global variables with LOAD_GLOBAL #120143
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
gh-70764: inspect.getclosurevars now identifies global variables with LOAD_GLOBAL #120143
Conversation
…OAD_GLOBAL instructions instead
| Thanks for the contribution! This could make  In particular, if a large function has lots of references to builtins (even the same builtin used many times) we will repeatedly raise and catch an exception, possibly many times for the same builtin name. This repeated exception raising could at least be mitigated by keeping a set of seen global names, and not re-looking-up an already-seen name (or just avoiding re-looking-up names already present in  That said, I'm not sure I see any other implementation strategy for fixing this function; we just don't preserve enough context from compilation on the code object, except in the bytecode itself. Would like to see if any other reviewer has better ideas here, before merging this. | 
…set before looking them up
| 
 Thanks for the review! I totally agree with your assessments. I've updated the approach so that it collects all global names in a set first before looking them up in global and builtin namespaces. And yeah unfortunately I don't see a way not to scan through all the bytecodes if we are to aim for accuracy. | 
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 will still be a slowdown, but not raising a lot of exceptions should help a lot, and inspect methods are often slow; correctness seems more important. And no better idea for how to make this method correct has surfaced; I don't think there is one. Going to go ahead and rebase this to make sure no other changes have impacted it in the last months, and then merge if signal looks good. Thanks again for the contribution!
…s with LOAD_GLOBAL (pythonGH-120143) (cherry picked from commit 83ba8c2) Co-authored-by: blhsing <[email protected]>
| GH-126459 is a backport of this pull request to the 3.13 branch. | 
…s with LOAD_GLOBAL (pythonGH-120143) (cherry picked from commit 83ba8c2) Co-authored-by: blhsing <[email protected]>
| GH-126460 is a backport of this pull request to the 3.12 branch. | 
…s with LOAD_GLOBAL (python#120143)
…s with LOAD_GLOBAL (python#120143)
inspect.getclosurevarsnow identifies global variables withLOAD_GLOBALCurrently
inspect.getclosurevarsidentifies a global variable by testing if a name inco_namesexists in the function's global namespace, but this approach can result in incorrectly classifying an attribute name as a global variable when the name exists both as an attriute and as a global variable.This PR fixes the issue by using the
LOAD_GLOBALandLOAD_ATTRinstructions instead to identify global names and unbound names, respectively.