A .config/gitfiles/hooks/commit-msg => .config/gitfiles/hooks/commit-msg +24 -0
@@ 0,0 1,24 @@
+#!/bin/sh
+#
+# An example hook script to check the commit log message.
+# Called by "git commit" with one argument, the name of the file
+# that has the commit message. The hook should exit with non-zero
+# status after issuing an appropriate message if it wants to stop the
+# commit. The hook is allowed to edit the commit message file.
+#
+# To enable this hook, rename this file to "commit-msg".
+
+# Uncomment the below to add a Signed-off-by line to the message.
+# Doing this in a hook is a bad idea in general, but the prepare-commit-msg
+# hook is more suited to it.
+#
+# SOB=$(git var GIT_AUTHOR_IDENT | sed -n 's/^\(.*>\).*$/Signed-off-by: \1/p')
+# grep -qs "^$SOB" "$1" || echo "$SOB" >> "$1"
+
+# This example catches duplicate Signed-off-by lines.
+
+test "" = "$(grep '^Signed-off-by: ' "$1" |
+ sort | uniq -c | sed -e '/^[ ]*1[ ]/d')" || {
+ echo >&2 Duplicate Signed-off-by lines.
+ exit 1
+}
A .config/gitfiles/hooks/prepare-commit-msg => .config/gitfiles/hooks/prepare-commit-msg +10 -0
@@ 0,0 1,10 @@
+#!/bin/sh
+
+SOB=$(git var GIT_AUTHOR_IDENT | sed -n "s/^\(.*>\).*$/Signed-off-by: \1/p")
+grep -qs "^$SOB""$1"|| echo "$SOB" >> "$1".tmp;
+
+(echo; git diff --cached| grep -e "+++" -e "---" -e "@@"|sed -e 's/.*/# &/')>> "$1".tmp;
+(echo; sed -e '/^$/d' "$1") >> "$1".tmp
+mv "$1".tmp "$1";
+
+# From https://habr.com/ru/post/75063/
M .gitconfig => .gitconfig +1 -0
@@ 9,6 9,7 @@
signingkey = 85523FCB002DAF83
[core]
quotepath = false
+ hooksPath = /home/riderius/.config/gitfiles/hooks
[gui]
encoding = utf-8
[gpg]