Source code for nxpy.core.temp_file

# nxpy.core package ----------------------------------------------------------

# Copyright Nicola Musatti 2010 - 2014
# Use, modification, and distribution are subject to the Boost Software
# License, Version 1.0. (See accompanying file LICENSE.txt or copy at
# http://www.boost.org/LICENSE_1_0.txt)

# See http://nxpy.sourceforge.net for library home page. ---------------------

r"""
Temporary files and directories.

Requires at least Python 2.6

"""

from __future__ import absolute_import

import logging
import os
import shutil
import stat
import tempfile

import nxpy.core.file_object
import nxpy.core.path
import nxpy.core.past


[docs]class TempFile(nxpy.core.file_object.WritableFileObject): r"""A temporary file that implements the context manager protocol. Wrap a :py:func:`tempfile.NamedTemporaryFile` generated file-like object, to ensure it is not deleted on close, but rather when the underlying context is closed. """
[docs] def __init__(self, *args, **kwargs): r"""Create a temporary file with the given arguments.""" # Python 2.5 compatible syntax. Doesn't work, but ensures that tests are skipped rather # than broken. # file = tempfile.NamedTemporaryFile(*args, delete=False, **kwargs) kwargs["delete"] = False if nxpy.core.past.V_2_7.at_most() and "encoding" in kwargs: del kwargs["encoding"] file_ = tempfile.NamedTemporaryFile(*args, **kwargs) super(TempFile, self).__init__(file_)
@property def name(self): r"""Return the actual file name.""" return self._file.name def __enter__(self): return self def __exit__(self, exc_type, exc_val, exc_tb): self._file.close() os.remove(self._file.name) return False
[docs]class TempDir(object): r"""A temporary directory that implements the context manager protocol. The directory is removed when the context is exited from. Uses :py:func:`tempfile.mkdtemp` to create the actual directory. """
[docs] def __init__(self, *args, **kwargs): r"""Create a temporary directory with the given arguments.""" self.dir = tempfile.mkdtemp(*args, **kwargs) mode = os.stat(self.dir).st_mode os.chmod(self.dir, mode | stat.S_IWRITE)
@property def name(self): r"""Return the directory name.""" return self.dir def __enter__(self): return self def __exit__(self, exc_type, exc_val, exc_tb): nxpy.core.path.blasttree(self.dir) return False