Commit 6b3a2c4a authored by Martin v. Löwis's avatar Martin v. Löwis

Patch #448227: Raise an exception when a directory is passed to execfile.

parent 96204f5e
......@@ -568,6 +568,8 @@ builtin_execfile(PyObject *self, PyObject *args)
PyObject *res;
FILE* fp;
PyCompilerFlags cf;
int exists;
struct stat s;
if (!PyArg_ParseTuple(args, "s|O!O!:execfile",
&filename,
......@@ -586,10 +588,27 @@ builtin_execfile(PyObject *self, PyObject *args)
PyEval_GetBuiltins()) != 0)
return NULL;
}
Py_BEGIN_ALLOW_THREADS
fp = fopen(filename, "r");
Py_END_ALLOW_THREADS
if (fp == NULL) {
exists = 0;
/* Test for existence or directory. */
if (!stat(filename, &s)) {
if (S_ISDIR(s.st_mode))
errno = EISDIR;
else
exists = 1;
}
if (exists) {
Py_BEGIN_ALLOW_THREADS
fp = fopen(filename, "r");
Py_END_ALLOW_THREADS
if (fp == NULL) {
exists = 0;
}
}
if (!exists) {
PyErr_SetFromErrno(PyExc_IOError);
return NULL;
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment