Skip to content

Commit

Permalink
catch errors on calculating the relative to root file path
Browse files Browse the repository at this point in the history
  • Loading branch information
dankrzeminski32 committed Jan 22, 2024
1 parent 7a51588 commit 24395f8
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 9 deletions.
6 changes: 5 additions & 1 deletion src/black/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@
find_user_pyproject_toml,
gen_python_files,
get_gitignore,
get_root_relative_path,
normalize_path_maybe_ignore,
parse_pyproject_toml,
path_is_excluded,
Expand Down Expand Up @@ -700,7 +701,10 @@ def get_sources(

# Compare the logic here to the logic in `gen_python_files`.
if is_stdin or path.is_file():
root_relative_path = path.absolute().relative_to(root).as_posix()
root_relative_path = get_root_relative_path(path, root, report)

if root_relative_path is None:
continue

root_relative_path = "/" + root_relative_path

Expand Down
24 changes: 16 additions & 8 deletions src/black/files.py
Original file line number Diff line number Diff line change
Expand Up @@ -259,14 +259,7 @@ def normalize_path_maybe_ignore(
try:
abspath = path if path.is_absolute() else Path.cwd() / path
normalized_path = abspath.resolve()
try:
root_relative_path = normalized_path.relative_to(root).as_posix()
except ValueError:
if report:
report.path_ignored(
path, f"is a symbolic link that points outside {root}"
)
return None
root_relative_path = get_root_relative_path(normalized_path, root, report)

except OSError as e:
if report:
Expand All @@ -276,6 +269,21 @@ def normalize_path_maybe_ignore(
return root_relative_path


def get_root_relative_path(
path: Path,
root: Path,
report: Optional[Report] = None,
) -> Optional[str]:
"""Returns the file path relative to the 'root' directory"""
try:
root_relative_path = path.absolute().relative_to(root).as_posix()
except ValueError:
if report:
report.path_ignored(path, f"is a symbolic link that points outside {root}")
return None
return root_relative_path


def _path_is_ignored(
root_relative_path: str,
root: Path,
Expand Down

0 comments on commit 24395f8

Please sign in to comment.