mirror of
https://https.git.savannah.gnu.org/git/libtool.git
synced 2026-01-27 01:44:28 +00:00
I like to name temporary directories that I will remove shortly with two leading commas so that they sort lexicographically at the top of `ls' output. Now, `./configure --prefix=`pwd`/,,inst' works again, for the first time in several years. * cfg.mk (sc_prohibit_sed_s_comma): Comma is too common a character to use routinely as the separator for sed substitutions on file paths and other variables determined by the user, causing bugs like the one I describe above. Make sure we don't accidentally reintroduce any comma separators in future. * Makefile.am, bootstrap, bootstrap.conf, build-aux/extract-trace, build-aux/general.m4sh, build-aux/git-hooks/commit-msg, build-aux/git-log-fix, build-aux/ltmain.m4sh, libtoolize.m4sh, m4/libtool.m4, m4/ltdl.m4, tests/cdemo-undef.test, tests/cmdline_wrap.at, tests/darwin.at, tests/defs.m4sh, tests/getopt-m4sh.at, tests/install.at, tests/libtoolize.at, tests/mdemo/Makefile.am, tests/need_lib_prefix.at, tests/sysroot.at, tests/tagdemo-undef.test, tests/testsuite.at: Try to use `|' as the default separator wherever possible, otherwise something else that doesn't occur in the substitution expression. * NEWS: Updated. Signed-off-by: Gary V. Vaughan <gary@gnu.org>
112 lines
2.4 KiB
Bash
Executable File
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
|