| from __future__ import absolute_import |
| from __future__ import print_function |
| from __future__ import unicode_literals |
| |
| import argparse |
| |
| from pre_commit_hooks.util import added_files |
| from pre_commit_hooks.util import cmd_output |
| |
| |
| def lower_set(iterable): |
| return set(x.lower() for x in iterable) |
| |
| |
| def find_conflicting_filenames(filenames): |
| repo_files = set(cmd_output('git', 'ls-files').splitlines()) |
| relevant_files = set(filenames) | added_files() |
| repo_files -= relevant_files |
| retv = 0 |
| |
| # new file conflicts with existing file |
| conflicts = lower_set(repo_files) & lower_set(relevant_files) |
| |
| # new file conflicts with other new file |
| lowercase_relevant_files = lower_set(relevant_files) |
| for filename in set(relevant_files): |
| if filename.lower() in lowercase_relevant_files: |
| lowercase_relevant_files.remove(filename.lower()) |
| else: |
| conflicts.add(filename.lower()) |
| |
| if conflicts: |
| conflicting_files = [ |
| x for x in repo_files | relevant_files |
| if x.lower() in conflicts |
| ] |
| for filename in sorted(conflicting_files): |
| print('Case-insensitivity conflict found: {0}'.format(filename)) |
| retv = 1 |
| |
| return retv |
| |
| |
| def main(argv=None): |
| parser = argparse.ArgumentParser() |
| parser.add_argument( |
| 'filenames', nargs='*', |
| help='Filenames pre-commit believes are changed.' |
| ) |
| |
| args = parser.parse_args(argv) |
| |
| return find_conflicting_filenames(args.filenames) |
| |
| |
| if __name__ == '__main__': |
| exit(main()) |