summaryrefslogtreecommitdiff
path: root/Python/errors.c
diff options
context:
space:
mode:
authorBrian Curtin <brian@python.org>2012-04-18 08:30:51 -0500
committerBrian Curtin <brian@python.org>2012-04-18 08:30:51 -0500
commit94c001b50377267626e136949ba410c8ad28a6f0 (patch)
treea7d1b531fdb547915b9df4cadbe71a7a70115cae /Python/errors.c
parent03c7ed15803def1eedec65522e6185fc5a1badf9 (diff)
downloadcpython-git-94c001b50377267626e136949ba410c8ad28a6f0.tar.gz
Fix email post-commit review comments.
Add INCREFs, fix args->kwargs, and a second args==NULL check was removed, left over from a merger with another function. Instead, checking msg==NULL does what that used to do in a roundabout way.
Diffstat (limited to 'Python/errors.c')
-rw-r--r--Python/errors.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/Python/errors.c b/Python/errors.c
index a49cde6247..63eebe2e77 100644
--- a/Python/errors.c
+++ b/Python/errors.c
@@ -590,29 +590,32 @@ PyErr_SetImportError(PyObject *msg, PyObject *name, PyObject *path)
{
PyObject *args, *kwargs, *error;
+ if (msg == NULL)
+ return NULL;
+
args = PyTuple_New(1);
if (args == NULL)
return NULL;
kwargs = PyDict_New();
- if (args == NULL)
+ if (kwargs == NULL)
return NULL;
- if (name == NULL)
+ if (name == NULL) {
+ Py_INCREF(Py_None);
name = Py_None;
+ }
- if (path == NULL)
+ if (path == NULL) {
+ Py_INCREF(Py_None);
path = Py_None;
+ }
Py_INCREF(msg);
- PyTuple_SetItem(args, 0, msg);
+ PyTuple_SetItem(args, 0, NULL);//msg);
PyDict_SetItemString(kwargs, "name", name);
PyDict_SetItemString(kwargs, "path", path);
- /* args must at least be an empty tuple */
- if (args == NULL)
- args = PyTuple_New(0);
-
error = PyObject_Call(PyExc_ImportError, args, kwargs);
if (error!= NULL) {
PyErr_SetObject((PyObject *) Py_TYPE(error), error);