From: Serhiy Storchaka Date: Sun, 22 Mar 2015 07:45:35 +0000 (+0200) Subject: Issue #22079: Py3k warning now is issued in PyType_Ready() instead of X-Git-Tag: v2.7.10rc1~114 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=ce16424b0bb430568c95691cb0439d28152e58bf;p=thirdparty%2FPython%2Fcpython.git Issue #22079: Py3k warning now is issued in PyType_Ready() instead of raising TypeError when statically allocated type subclasses dynamically allocated type --- diff --git a/Objects/typeobject.c b/Objects/typeobject.c index 6055cd9542d1..22def745da1e 100644 --- a/Objects/typeobject.c +++ b/Objects/typeobject.c @@ -4074,16 +4074,19 @@ PyType_Ready(PyTypeObject *type) } /* All bases of statically allocated type should be statically allocated */ - if (!(type->tp_flags & Py_TPFLAGS_HEAPTYPE)) + if (Py_Py3kWarningFlag && !(type->tp_flags & Py_TPFLAGS_HEAPTYPE)) for (i = 0; i < n; i++) { PyObject *b = PyTuple_GET_ITEM(bases, i); if (PyType_Check(b) && (((PyTypeObject *)b)->tp_flags & Py_TPFLAGS_HEAPTYPE)) { - PyErr_Format(PyExc_TypeError, - "type '%.100s' is not dynamically allocated but " - "its base type '%.100s' is dynamically allocated", - type->tp_name, ((PyTypeObject *)b)->tp_name); - goto error; + char buf[300]; + PyOS_snprintf(buf, sizeof(buf), + "type '%.100s' is not dynamically allocated but " + "its base type '%.100s' is dynamically allocated", + type->tp_name, ((PyTypeObject *)b)->tp_name); + if (PyErr_WarnPy3k(buf, 1) < 0) + goto error; + break; } }