diff options
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/tempfile.py | 59 |
1 files changed, 41 insertions, 18 deletions
diff --git a/Lib/tempfile.py b/Lib/tempfile.py index 793c23f..db750d4 100644 --- a/Lib/tempfile.py +++ b/Lib/tempfile.py @@ -1,19 +1,44 @@ # Temporary file name allocation +# +# XXX This tries to be not UNIX specific, but I don't know beans about +# how to choose a temp directory or filename on MS-DOS or other +# systems so it may have to be changed... -import posix -import path +import os -# Changeable parameters (by clients!)... -tempdir = '/usr/tmp' -template = '@' +# Parameters that the caller may set to override the defaults -# Use environment variable $TMPDIR to override default tempdir. +tempdir = None +template = None -if posix.environ.has_key('TMPDIR'): - # XXX Could check that it's a writable directory... - tempdir = posix.environ['TMPDIR'] + +# Function to calculate the directory to use + +def gettempdir(): + global tempdir + if tempdir == None: + try: + tempdir = os.environ['TMPDIR'] + except (KeyError, AttributeError): + if os.name == 'posix': + tempdir = '/usr/tmp' # XXX Why not /tmp? + else: + tempdir = os.getcwd() # XXX Is this OK? + return tempdir + + +# Function to calculate a prefix of the filename to use + +def gettempprefix(): + global template + if template == None: + if os.name == 'posix': + template = '@' + `os.getpid()` + '.' + else: + template = 'tmp' # XXX might choose a better one + return template # Counter for generating unique names @@ -21,16 +46,14 @@ if posix.environ.has_key('TMPDIR'): counter = 0 -# User-callable function -# XXX Should this have a parameter, like C's mktemp()? -# XXX Should we instead use the model of Standard C's tempnam()? -# XXX By all means, avoid a mess with four different functions like C... +# User-callable function to return a unique temporary file name def mktemp(): global counter + dir = gettempdir() + pre = gettempprefix() while 1: - counter = counter+1 - file = tempdir+'/'+template+`posix.getpid()`+'.'+`counter` - if not path.exists(file): - break - return file + counter = counter + 1 + file = os.path.join(dir, pre + `counter`) + if not os.path.exists(file): + return file |