Merged revisions 76794 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r76794 | benjamin.peterson | 2009-12-13 10:36:53 -0600 (Sun, 13 Dec 2009) | 2 lines fix the ignoring of __cmp__ method on metaclasses #7491 ........
This commit is contained in:
parent
62926f0b1e
commit
d76e711eab
|
@ -1198,6 +1198,15 @@ order (MRO) for bases """
|
|||
# This used to crash
|
||||
self.assertRaises(TypeError, MyABC.a.__set__, u, 3)
|
||||
|
||||
def test_metaclass_cmp(self):
|
||||
# See bug 7491.
|
||||
class M(type):
|
||||
def __cmp__(self, other):
|
||||
return -1
|
||||
class X(object):
|
||||
__metaclass__ = M
|
||||
self.assertTrue(X < M)
|
||||
|
||||
def test_dynamics(self):
|
||||
# Testing class attribute propagation...
|
||||
class D(object):
|
||||
|
|
|
@ -12,6 +12,8 @@ What's New in Python 2.6.5
|
|||
Core and Builtins
|
||||
-----------------
|
||||
|
||||
- Issue #7491: Metaclass's __cmp__ method was ignored.
|
||||
|
||||
- Add Py3k warnings for parameter names in parenthesis.
|
||||
|
||||
- Issue #7362: Give a proper error message for def f((x)=3): pass.
|
||||
|
|
|
@ -645,7 +645,11 @@ type_richcompare(PyObject *v, PyObject *w, int op)
|
|||
int c;
|
||||
|
||||
/* Make sure both arguments are types. */
|
||||
if (!PyType_Check(v) || !PyType_Check(w)) {
|
||||
if (!PyType_Check(v) || !PyType_Check(w) ||
|
||||
/* If there is a __cmp__ method defined, let it be called instead
|
||||
of our dumb function designed merely to warn. See bug
|
||||
#7491. */
|
||||
Py_TYPE(v)->tp_compare || Py_TYPE(w)->tp_compare) {
|
||||
result = Py_NotImplemented;
|
||||
goto out;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue