2008-07-27 06:48:51 +08:00
|
|
|
"""
|
|
|
|
The temp module provides a NamedTemporaryFile that can be re-opened on any
|
|
|
|
platform. Most platforms use the standard Python tempfile.TemporaryFile class,
|
|
|
|
but MS Windows users are given a custom class.
|
|
|
|
|
|
|
|
This is needed because in Windows NT, the default implementation of
|
|
|
|
NamedTemporaryFile uses the O_TEMPORARY flag, and thus cannot be reopened [1].
|
|
|
|
|
|
|
|
1: http://mail.python.org/pipermail/python-list/2005-December/359474.html
|
|
|
|
"""
|
|
|
|
|
|
|
|
import os
|
|
|
|
import tempfile
|
2009-05-08 23:08:09 +08:00
|
|
|
from django.core.files.utils import FileProxyMixin
|
2008-07-27 06:48:51 +08:00
|
|
|
|
|
|
|
__all__ = ('NamedTemporaryFile', 'gettempdir',)
|
|
|
|
|
|
|
|
if os.name == 'nt':
|
2009-05-08 23:08:09 +08:00
|
|
|
class TemporaryFile(FileProxyMixin):
|
2008-07-27 06:48:51 +08:00
|
|
|
"""
|
|
|
|
Temporary file object constructor that works in Windows and supports
|
|
|
|
reopening of the temporary file in windows.
|
|
|
|
"""
|
|
|
|
def __init__(self, mode='w+b', bufsize=-1, suffix='', prefix='',
|
|
|
|
dir=None):
|
|
|
|
fd, name = tempfile.mkstemp(suffix=suffix, prefix=prefix,
|
|
|
|
dir=dir)
|
|
|
|
self.name = name
|
2008-08-24 01:56:02 +08:00
|
|
|
self.file = os.fdopen(fd, mode, bufsize)
|
|
|
|
self.close_called = False
|
|
|
|
|
|
|
|
# Because close can be called during shutdown
|
|
|
|
# we need to cache os.unlink and access it
|
|
|
|
# as self.unlink only
|
|
|
|
unlink = os.unlink
|
|
|
|
|
|
|
|
def close(self):
|
|
|
|
if not self.close_called:
|
|
|
|
self.close_called = True
|
|
|
|
try:
|
|
|
|
self.file.close()
|
|
|
|
except (OSError, IOError):
|
|
|
|
pass
|
|
|
|
try:
|
|
|
|
self.unlink(self.name)
|
|
|
|
except (OSError):
|
|
|
|
pass
|
2008-07-27 06:48:51 +08:00
|
|
|
|
2013-09-07 02:23:50 +08:00
|
|
|
@property
|
|
|
|
def closed(self):
|
|
|
|
"""
|
|
|
|
This attribute needs to be accessible in certain situations,
|
|
|
|
because this class is supposed to mock the API of the class
|
|
|
|
tempfile.NamedTemporaryFile in the Python standard library.
|
|
|
|
"""
|
|
|
|
return self.file.closed
|
|
|
|
|
2008-07-27 06:48:51 +08:00
|
|
|
def __del__(self):
|
2008-08-24 01:56:02 +08:00
|
|
|
self.close()
|
|
|
|
|
2008-07-27 06:48:51 +08:00
|
|
|
NamedTemporaryFile = TemporaryFile
|
|
|
|
else:
|
|
|
|
NamedTemporaryFile = tempfile.NamedTemporaryFile
|
|
|
|
|
|
|
|
gettempdir = tempfile.gettempdir
|