diff options
| author | Devtools Arcadia <[email protected]> | 2022-02-07 18:08:42 +0300 | 
|---|---|---|
| committer | Devtools Arcadia <[email protected]> | 2022-02-07 18:08:42 +0300 | 
| commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
| tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /contrib/python/ipython/py3/IPython/utils/tempdir.py | |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'contrib/python/ipython/py3/IPython/utils/tempdir.py')
| -rw-r--r-- | contrib/python/ipython/py3/IPython/utils/tempdir.py | 57 | 
1 files changed, 57 insertions, 0 deletions
| diff --git a/contrib/python/ipython/py3/IPython/utils/tempdir.py b/contrib/python/ipython/py3/IPython/utils/tempdir.py new file mode 100644 index 00000000000..98f6aeb3c6b --- /dev/null +++ b/contrib/python/ipython/py3/IPython/utils/tempdir.py @@ -0,0 +1,57 @@ +""" This module contains classes - NamedFileInTemporaryDirectory, TemporaryWorkingDirectory. + +These classes add extra features such as creating a named file in temporary directory and +creating a context manager for the working directory which is also temporary. +""" + +import os as _os +from tempfile import TemporaryDirectory + + +class NamedFileInTemporaryDirectory(object): + +    def __init__(self, filename, mode='w+b', bufsize=-1, **kwds): +        """ +        Open a file named `filename` in a temporary directory. + +        This context manager is preferred over `NamedTemporaryFile` in +        stdlib `tempfile` when one needs to reopen the file. + +        Arguments `mode` and `bufsize` are passed to `open`. +        Rest of the arguments are passed to `TemporaryDirectory`. + +        """ +        self._tmpdir = TemporaryDirectory(**kwds) +        path = _os.path.join(self._tmpdir.name, filename) +        self.file = open(path, mode, bufsize) + +    def cleanup(self): +        self.file.close() +        self._tmpdir.cleanup() + +    __del__ = cleanup + +    def __enter__(self): +        return self.file + +    def __exit__(self, type, value, traceback): +        self.cleanup() + + +class TemporaryWorkingDirectory(TemporaryDirectory): +    """ +    Creates a temporary directory and sets the cwd to that directory. +    Automatically reverts to previous cwd upon cleanup. +    Usage example: + +        with TemporaryWorkingDirectory() as tmpdir: +            ... +    """ +    def __enter__(self): +        self.old_wd = _os.getcwd() +        _os.chdir(self.name) +        return super(TemporaryWorkingDirectory, self).__enter__() + +    def __exit__(self, exc, value, tb): +        _os.chdir(self.old_wd) +        return super(TemporaryWorkingDirectory, self).__exit__(exc, value, tb) | 
