]>
git.madduck.net Git - etc/vim.git/blobdiff - black.py
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
"silence those with 2>/dev/null."
),
)
"silence those with 2>/dev/null."
),
)
+@click.option(
+ "-v",
+ "--verbose",
+ is_flag=True,
+ help=(
+ "Also emit messages to stderr about files that were not changed or were "
+ "ignored due to --exclude=."
+ ),
+)
@click.version_option(version=__version__)
@click.argument(
"src",
@click.version_option(version=__version__)
@click.argument(
"src",
py36: bool,
skip_string_normalization: bool,
quiet: bool,
py36: bool,
skip_string_normalization: bool,
quiet: bool,
include: str,
exclude: str,
src: List[str],
include: str,
exclude: str,
src: List[str],
mode = FileMode.from_configuration(
py36=py36, pyi=pyi, skip_string_normalization=skip_string_normalization
)
mode = FileMode.from_configuration(
py36=py36, pyi=pyi, skip_string_normalization=skip_string_normalization
)
- report = Report(check=check, quiet=quiet)
+ report = Report(check=check, quiet=quiet, verbose=verbose )
sources: List[Path] = []
try:
include_regex = re.compile(include)
sources: List[Path] = []
try:
include_regex = re.compile(include)
p = Path(s)
if p.is_dir():
sources.extend(
p = Path(s)
if p.is_dir():
sources.extend(
- gen_python_files_in_dir(p, root, include_regex, exclude_regex)
+ gen_python_files_in_dir(p, root, include_regex, exclude_regex, report )
)
elif p.is_file() or s == "-":
# if a file was explicitly given, we don't care about its extension
)
elif p.is_file() or s == "-":
# if a file was explicitly given, we don't care about its extension
def gen_python_files_in_dir(
def gen_python_files_in_dir(
- path: Path, root: Path, include: Pattern[str], exclude: Pattern[str]
+ path: Path,
+ root: Path,
+ include: Pattern[str],
+ exclude: Pattern[str],
+ report: "Report",
) -> Iterator[Path]:
"""Generate all files under `path` whose paths are not excluded by the
`exclude` regex, but are included by the `include` regex.
) -> Iterator[Path]:
"""Generate all files under `path` whose paths are not excluded by the
`exclude` regex, but are included by the `include` regex.
+
+ `report` is where output about exclusions goes.
"""
assert root.is_absolute(), f"INTERNAL ERROR: `root` must be absolute but is {root}"
for child in path.iterdir():
"""
assert root.is_absolute(), f"INTERNAL ERROR: `root` must be absolute but is {root}"
for child in path.iterdir():
- normalized_path = child.resolve().relative_to(root).as_posix()
+ normalized_path = "/" + child.resolve().relative_to(root).as_posix()
if child.is_dir():
normalized_path += "/"
exclude_match = exclude.search(normalized_path)
if exclude_match and exclude_match.group(0):
if child.is_dir():
normalized_path += "/"
exclude_match = exclude.search(normalized_path)
if exclude_match and exclude_match.group(0):
+ report.path_ignored(child, f"matches --exclude={exclude.pattern}")
continue
if child.is_dir():
continue
if child.is_dir():
- yield from gen_python_files_in_dir(child, root, include, exclude)
+ yield from gen_python_files_in_dir(child, root, include, exclude, report )
elif child.is_file():
include_match = include.search(normalized_path)
elif child.is_file():
include_match = include.search(normalized_path)
check: bool = False
quiet: bool = False
check: bool = False
quiet: bool = False
change_count: int = 0
same_count: int = 0
failure_count: int = 0
change_count: int = 0
same_count: int = 0
failure_count: int = 0
"""Increment the counter for successful reformatting. Write out a message."""
if changed is Changed.YES:
reformatted = "would reformat" if self.check else "reformatted"
"""Increment the counter for successful reformatting. Write out a message."""
if changed is Changed.YES:
reformatted = "would reformat" if self.check else "reformatted"
+ if self.verbose or not self.quiet:
out(f"{reformatted} {src}")
self.change_count += 1
else:
out(f"{reformatted} {src}")
self.change_count += 1
else:
if changed is Changed.NO:
msg = f"{src} already well formatted, good job."
else:
if changed is Changed.NO:
msg = f"{src} already well formatted, good job."
else:
err(f"error: cannot format {src}: {message}")
self.failure_count += 1
err(f"error: cannot format {src}: {message}")
self.failure_count += 1
+ def path_ignored(self, path: Path, message: str) -> None:
+ if self.verbose:
+ out(f"{path} ignored: {message}", bold=False)
+
@property
def return_code(self) -> int:
"""Return the exit code that the app should use.
@property
def return_code(self) -> int:
"""Return the exit code that the app should use.