diff options
author | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2002-03-22 20:38:57 (GMT) |
---|---|---|
committer | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2002-03-22 20:38:57 (GMT) |
commit | 398b9f6d6d75628efe03fb4d8dc1aa2df6c35a67 (patch) | |
tree | 4d85786da1088075f900d214b5904b5542652062 | |
parent | 07c57d4e60083981a3ddcd8ca56b85dbc62c4dbb (diff) | |
download | cpython-398b9f6d6d75628efe03fb4d8dc1aa2df6c35a67.zip cpython-398b9f6d6d75628efe03fb4d8dc1aa2df6c35a67.tar.gz cpython-398b9f6d6d75628efe03fb4d8dc1aa2df6c35a67.tar.bz2 |
Disallow open()ing of directories. Closes SF bug 487277.
-rw-r--r-- | Objects/fileobject.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/Objects/fileobject.c b/Objects/fileobject.c index c8fb214..924ddcf 100644 --- a/Objects/fileobject.c +++ b/Objects/fileobject.c @@ -56,6 +56,32 @@ PyFile_Name(PyObject *f) return ((PyFileObject *)f)->f_name; } +/* On Unix, fopen will succeed for directories. + In Python, there should be no file objects referring to + directories, so we need a check. */ + +static PyFileObject* +dircheck(PyFileObject* f) +{ +#if defined(HAVE_FSTAT) && defined(S_IFDIR) && defined(EISDIR) + struct stat buf; + if (f->f_fp == NULL) + return f; + if (fstat(fileno(f->f_fp), &buf) == 0 && + S_ISDIR(buf.st_mode)) { +#ifdef HAVE_STRERROR + char *msg = strerror(EISDIR); +#else + char *msg = "Is a directory"; +#endif + PyObject *exc = PyObject_CallFunction(PyExc_IOError, "(is)", EISDIR, msg); + PyErr_SetObject(PyExc_IOError, exc); + return NULL; + } +#endif + return f; +} + static PyObject * fill_file_fields(PyFileObject *f, FILE *fp, char *name, char *mode, @@ -77,6 +103,7 @@ fill_file_fields(PyFileObject *f, FILE *fp, char *name, char *mode, if (f->f_name == NULL || f->f_mode == NULL) return NULL; f->f_fp = fp; + f = dircheck(f); return (PyObject *) f; } @@ -130,6 +157,7 @@ open_the_file(PyFileObject *f, char *name, char *mode) PyErr_SetFromErrnoWithFilename(PyExc_IOError, name); f = NULL; } + f = dircheck(f); return (PyObject *)f; } |