diff options
author | Harmen Stoppels <me@harmenstoppels.nl> | 2024-11-06 11:49:14 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-11-06 11:49:14 +0100 |
commit | a31c525778773b8c6a6fc35617454d954a05d74d (patch) | |
tree | 227cc32fb980edf778d7432d91276dd2c52d74fb /lib | |
parent | 2aa5a1643321d57326540e548d98b790d375b47d (diff) | |
download | spack-a31c525778773b8c6a6fc35617454d954a05d74d.tar.gz spack-a31c525778773b8c6a6fc35617454d954a05d74d.tar.bz2 spack-a31c525778773b8c6a6fc35617454d954a05d74d.tar.xz spack-a31c525778773b8c6a6fc35617454d954a05d74d.zip |
llnl.util.filesystem.find: restore old error handling (#47463)
Diffstat (limited to 'lib')
-rw-r--r-- | lib/spack/llnl/util/filesystem.py | 31 |
1 files changed, 11 insertions, 20 deletions
diff --git a/lib/spack/llnl/util/filesystem.py b/lib/spack/llnl/util/filesystem.py index b63b6e94b3..24055c902b 100644 --- a/lib/spack/llnl/util/filesystem.py +++ b/lib/spack/llnl/util/filesystem.py @@ -1741,6 +1741,11 @@ def find(root, files, recursive=True, max_depth: Optional[int] = None): return result +def _log_file_access_issue(e: OSError, path: str) -> None: + errno_name = errno.errorcode.get(e.errno, "UNKNOWN") + tty.debug(f"find must skip {path}: {errno_name} {e}") + + @system_path_filter(arg_slice=slice(1)) def find_max_depth(root, globs, max_depth: Optional[int] = None): """Given a set of non-recursive glob file patterns, finds all @@ -1754,19 +1759,10 @@ def find_max_depth(root, globs, max_depth: Optional[int] = None): If ``globs`` is a list, files matching earlier entries are placed in the return value before files matching later entries. """ - # If root doesn't exist, then we say we found nothing. If it - # exists but is not a dir, we assume the user would want to - # know; likewise if it exists but we do not have permission to - # access it. try: stat_root = os.stat(root) - except OSError as e: - if e.errno == errno.ENOENT: - return [] - else: - raise - if not stat.S_ISDIR(stat_root.st_mode): - raise ValueError(f"{root} is not a directory") + except OSError: + return [] if max_depth is None: max_depth = sys.maxsize @@ -1790,10 +1786,6 @@ def find_max_depth(root, globs, max_depth: Optional[int] = None): # https://github.com/python/cpython/blob/3.9/Python/fileutils.c return (stat_info.st_ino, stat_info.st_dev) - def _log_file_access_issue(e): - errno_name = errno.errorcode.get(e.errno, "UNKNOWN") - tty.debug(f"find must skip {dir_entry.path}: {errno_name} {str(e)}") - visited_dirs = set([_dir_id(stat_root)]) # Each queue item stores the depth and path @@ -1808,9 +1800,8 @@ def find_max_depth(root, globs, max_depth: Optional[int] = None): depth, next_dir = dir_queue.pop() try: dir_iter = os.scandir(next_dir) - except OSError: - # Most commonly, this would be a permissions issue, for - # example if we are scanning an external directory like /usr + except OSError as e: + _log_file_access_issue(e, next_dir) continue with dir_iter: @@ -1821,7 +1812,7 @@ def find_max_depth(root, globs, max_depth: Optional[int] = None): except OSError as e: # Possible permission issue, or a symlink that cannot # be resolved (ELOOP). - _log_file_access_issue(e) + _log_file_access_issue(e, dir_entry.path) continue if it_is_a_dir and (depth < max_depth): @@ -1837,7 +1828,7 @@ def find_max_depth(root, globs, max_depth: Optional[int] = None): else: stat_info = dir_entry.stat(follow_symlinks=True) except OSError as e: - _log_file_access_issue(e) + _log_file_access_issue(e, dir_entry.path) continue dir_id = _dir_id(stat_info) |