mirror of https://github.com/python/cpython
Restore changeset 5bd9db528aed (issue #18408)
"Issue #18408: PyObject_Str(), PyObject_Repr() and type_call() now fail with an assertion error if they are called with an exception set (PyErr_Occurred()). As PyEval_EvalFrameEx(), they may clear the current exception and so the caller looses its exception."
This commit is contained in:
parent
c82bfd871f
commit
33824f6fd7
|
@ -449,6 +449,14 @@ PyObject_Repr(PyObject *v)
|
||||||
if (Py_TYPE(v)->tp_repr == NULL)
|
if (Py_TYPE(v)->tp_repr == NULL)
|
||||||
return PyUnicode_FromFormat("<%s object at %p>",
|
return PyUnicode_FromFormat("<%s object at %p>",
|
||||||
v->ob_type->tp_name, v);
|
v->ob_type->tp_name, v);
|
||||||
|
|
||||||
|
#ifdef Py_DEBUG
|
||||||
|
/* PyObject_Repr() must not be called with an exception set,
|
||||||
|
because it may clear it (directly or indirectly) and so the
|
||||||
|
caller looses its exception */
|
||||||
|
assert(!PyErr_Occurred());
|
||||||
|
#endif
|
||||||
|
|
||||||
res = (*v->ob_type->tp_repr)(v);
|
res = (*v->ob_type->tp_repr)(v);
|
||||||
if (res == NULL)
|
if (res == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -491,6 +499,13 @@ PyObject_Str(PyObject *v)
|
||||||
if (Py_TYPE(v)->tp_str == NULL)
|
if (Py_TYPE(v)->tp_str == NULL)
|
||||||
return PyObject_Repr(v);
|
return PyObject_Repr(v);
|
||||||
|
|
||||||
|
#ifdef Py_DEBUG
|
||||||
|
/* PyObject_Str() must not be called with an exception set,
|
||||||
|
because it may clear it (directly or indirectly) and so the
|
||||||
|
caller looses its exception */
|
||||||
|
assert(!PyErr_Occurred());
|
||||||
|
#endif
|
||||||
|
|
||||||
/* It is possible for a type to have a tp_str representation that loops
|
/* It is possible for a type to have a tp_str representation that loops
|
||||||
infinitely. */
|
infinitely. */
|
||||||
if (Py_EnterRecursiveCall(" while getting the str of an object"))
|
if (Py_EnterRecursiveCall(" while getting the str of an object"))
|
||||||
|
|
|
@ -736,6 +736,13 @@ type_call(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef Py_DEBUG
|
||||||
|
/* type_call() must not be called with an exception set,
|
||||||
|
because it may clear it (directly or indirectly) and so the
|
||||||
|
caller looses its exception */
|
||||||
|
assert(!PyErr_Occurred());
|
||||||
|
#endif
|
||||||
|
|
||||||
obj = type->tp_new(type, args, kwds);
|
obj = type->tp_new(type, args, kwds);
|
||||||
if (obj != NULL) {
|
if (obj != NULL) {
|
||||||
/* Ugly exception: when the call was type(something),
|
/* Ugly exception: when the call was type(something),
|
||||||
|
|
Loading…
Reference in New Issue