From 769c0bd93878652f0d4fc4362937d303cd90abae Mon Sep 17 00:00:00 2001 From: rishabhjain1712 Date: Mon, 2 Sep 2024 23:06:22 +0530 Subject: [PATCH 1/2] fix pre-commit-2332 --- pre_commit_hooks/check_json.py | 48 ++++++++++++++++++++++++++++------ 1 file changed, 40 insertions(+), 8 deletions(-) diff --git a/pre_commit_hooks/check_json.py b/pre_commit_hooks/check_json.py index 6a679fee..51e0f21c 100644 --- a/pre_commit_hooks/check_json.py +++ b/pre_commit_hooks/check_json.py @@ -2,8 +2,8 @@ import argparse import json -from typing import Any -from typing import Sequence +import re +from typing import Any, Sequence def raise_duplicate_keys( @@ -17,6 +17,29 @@ def raise_duplicate_keys( d[key] = val return d +def check_mixed_indentation(content: str, filename: str) -> bool: + """ + Checks a string content for mixed indentation (tabs and spaces) in leading whitespace. + + Args: + content (str): The content of the file to check. + filename (str): The name of the file being checked (for reporting purposes). + + Returns: + bool: True if mixed indentation is found, False otherwise. + """ + found_mixed = False + + for i, line in enumerate(content.splitlines(), 1): + # Determine leading whitespace + leading_whitespace = line[:len(line) - len(line.lstrip())] + + # Check if both tabs and spaces are present in leading whitespace + if ' ' in leading_whitespace and '\t' in leading_whitespace: + print(f"{filename}: Mixed indentation (tabs and spaces) found on line {i}") + found_mixed = True + + return not found_mixed def main(argv: Sequence[str] | None = None) -> int: parser = argparse.ArgumentParser() @@ -25,12 +48,21 @@ def main(argv: Sequence[str] | None = None) -> int: retval = 0 for filename in args.filenames: - with open(filename, 'rb') as f: - try: - json.load(f, object_pairs_hook=raise_duplicate_keys) - except ValueError as exc: - print(f'{filename}: Failed to json decode ({exc})') - retval = 1 + with open(filename, 'r') as f: + content = f.read() + + # Check for mixed indentation first + if not check_mixed_indentation(content, filename): + retval = 1 + continue + + # Then, attempt to parse the JSON + try: + json.loads(content, object_pairs_hook=raise_duplicate_keys) + except ValueError as exc: + print(f'{filename}: Failed to json decode ({exc})') + retval = 1 + return retval From 846d3cc2d641a2560a4a1bd47fe2a256e2304678 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 2 Sep 2024 17:39:02 +0000 Subject: [PATCH 2/2] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- pre_commit_hooks/check_json.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/pre_commit_hooks/check_json.py b/pre_commit_hooks/check_json.py index 51e0f21c..ef4629a2 100644 --- a/pre_commit_hooks/check_json.py +++ b/pre_commit_hooks/check_json.py @@ -3,7 +3,8 @@ import argparse import json import re -from typing import Any, Sequence +from typing import Any +from typing import Sequence def raise_duplicate_keys( @@ -17,6 +18,7 @@ def raise_duplicate_keys( d[key] = val return d + def check_mixed_indentation(content: str, filename: str) -> bool: """ Checks a string content for mixed indentation (tabs and spaces) in leading whitespace. @@ -41,6 +43,7 @@ def check_mixed_indentation(content: str, filename: str) -> bool: return not found_mixed + def main(argv: Sequence[str] | None = None) -> int: parser = argparse.ArgumentParser() parser.add_argument('filenames', nargs='*', help='Filenames to check.') @@ -48,7 +51,7 @@ def main(argv: Sequence[str] | None = None) -> int: retval = 0 for filename in args.filenames: - with open(filename, 'r') as f: + with open(filename) as f: content = f.read() # Check for mixed indentation first