diff options
author | Peter Astrand <astrand@lysator.liu.se> | 2004-11-07 14:15:28 (GMT) |
---|---|---|
committer | Peter Astrand <astrand@lysator.liu.se> | 2004-11-07 14:15:28 (GMT) |
commit | f8e74b12b00401b9cd6322fc339a1b9111e944df (patch) | |
tree | 51c81e79cb15554e54ca3a0deb5ad2645f5aeeed | |
parent | 4f802ac2b6dfbf28de270dafcf11f8d71a607b81 (diff) | |
download | cpython-f8e74b12b00401b9cd6322fc339a1b9111e944df.zip cpython-f8e74b12b00401b9cd6322fc339a1b9111e944df.tar.gz cpython-f8e74b12b00401b9cd6322fc339a1b9111e944df.tar.bz2 |
If close() fails in file_dealloc, then print an error message to
stderr. close() can fail if the user is out-of-quota, for example.
Fixes #959379.
-rw-r--r-- | Objects/fileobject.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/Objects/fileobject.c b/Objects/fileobject.c index 34f28e3..c08345c 100644 --- a/Objects/fileobject.c +++ b/Objects/fileobject.c @@ -300,12 +300,19 @@ static void drop_readahead(PyFileObject *); static void file_dealloc(PyFileObject *f) { + int sts = 0; if (f->weakreflist != NULL) PyObject_ClearWeakRefs((PyObject *) f); if (f->f_fp != NULL && f->f_close != NULL) { Py_BEGIN_ALLOW_THREADS - (*f->f_close)(f->f_fp); + sts = (*f->f_close)(f->f_fp); Py_END_ALLOW_THREADS + if (sts == EOF) +#ifdef HAVE_STRERROR + PySys_WriteStderr("close failed: [Errno %d] %s\n", errno, strerror(errno)); +#else + PySys_WriteStderr("close failed: [Errno %d]\n", errno); +#endif } PyMem_Free(f->f_setbuf); Py_XDECREF(f->f_name); |