aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2019-03-30 15:01:24 -0400
committerDrew DeVault <sir@cmpwn.com>2019-03-30 15:01:24 -0400
commit411e247a80302bac1137c81d7fa793f7ddca9a0e (patch)
tree1e802f2d98b1a582f02c69fb3f576bd654fb4adc
parentfa04a1e036a418258451466d99de34a9546a9965 (diff)
Update hldiff.py to match git more closely
-rwxr-xr-xcontrib/hldiff.py12
1 files changed, 10 insertions, 2 deletions
diff --git a/contrib/hldiff.py b/contrib/hldiff.py
index e12f688..367dcda 100755
--- a/contrib/hldiff.py
+++ b/contrib/hldiff.py
@@ -5,20 +5,28 @@ import re
patch = sys.stdin.read().replace("\r\n", "\n")
stat_re = re.compile(r'(\+*)(\-*)')
+lines_re = re.compile(r'@@ (-\d+,\d+ \+\d+,\d+) @@')
hit_diff = False
for line in patch.split("\n"):
if line.startswith("diff "):
hit_diff = True
- print(line)
+ print(f"{Style.BRIGHT}{line}{Style.RESET_ALL}")
continue
if hit_diff:
if line.startswith("-"):
print(f"{Fore.RED}{line}{Style.RESET_ALL}")
elif line.startswith("+"):
print(f"{Fore.GREEN}{line}{Style.RESET_ALL}")
- else:
+ elif line.startswith(" "):
print(line)
+ else:
+ if line.startswith("@@"):
+ line = lines_re.sub(f"{Fore.BLUE}@@ \\1 @@{Style.RESET_ALL}",
+ line)
+ print(line)
+ else:
+ print(f"{Style.BRIGHT}{line}{Style.RESET_ALL}")
else:
if line.startswith(" ") and "|" in line and ("+" in line or "-" in line):
line = stat_re.sub(