Merge branch 'kf/post-receive-sample-hook'

* kf/post-receive-sample-hook:
  post-receive-email: optional message line count limit
This commit is contained in:
Junio C Hamano 2010-08-18 12:16:50 -07:00
commit c1807defb8

View File

@ -55,6 +55,11 @@
# "t=%s; printf 'http://.../?id=%%s' \$t; echo;echo; git show -C \$t; echo" # "t=%s; printf 'http://.../?id=%%s' \$t; echo;echo; git show -C \$t; echo"
# Be careful if "..." contains things that will be expanded by shell "eval" # Be careful if "..." contains things that will be expanded by shell "eval"
# or printf. # or printf.
# hooks.emailmaxlines
# The maximum number of lines that should be included in the generated
# email body. If not specified, there is no limit.
# Lines beyond the limit are suppressed and counted, and a final
# line is added indicating the number of suppressed lines.
# #
# Notes # Notes
# ----- # -----
@ -84,6 +89,7 @@ generate_email()
oldrev=$(git rev-parse $1) oldrev=$(git rev-parse $1)
newrev=$(git rev-parse $2) newrev=$(git rev-parse $2)
refname="$3" refname="$3"
maxlines=$4
# --- Interpret # --- Interpret
# 0000->1234 (create) # 0000->1234 (create)
@ -192,7 +198,12 @@ generate_email()
fn_name=atag fn_name=atag
;; ;;
esac esac
if [ -z "$maxlines" ]; then
generate_${change_type}_${fn_name}_email generate_${change_type}_${fn_name}_email
else
generate_${change_type}_${fn_name}_email | limit_lines $maxlines
fi
generate_email_footer generate_email_footer
} }
@ -642,6 +653,24 @@ show_new_revisions()
} }
limit_lines()
{
lines=0
skipped=0
while IFS="" read -r line; do
lines=$((lines + 1))
if [ $lines -gt $1 ]; then
skipped=$((skipped + 1))
else
printf "%s\n" "$line"
fi
done
if [ $skipped -ne 0 ]; then
echo "... $skipped lines suppressed ..."
fi
}
send_mail() send_mail()
{ {
if [ -n "$envelopesender" ]; then if [ -n "$envelopesender" ]; then
@ -679,6 +708,7 @@ announcerecipients=$(git config hooks.announcelist)
envelopesender=$(git config hooks.envelopesender) envelopesender=$(git config hooks.envelopesender)
emailprefix=$(git config hooks.emailprefix || echo '[SCM] ') emailprefix=$(git config hooks.emailprefix || echo '[SCM] ')
custom_showrev=$(git config hooks.showrev) custom_showrev=$(git config hooks.showrev)
maxlines=$(git config hooks.emailmaxlines)
# --- Main loop # --- Main loop
# Allow dual mode: run from the command line just like the update hook, or # Allow dual mode: run from the command line just like the update hook, or
@ -691,6 +721,6 @@ if [ -n "$1" -a -n "$2" -a -n "$3" ]; then
else else
while read oldrev newrev refname while read oldrev newrev refname
do do
generate_email $oldrev $newrev $refname | send_mail generate_email $oldrev $newrev $refname $maxlines | send_mail
done done
fi fi