libtool/build-aux/git-hooks/commit-msg
Gary V. Vaughan d98a30fbce syntax-check: fix violations and implement sc_old_style_quoting.
Modern GNU ASCII quoting in output and comments is done
'like this'.
* cfg.mk (sc_old_style_quoting): Try to catch most instances
of `old style quoting' so that it is not accidentally re-
introduced to the code.
* HACKING, Makefile.am, NEWS, PORTING, README, TODO, bootstrap,
bootstrap.conf, build-aux/edit-readme-alpha,
build-aux/git-hooks/commit-msg, build-aux/ltmain.in,
doc/libtool.texi, gl/build-aux/bootstrap.in,
gl/build-aux/extract-trace, gl/build-aux/funclib.sh,
gl/build-aux/inline-source, gl/build-aux/options-parser,
libltdl/libltdl/slist.h, libltdl/loaders/loadlibrary.c,
libltdl/ltdl.c, libltdl/slist.c, libtoolize.in, m4/argz.m4,
m4/libtool.m4, m4/ltdl.m4, m4/ltoptions.m4, m4/ltsugar.m4,
tests/cmdline_wrap.at, tests/configure-iface.at, tests/demo.at,
tests/depdemo.at, tests/deplib-in-subdir.at,
tests/deplibs-mingw.at, tests/destdir.at, tests/execute-mode.at,
tests/f77demo.at, tests/fail.at, tests/inherited_flags.at,
tests/libtool.at, tests/libtoolize.at, tests/lt_dladvise.at,
tests/lt_dlexit.at, tests/mdemo.at, tests/need_lib_prefix.at,
tests/old-ltdl-iface.at, tests/old-m4-iface.at, tests/static.at,
tests/stresstest.at, tests/testsuite.at, tests/versioning.at:
Convert to upright quotes.

Signed-off-by: Gary V. Vaughan <gary@gnu.org>
2012-10-22 00:01:13 +07:00

112 lines
2.4 KiB
Bash
Executable File

#!/bin/sh
# An example hook script for catching duplicate or malformed
# Co-authored-by or Copyright-paperwork-exempt lines in the
# commit message.
: ${SED="sed"}
test set = ${ECHO+'set'} = set || ECHO='printf %s\n'
basename='s|^.*/||'
nl='
'
progpath=$0
progname=`$ECHO "$progpath" |$SED -e "$basename"`
log_file=$1
export log_file
fn_error ()
{
prefix="$progname: error: "
save_IFS=$IFS
IFS=$nl
for line in $*; do
IFS=$save_IFS
$ECHO "$prefix$line" 1>&2
prefix="$progname: "
done
IFS=$save_IFS
}
fn_re_edit ()
{
$ECHO 'Press return to edit. Ctrl-C to abort...' >&2
read v
${EDITOR-'vi'} "$log_file"
}
fn_rewrite ()
{
# Output once to stderr
fn_error "$*"
# And again as a comment in the log_file ready for re-editing
$ECHO "$*" |$SED 's|^|# |'
echo
cat "$log_file"
}
fn_check_msg ()
{
return_status=0
CAB_re='^Co-authored-by: '
CPR_re='^Copyright-paperwork-exempt: '
# Flag duplicated Co-authored-by lines.
dups=`grep "$CAB_re" "$log_file" 2>/dev/null \
|sort |uniq -c |sed -e '/^[ ]*1[ ]/d'`
test -n "$dups" && {
$ECHO 'Duplicate Co-authored-by lines:
'"$dups"
return_status=1
}
# Make sure each Co-authored-by line contains a valid email.
email_re='<.*@.*\..*>'
grep "$CAB_re" "$log_file" 2>/dev/null \
|while read CAB; do
test 0 -eq `expr "$CAB" : ".*$email_re"` && {
echo "Malformed or missing email in '$CAB'"
return_status=1
}
done
# Flag duplicated Copyright-paperwork-exempt lines.
count=`grep "$CPR_re" "$log_file" 2>/dev/null \
|wc |sed -e 's|^[ ]*||;s|[ ].*$||'`
test 2 -gt "$count" || {
$ECHO 'More than one Copyright-paperwork-exempt line.'
return_status=1
}
# Make sure Copyright-paperwork-exempt line is valid.
if grep "$CPR_re[Nn]" "$log_file" >/dev/null 2>&1; then
$ECHO "\
'Copyright-paperwork-exempt: No' is redundant, please remove."
return_status=1
else
not_yes=`grep "$CPR_re" "$log_file" 2>/dev/null \
|grep -v "${CPR_re}Yes\$"`
test -n "$not_yes" && {
$ECHO "'Copyright-paperwork-exempt' setting must be 'Yes'."
return_status=1
}
fi
return $return_status
}
while :; do
err=`fn_check_msg` && break
fn_rewrite "$err" > "${log_file}T" && mv "${log_file}T" "$log_file"
fn_re_edit
done