summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRaymond Hettinger <rhettinger@users.noreply.github.com>2021-11-19 12:43:49 -0600
committerGitHub <noreply@github.com>2021-11-19 19:43:49 +0100
commite34809e1c2a09478f4e0651d551c9c12d3c556ab (patch)
tree25d303a76df06f9c697863057ab267b21f87b65d
parentd32316a2aacc3b3c4f6f56f96edb09a4437c8bdb (diff)
downloadcpython-git-e34809e1c2a09478f4e0651d551c9c12d3c556ab.tar.gz
bpo-19072: Classmethod can wrap other classmethod like descriptors (GH-29634)
staticmethod() also became callable in Python 3.10. See: b83861f02.
-rw-r--r--Doc/howto/descriptor.rst9
1 files changed, 8 insertions, 1 deletions
diff --git a/Doc/howto/descriptor.rst b/Doc/howto/descriptor.rst
index 575caeb720..6ce062d0fa 100644
--- a/Doc/howto/descriptor.rst
+++ b/Doc/howto/descriptor.rst
@@ -1264,6 +1264,9 @@ Using the non-data descriptor protocol, a pure Python version of
def __get__(self, obj, objtype=None):
return self.f
+ def __call__(self, *args, **kwds):
+ return self.f(*args, **kwds)
+
.. testcode::
:hide:
@@ -1272,6 +1275,8 @@ Using the non-data descriptor protocol, a pure Python version of
def f(x):
return x * 10
+ wrapped_ord = StaticMethod(ord)
+
.. doctest::
:hide:
@@ -1279,6 +1284,8 @@ Using the non-data descriptor protocol, a pure Python version of
30
>>> E_sim().f(3)
30
+ >>> wrapped_ord('A')
+ 65
Class methods
@@ -1344,7 +1351,7 @@ Using the non-data descriptor protocol, a pure Python version of
if cls is None:
cls = type(obj)
if hasattr(type(self.f), '__get__'):
- return self.f.__get__(cls)
+ return self.f.__get__(cls, cls)
return MethodType(self.f, cls)
.. testcode::