summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRaymond Hettinger <python@rcn.com>2003-06-18 01:13:41 (GMT)
committerRaymond Hettinger <python@rcn.com>2003-06-18 01:13:41 (GMT)
commitbe9715398b87df269d0781a7c436e10cfa4a0ea4 (patch)
tree21609b835a4f88dddbceb78205b26b20cfb5f8e6
parent9b1587836992c460d213b9bbc6f539516139bdf2 (diff)
downloadcpython-be9715398b87df269d0781a7c436e10cfa4a0ea4.zip
cpython-be9715398b87df269d0781a7c436e10cfa4a0ea4.tar.gz
cpython-be9715398b87df269d0781a7c436e10cfa4a0ea4.tar.bz2
SF bug #753451: classmethod abuse --> SystemError
Check the argument to classmethod for callability. Backport candidate.
-rw-r--r--Lib/test/test_descr.py8
-rw-r--r--Objects/funcobject.c6
2 files changed, 14 insertions, 0 deletions
diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py
index 9587596..46e3c48 100644
--- a/Lib/test/test_descr.py
+++ b/Lib/test/test_descr.py
@@ -1485,6 +1485,14 @@ def classmethods():
vereq(super(D,D).goo(), (D,))
vereq(super(D,d).goo(), (D,))
+ # Verify that argument is checked for callability (SF bug 753451)
+ try:
+ classmethod(1).__get__(1)
+ except TypeError:
+ pass
+ else:
+ raise TestFailed, "classmethod should check for callability"
+
def classmethods_in_c():
if verbose: print "Testing C-based class methods..."
import xxsubtype as spam
diff --git a/Objects/funcobject.c b/Objects/funcobject.c
index 8f2d8df..c414bca 100644
--- a/Objects/funcobject.c
+++ b/Objects/funcobject.c
@@ -640,6 +640,12 @@ cm_init(PyObject *self, PyObject *args, PyObject *kwds)
if (!PyArg_UnpackTuple(args, "classmethod", 1, 1, &callable))
return -1;
+ if (!PyCallable_Check(callable)) {
+ PyErr_Format(PyExc_TypeError, "'%s' object is not callable",
+ callable->ob_type->tp_name);
+ return -1;
+ }
+
Py_INCREF(callable);
cm->cm_callable = callable;
return 0;