mirror of
https://github.com/pre-commit/pre-commit-hooks.git
synced 2026-04-08 12:34:17 +00:00
Add hook to check the number of allowed lines
This commit is contained in:
parent
1ca4ceba96
commit
9d0b99f39f
4 changed files with 72 additions and 0 deletions
|
|
@ -58,6 +58,11 @@ Attempts to load all json files to verify syntax.
|
||||||
#### `check-merge-conflict`
|
#### `check-merge-conflict`
|
||||||
Check for files that contain merge conflict strings.
|
Check for files that contain merge conflict strings.
|
||||||
|
|
||||||
|
#### `check-number-of-lines-count`
|
||||||
|
Check if number of lines of a file is greater than a threshold. You can
|
||||||
|
configure this with the following commandline option:
|
||||||
|
- `--max-lines N` - maximum number of lines allowed in a file.
|
||||||
|
|
||||||
#### `check-shebang-scripts-are-executable`
|
#### `check-shebang-scripts-are-executable`
|
||||||
Checks that scripts with shebangs are executable.
|
Checks that scripts with shebangs are executable.
|
||||||
|
|
||||||
|
|
|
||||||
35
pre_commit_hooks/check_number_of_lines_count.py
Executable file
35
pre_commit_hooks/check_number_of_lines_count.py
Executable file
|
|
@ -0,0 +1,35 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
import argparse
|
||||||
|
from typing import Optional
|
||||||
|
from typing import Sequence
|
||||||
|
|
||||||
|
|
||||||
|
def main(argv: Optional[Sequence[str]] = None) -> int:
|
||||||
|
parser = argparse.ArgumentParser()
|
||||||
|
parser.add_argument('filenames', nargs='*')
|
||||||
|
parser.add_argument(
|
||||||
|
'--max-lines',
|
||||||
|
default=30,
|
||||||
|
type=int,
|
||||||
|
action='store',
|
||||||
|
help='Maximum allowable number of lines (default: 30)',
|
||||||
|
)
|
||||||
|
args = parser.parse_args(argv)
|
||||||
|
|
||||||
|
retcode = 0
|
||||||
|
for filename in args.filenames:
|
||||||
|
with open(filename) as file:
|
||||||
|
file_content = file.readlines()
|
||||||
|
number_of_lines = len(file_content)
|
||||||
|
if number_of_lines > args.max_lines:
|
||||||
|
print(
|
||||||
|
f'{filename} ({number_of_lines} lines) exceeds '
|
||||||
|
f'{args.max_lines} lines.',
|
||||||
|
)
|
||||||
|
retcode = 1
|
||||||
|
|
||||||
|
return retcode
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
exit(main())
|
||||||
|
|
@ -43,6 +43,7 @@ console_scripts =
|
||||||
check-executables-have-shebangs = pre_commit_hooks.check_executables_have_shebangs:main
|
check-executables-have-shebangs = pre_commit_hooks.check_executables_have_shebangs:main
|
||||||
check-json = pre_commit_hooks.check_json:main
|
check-json = pre_commit_hooks.check_json:main
|
||||||
check-merge-conflict = pre_commit_hooks.check_merge_conflict:main
|
check-merge-conflict = pre_commit_hooks.check_merge_conflict:main
|
||||||
|
check-number-of-lines-count = check_number_of_lines_count:main
|
||||||
check-shebang-scripts-are-executable = pre_commit_hooks.check_shebang_scripts_are_executable:main
|
check-shebang-scripts-are-executable = pre_commit_hooks.check_shebang_scripts_are_executable:main
|
||||||
check-symlinks = pre_commit_hooks.check_symlinks:main
|
check-symlinks = pre_commit_hooks.check_symlinks:main
|
||||||
check-toml = pre_commit_hooks.check_toml:main
|
check-toml = pre_commit_hooks.check_toml:main
|
||||||
|
|
|
||||||
31
tests/check_number_of_lines_count_test.py
Normal file
31
tests/check_number_of_lines_count_test.py
Normal file
|
|
@ -0,0 +1,31 @@
|
||||||
|
from pre_commit_hooks.check_number_of_lines_count import main
|
||||||
|
|
||||||
|
|
||||||
|
def test_number_of_lines_count_bad(tmpdir):
|
||||||
|
max_lines = 30
|
||||||
|
line_contents = []
|
||||||
|
filename = tmpdir.join('lines_count_bad')
|
||||||
|
|
||||||
|
for line_number in range(max_lines + 1):
|
||||||
|
line_contents.append(f'I am the {line_number+1}. line!')
|
||||||
|
|
||||||
|
with open(filename, 'w') as file:
|
||||||
|
file.write('\n'.join(line_contents))
|
||||||
|
|
||||||
|
ret = main([str(filename), f'--max-lines={max_lines}'])
|
||||||
|
assert ret == 1
|
||||||
|
|
||||||
|
|
||||||
|
def test_number_of_lines_count_good(tmpdir):
|
||||||
|
max_lines = 30
|
||||||
|
line_contents = []
|
||||||
|
filename = tmpdir.join('lines_count_good')
|
||||||
|
|
||||||
|
for line_number in range(max_lines):
|
||||||
|
line_contents.append(f'I am the {line_number+1}. line!')
|
||||||
|
|
||||||
|
with open(filename, 'w') as file:
|
||||||
|
file.write('\n'.join(line_contents))
|
||||||
|
|
||||||
|
ret = main([str(filename), f'--max-lines={max_lines}'])
|
||||||
|
assert ret == 0
|
||||||
Loading…
Add table
Add a link
Reference in a new issue