diff options
author | Guido van Rossum <guido@python.org> | 2002-08-10 05:42:07 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2002-08-10 05:42:07 (GMT) |
commit | 40af889081938c1fea83cba0a9cbdb35e299119d (patch) | |
tree | b82e6e114ba1710a0d4bb6fbdd23baf7c7a25dea | |
parent | e05f65a0c6fb0b59fe72bcb8055eb74a3f63bff8 (diff) | |
download | cpython-40af889081938c1fea83cba0a9cbdb35e299119d.zip cpython-40af889081938c1fea83cba0a9cbdb35e299119d.tar.gz cpython-40af889081938c1fea83cba0a9cbdb35e299119d.tar.bz2 |
Disallow class assignment completely unless both old and new are heap
types. This prevents nonsense like 2.__class__ = bool or
True.__class__ = int.
-rw-r--r-- | Lib/test/test_descr.py | 5 | ||||
-rw-r--r-- | Objects/typeobject.c | 15 |
2 files changed, 14 insertions, 6 deletions
diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py index 51fa0d9..1ce08b7 100644 --- a/Lib/test/test_descr.py +++ b/Lib/test/test_descr.py @@ -2478,6 +2478,11 @@ def setclass(): cant(C(), object) cant(object(), list) cant(list(), object) + class Int(int): __slots__ = [] + cant(2, Int) + cant(Int(), int) + cant(True, int) + cant(2, bool) def setdict(): if verbose: print "Testing __dict__ assignment..." diff --git a/Objects/typeobject.c b/Objects/typeobject.c index 020cbf2..fddde51 100644 --- a/Objects/typeobject.c +++ b/Objects/typeobject.c @@ -1745,6 +1745,13 @@ object_set_class(PyObject *self, PyObject *value, void *closure) return -1; } new = (PyTypeObject *)value; + if (!(new->tp_flags & Py_TPFLAGS_HEAPTYPE) || + !(old->tp_flags & Py_TPFLAGS_HEAPTYPE)) + { + PyErr_Format(PyExc_TypeError, + "__class__ assignment: only for heap types"); + return -1; + } if (new->tp_dealloc != old->tp_dealloc || new->tp_free != old->tp_free) { @@ -1771,13 +1778,9 @@ object_set_class(PyObject *self, PyObject *value, void *closure) old->tp_name); return -1; } - if (new->tp_flags & Py_TPFLAGS_HEAPTYPE) { - Py_INCREF(new); - } + Py_INCREF(new); self->ob_type = new; - if (old->tp_flags & Py_TPFLAGS_HEAPTYPE) { - Py_DECREF(old); - } + Py_DECREF(old); return 0; } |