summaryrefslogtreecommitdiffstats
path: root/Objects/exceptions.c
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2007-08-21 06:01:18 (GMT)
committerGeorg Brandl <georg@python.org>2007-08-21 06:01:18 (GMT)
commitfdca6d8599e46ee7fc7844a798666fc60923fbe5 (patch)
tree238caa41f0e2edce919e55b1d658330415036caa /Objects/exceptions.c
parent1bb124ad0d9a81664170d9a41c6c8128ceafbc33 (diff)
downloadcpython-fdca6d8599e46ee7fc7844a798666fc60923fbe5.zip
cpython-fdca6d8599e46ee7fc7844a798666fc60923fbe5.tar.gz
cpython-fdca6d8599e46ee7fc7844a798666fc60923fbe5.tar.bz2
Demand version 2.5.1 since 2.5 has a bug with codecs.open context managers.
Diffstat (limited to 'Objects/exceptions.c')
-rw-r--r--Objects/exceptions.c38
1 files changed, 32 insertions, 6 deletions
diff --git a/Objects/exceptions.c b/Objects/exceptions.c
index 3d79383..103a662 100644
--- a/Objects/exceptions.c
+++ b/Objects/exceptions.c
@@ -38,18 +38,31 @@ BaseException_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
/* the dict is created on the fly in PyObject_GenericSetAttr */
self->message = self->dict = NULL;
- self->args = PyTuple_New(0);
- if (!self->args) {
+ if (!args) {
+ /* MemoryError instantiation */
+ args = PyTuple_New(0);
+ if (!args) {
+ Py_DECREF(self);
+ return NULL;
+ }
+ } else {
+ Py_INCREF(args);
+ }
+
+ self->args = args;
+
+ /* Since the args can be overwritten in __init__, we have to store
+ the original args somewhere for pickling. */
+ if (PyObject_SetAttrString((PyObject *)self, "__newargs__", args) < 0) {
Py_DECREF(self);
return NULL;
}
-
+
self->message = PyString_FromString("");
if (!self->message) {
Py_DECREF(self);
return NULL;
}
-
return (PyObject *)self;
}
@@ -147,10 +160,23 @@ BaseException_repr(PyBaseExceptionObject *self)
static PyObject *
BaseException_reduce(PyBaseExceptionObject *self)
{
+ PyObject *result;
+ PyObject *newargs = PyObject_GetAttrString((PyObject *)self, "__newargs__");
+ if (!newargs) {
+ if (PyErr_ExceptionMatches(PyExc_AttributeError)) {
+ PyErr_SetString(PyExc_AttributeError,
+ "To pickle exceptions via BaseException.__reduce__, "
+ "you need to set the __newargs__ attribute in your "
+ "custom __new__ method.");
+ }
+ return NULL;
+ }
if (self->args && self->dict)
- return PyTuple_Pack(3, Py_Type(self), self->args, self->dict);
+ result = PyTuple_Pack(3, Py_Type(self), newargs, self->dict);
else
- return PyTuple_Pack(2, Py_Type(self), self->args);
+ result = PyTuple_Pack(2, Py_Type(self), newargs);
+ Py_DECREF(newargs);
+ return result;
}
/*