]> granicus.if.org Git - python/commitdiff
bpo-38026: fix inspect.getattr_static (GH-15676)
authorInada Naoki <songofacandy@gmail.com>
Thu, 5 Sep 2019 04:07:08 +0000 (13:07 +0900)
committerGitHub <noreply@github.com>
Thu, 5 Sep 2019 04:07:08 +0000 (13:07 +0900)
It should avoid dynamic lookup including `isinstance`.

This is a regression caused by GH-5351.

Lib/inspect.py
Misc/NEWS.d/next/Library/2019-09-04-20-34-14.bpo-38026.0LLRX-.rst [new file with mode: 0644]

index 99a580bd2f23500a60010362961634c7295f2891..a616f2d49b7d96a6206239ee2fb99b41ca18f1a0 100644 (file)
@@ -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
@@ -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
diff --git a/Misc/NEWS.d/next/Library/2019-09-04-20-34-14.bpo-38026.0LLRX-.rst b/Misc/NEWS.d/next/Library/2019-09-04-20-34-14.bpo-38026.0LLRX-.rst
new file mode 100644 (file)
index 0000000..166cd86
--- /dev/null
@@ -0,0 +1,2 @@
+Fixed :func:`inspect.getattr_static` used ``isinstance`` while it should
+avoid dynamic lookup.