summaryrefslogtreecommitdiff
path: root/Python/errors.c
diff options
context:
space:
mode:
authorBarry Warsaw <barry@python.org>2000-05-02 19:27:51 +0000
committerBarry Warsaw <barry@python.org>2000-05-02 19:27:51 +0000
commitf14609a3ae25a30a658ad3b143331382927c2c4e (patch)
tree69ad1ff53bf0fe3d61e6b652e452e0e5301b2fb7 /Python/errors.c
parenta16a2a6c859b877b2a88af07573c86dae3f1ce3b (diff)
downloadcpython-f14609a3ae25a30a658ad3b143331382927c2c4e.tar.gz
PyErr_GivenExceptionMatches(): Check for err==NULL and exc==NULL and
return 0 (exceptions don't match). This means that if an ImportError is raised because exceptions.py can't be imported, the interpreter will exit "cleanly" with an error message instead of just core dumping. PyErr_SetFromErrnoWithFilename(), PyErr_SetFromWindowsErrWithFilename(): Don't test on Py_UseClassExceptionsFlag.
Diffstat (limited to 'Python/errors.c')
-rw-r--r--Python/errors.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/Python/errors.c b/Python/errors.c
index ebce5ddbb3..d05a21d5ba 100644
--- a/Python/errors.c
+++ b/Python/errors.c
@@ -125,6 +125,10 @@ int
PyErr_GivenExceptionMatches(err, exc)
PyObject *err, *exc;
{
+ if (err == NULL || exc == NULL) {
+ /* maybe caused by "import exceptions" that failed early on */
+ return 0;
+ }
if (PyTuple_Check(exc)) {
int i, n;
n = PyTuple_Size(exc);
@@ -331,7 +335,7 @@ PyErr_SetFromErrnoWithFilename(exc, filename)
}
}
#endif
- if (filename != NULL && Py_UseClassExceptionsFlag)
+ if (filename != NULL)
v = Py_BuildValue("(iss)", i, s, filename);
else
v = Py_BuildValue("(is)", i, s);
@@ -379,7 +383,7 @@ PyObject *PyErr_SetFromWindowsErrWithFilename(
/* remove trailing cr/lf and dots */
while (len > 0 && (s[len-1] <= ' ' || s[len-1] == '.'))
s[--len] = '\0';
- if (filename != NULL && Py_UseClassExceptionsFlag)
+ if (filename != NULL)
v = Py_BuildValue("(iss)", err, s, filename);
else
v = Py_BuildValue("(is)", err, s);