diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-02-13 00:37:29 +0200 |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-02-13 00:37:29 +0200 |
commit | ff7fef9601d15cdf274b4b984c7638f33002e879 (patch) | |
tree | 3daf809b893ec457ef45c321e8319814251f343a /Lib/tempfile.py | |
parent | b52d432a780fdfb861000c95eb2bbb594fda9900 (diff) | |
parent | f6b361ec1a10b93ff8b927b400ca1777429bb23a (diff) | |
download | cpython-git-ff7fef9601d15cdf274b4b984c7638f33002e879.tar.gz |
Issue #16800: tempfile.gettempdir() no longer left temporary files when
the disk is full. Original patch by Amir Szekely.
Diffstat (limited to 'Lib/tempfile.py')
-rw-r--r-- | Lib/tempfile.py | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/Lib/tempfile.py b/Lib/tempfile.py index 0cc5c04405..3c3aec1eed 100644 --- a/Lib/tempfile.py +++ b/Lib/tempfile.py @@ -172,11 +172,14 @@ def _get_default_tempdir(): filename = _os.path.join(dir, name) try: fd = _os.open(filename, _bin_openflags, 0o600) - fp = _io.open(fd, 'wb') - fp.write(b'blat') - fp.close() - _os.unlink(filename) - del fp, fd + try: + try: + fp = _io.open(fd, 'wb', buffering=0, closefd=False) + fp.write(b'blat') + finally: + _os.close(fd) + finally: + _os.unlink(filename) return dir except FileExistsError: pass |