I'm writing a pre-commit hook, or better, I'm editing the hook that comes standard on the tigris SVN release.
My goals are modest, I just want to write an error message to the person who has commited without providing a commit message.
So my thoughts were开发者_开发知识库 to just write to stderr with a simple error message. But for some reason, my messages never seem to get through.
Everyone on the internet says I have got to write to stderr. But somehow that doesn't work.
REPOS="$1"
TXN="$2"
LOG=""
#here is where it seems to wrong
#if [ ${#LOG} -lt 1 ]
echo "You did not provide a commit message, please try again." 2>&1
#fi
echo
# Make sure that the log message contains some text.
SVNLOOK=/usr/bin/svnlook
$SVNLOOK log -t "$TXN" "$REPOS" | \
grep "[a-zA-Z0-9]" > LOG || exit 1
# Exit on all errors.
set -e
# All checks passed, so allow the commit.
exit 0
You have to excuse me if this is a silly question, but i'm a linux novice, so apologies beforehand.
thanks, Jasper
Your way of determining the log message is wrong. Try this instead:
SVNLOOK=/usr/bin/svnlook
LOGMSG=`$SVNLOOK log -t “$TXN” “$REPOS” | grep “[a-zA-Z0-9]” | wc -c`
if [ "$LOGMSG" -lt 1 ]; then
echo -e “Please provide a meaningful comment when committing changes.” 1>&2
exit 1
fi
Your code:
echo "You did not provide a commit message, please try again." 2>&1
does NOT print to stderr (instead it redirects stderr to stdout). Use instead (important is the 1>&2):
echo "You did not provide a commit message, please try again." 1>&2
精彩评论