From 32fcf7b26462f5d51d577f8beda9d49cd3a0f441 Mon Sep 17 00:00:00 2001 From: tuncbkose <48298909+tuncbkose@users.noreply.github.com> Date: Sat, 6 May 2023 20:59:20 +0300 Subject: [PATCH] Moved ensure_dir_exists to FilesWriter (#1987) Co-authored-by: Steven Silvester --- nbconvert/utils/io.py | 18 ------------------ nbconvert/writers/files.py | 25 +++++++++++++++++++------ 2 files changed, 19 insertions(+), 24 deletions(-) diff --git a/nbconvert/utils/io.py b/nbconvert/utils/io.py index 7ca822210..dd402a5a9 100644 --- a/nbconvert/utils/io.py +++ b/nbconvert/utils/io.py @@ -117,21 +117,3 @@ def link_or_copy(src, dst): # Either link isn't supported, or the filesystem doesn't support # linking, or 'src' and 'dst' are on different filesystems. shutil.copy(src, dst) - - -def ensure_dir_exists(path, mode=0o755): - """ensure that a directory exists - - If it doesn't exist, try to create it and protect against a race condition - if another process is doing the same. - - The default permissions are 755, which differ from os.makedirs default of 777. - """ - if not os.path.exists(path): - try: - os.makedirs(path, mode=mode) - except OSError as e: - if e.errno != errno.EEXIST: - raise - elif not os.path.isdir(path): - raise OSError("%r exists but is not a directory" % path) diff --git a/nbconvert/writers/files.py b/nbconvert/writers/files.py index 852496c19..e5021ea94 100644 --- a/nbconvert/writers/files.py +++ b/nbconvert/writers/files.py @@ -3,13 +3,14 @@ # Copyright (c) IPython Development Team. # Distributed under the terms of the Modified BSD License. +import errno import glob import os from pathlib import Path from traitlets import Unicode, observe -from nbconvert.utils.io import ensure_dir_exists, link_or_copy +from nbconvert.utils.io import link_or_copy from .base import WriterBase @@ -38,18 +39,30 @@ class FilesWriter(WriterBase): def _build_directory_changed(self, change): new = change["new"] if new: - ensure_dir_exists(new) + self._makedir(new) def __init__(self, **kw): """Initialize the writer.""" super().__init__(**kw) self._build_directory_changed({"new": self.build_directory}) - def _makedir(self, path): - """Make a directory if it doesn't already exist""" - if path: + def _makedir(self, path, mode=0o755): + """ensure that a directory exists + + If it doesn't exist, try to create it and protect against a race condition + if another process is doing the same. + + The default permissions are 755, which differ from os.makedirs default of 777. + """ + if not os.path.exists(path): self.log.info("Making directory %s", path) - ensure_dir_exists(path) + try: + os.makedirs(path, mode=mode) + except OSError as e: + if e.errno != errno.EEXIST: + raise + elif not os.path.isdir(path): + raise OSError("%r exists but is not a directory" % path) def _write_items(self, items, build_dir): """Write a dict containing filename->binary data"""