diff options
Diffstat (limited to 'Objects')
| -rw-r--r-- | Objects/object.c | 15 | ||||
| -rw-r--r-- | Objects/typeobject.c | 7 | 
2 files changed, 22 insertions, 0 deletions
diff --git a/Objects/object.c b/Objects/object.c index 006f0d4dbc..693d8c73b1 100644 --- a/Objects/object.c +++ b/Objects/object.c @@ -449,6 +449,14 @@ PyObject_Repr(PyObject *v)      if (Py_TYPE(v)->tp_repr == NULL)          return PyUnicode_FromFormat("<%s object at %p>",                                      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);      if (res == NULL)          return NULL; @@ -491,6 +499,13 @@ PyObject_Str(PyObject *v)      if (Py_TYPE(v)->tp_str == NULL)          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         infinitely. */      if (Py_EnterRecursiveCall(" while getting the str of an object")) diff --git a/Objects/typeobject.c b/Objects/typeobject.c index c6ff0193e7..3ff42da1dd 100644 --- a/Objects/typeobject.c +++ b/Objects/typeobject.c @@ -736,6 +736,13 @@ type_call(PyTypeObject *type, PyObject *args, PyObject *kwds)          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);      if (obj != NULL) {          /* Ugly exception: when the call was type(something),  | 
