]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-19072: Update descriptor howto for decorator chaining (GH-22934)
authorRaymond Hettinger <rhettinger@users.noreply.github.com>
Sat, 24 Oct 2020 01:37:27 +0000 (18:37 -0700)
committerGitHub <noreply@github.com>
Sat, 24 Oct 2020 01:37:27 +0000 (18:37 -0700)
Doc/howto/descriptor.rst

index 4a53b9e61569227b8650dc7cb8346d409e0b3a67..4e9fad30d31c4f1efb83aa0724c393585258ab08 100644 (file)
@@ -872,6 +872,16 @@ Using the non-data descriptor protocol, a pure Python version of
         def __get__(self, obj, cls=None):
             if cls is None:
                 cls = type(obj)
-            def newfunc(*args):
-                return self.f(cls, *args)
-            return newfunc
+            if hasattr(obj, '__get__'):
+                return self.f.__get__(cls)
+            return types.MethodType(self.f, cls)
+
+The code path for ``hasattr(obj, '__get__')`` was added in Python 3.9 and
+makes it possible for :func:`classmethod` to support chained decorators.
+For example, a classmethod and property could be chained together::
+
+    class G:
+        @classmethod
+        @property
+        def __doc__(cls):
+            return f'A doc for {cls.__name__!r}'