2022-04-14 14:02:20 +02:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
#
|
|
|
|
# Copyright (c) 2020-2022 The Bitcoin Core developers
|
|
|
|
# Distributed under the MIT software license, see the accompanying
|
|
|
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#
|
|
|
|
# Linter to check that commit messages have a new line before the body
|
|
|
|
# or no body at all
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from subprocess import check_output
|
|
|
|
|
|
|
|
|
|
|
|
def parse_args():
|
|
|
|
"""Parse command line arguments."""
|
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description="""
|
|
|
|
Linter to check that commit messages have a new line before
|
|
|
|
the body or no body at all.
|
|
|
|
""",
|
|
|
|
epilog=f"""
|
|
|
|
You can manually set the commit-range with the COMMIT_RANGE
|
2024-03-15 15:00:13 +01:00
|
|
|
environment variable (e.g. "COMMIT_RANGE='HEAD~n..HEAD'
|
|
|
|
{sys.argv[0]}") for the last 'n' commits.
|
2022-04-14 14:02:20 +02:00
|
|
|
""")
|
|
|
|
return parser.parse_args()
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
2024-03-15 15:00:13 +01:00
|
|
|
parse_args()
|
2022-04-14 14:02:20 +02:00
|
|
|
exit_code = 0
|
|
|
|
|
2024-03-15 15:00:13 +01:00
|
|
|
assert os.getenv("COMMIT_RANGE") # E.g. COMMIT_RANGE='HEAD~n..HEAD'
|
|
|
|
commit_range = os.getenv("COMMIT_RANGE")
|
2022-04-14 14:02:20 +02:00
|
|
|
|
2024-12-11 23:10:11 +01:00
|
|
|
commit_hashes = check_output(["git", "-c", "log.showSignature=false", "log", commit_range, "--format=%H"], text=True, encoding="utf8").splitlines()
|
2022-04-14 14:02:20 +02:00
|
|
|
|
|
|
|
for hash in commit_hashes:
|
2024-12-11 23:10:11 +01:00
|
|
|
commit_info = check_output(["git", "-c", "log.showSignature=false", "log", "--format=%B", "-n", "1", hash], text=True, encoding="utf8").splitlines()
|
2022-04-14 14:02:20 +02:00
|
|
|
if len(commit_info) >= 2:
|
|
|
|
if commit_info[1]:
|
|
|
|
print(f"The subject line of commit hash {hash} is followed by a non-empty line. Subject lines should always be followed by a blank line.")
|
|
|
|
exit_code = 1
|
|
|
|
|
|
|
|
sys.exit(exit_code)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|