This repository has been archived on 2023-06-07. You can view files and clone it, but cannot push or open issues or pull requests.
errsy/main.py
Mylloon cc24d047b4
- add some type annotation
- resolve an issue with directories
2023-05-29 17:17:24 +02:00

67 lines
2.1 KiB
Python

import re
import subprocess
import sys
from src.errors import ClangError
from src.utils import analyze_args
def clang_format(file_path) -> str:
command = ["clang-format", "--dry-run", file_path]
try:
output = subprocess.check_output(command, stderr=subprocess.STDOUT, text=True)
except subprocess.CalledProcessError as e:
output = e.output
except FileNotFoundError as e:
print(f"Commande non trouvé : {e.filename}", file=sys.stderr)
print(
"clang est requis pour utilisé ce programme, installé-le via "
f"votre gestionnaire de paquet : {e.filename}",
file=sys.stderr,
)
exit(1)
return output
def parse_clang_format_output(output) -> list[ClangError]:
error_pattern = (
r"(?P<filename>.+):(?P<line_number>\d+):(?P<column_number>\d+):"
r" warning: code should be clang-formatted \[(?P<warning_message>.+)\]"
)
error_matches = re.finditer(error_pattern, output)
errors = []
for error_match in error_matches:
filename = error_match.group("filename")
line_number = int(error_match.group("line_number"))
column_number = int(error_match.group("column_number"))
warning_message = error_match.group("warning_message")
errors.append(
ClangError(
filename,
line_number,
column_number,
warning_message[1:],
)
)
return errors
if __name__ == "__main__":
files = analyze_args(sys.argv[1:])
for file in files:
clang_format_output = clang_format(file)
parsed_output = parse_clang_format_output(clang_format_output)
if parsed_output:
for error in parsed_output:
print(
f"Avertissement dans {error.filename} "
f"à la ligne {error.line_number}, "
f"caractère {error.column_number} : {error.warning_message}"
)
else:
print(f"Aucun avertissement trouvé dans {file}.")