Skip to content

Commit

Permalink
bpo-38026: fix inspect.getattr_static (GH-15676)
Browse files Browse the repository at this point in the history
It should avoid dynamic lookup including `isinstance`.

This is a regression caused by GH-5351.
  • Loading branch information
methane committed Sep 5, 2019
1 parent 2cd9025 commit 8f9cc87
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 2 deletions.
4 changes: 2 additions & 2 deletions Lib/inspect.py
Expand Up @@ -1558,7 +1558,7 @@ def _shadowed_dict(klass):
except KeyError:
pass
else:
if not (isinstance(class_dict, types.GetSetDescriptorType) and
if not (type(class_dict) is types.GetSetDescriptorType and
class_dict.__name__ == "__dict__" and
class_dict.__objclass__ is entry):
return class_dict
Expand All @@ -1580,7 +1580,7 @@ def getattr_static(obj, attr, default=_sentinel):
klass = type(obj)
dict_attr = _shadowed_dict(klass)
if (dict_attr is _sentinel or
isinstance(dict_attr, types.MemberDescriptorType)):
type(dict_attr) is types.MemberDescriptorType):
instance_result = _check_instance(obj, attr)
else:
klass = obj
Expand Down
@@ -0,0 +1,2 @@
Fixed :func:`inspect.getattr_static` used ``isinstance`` while it should
avoid dynamic lookup.

0 comments on commit 8f9cc87

Please sign in to comment.