Junio C Hamano <junkio@xxxxxxx> writes: > David Woodhouse <dwmw2@xxxxxxxxxxxxx> writes: > >> # $FROM specifies the From: header used in the mails. It'll default >> # to GIT_COMMITTER_EMAIL if that exists, or to `whoami`@`hostname` > > I am not sure if this part is tested.. > >> # Unless configured otherwise, just cat it instead of mailing. >> if [ -z "$FROM" ]; then >> if [ -z "$GIT_COMMITTER_EMAIL" ]; then >> FROM="$GIT_COMMITTER_EMAIL" >> else >> FROM=`whoami`@`hostname` >> fi >> fi > > Maybe you meant 'if test -n "$GIT_COMMITTER_EMAIL"' here? > >> # takes an object and generates the object's parent(s) >> createmail () { >> local commit > > If you were to do bashism local, don't you want to also localize > other variables like key, SUBHEX, NEWSUB,...? > > It may make sense to enhance format-patch to do the Q encoding, > so that you do not have to do this part by hand... > >> git-diff -B $parent $commit > $TMPCM >> diffstat -p1 $TMPCM 2>/dev/null > > With GIT 1.3.0 and later: > > git diff --patch-with-stat $parent..$commit > > would be simpler here. Or at least lose "diffstat -p1" and replace it with git-apply --stat --status which would be more pleasant. >> if [ -z $2 ]; then >> lastmail=`cat $MAILTAG` >> else >> lastmail=$(git-rev-parse $2) >> fi > > lastmail=`git rev-parse --default "$MAILTAG" ${2+"$2"}` As I wrote it this is broken, sorry. This assumes you stop doing "MAILTAG=.git/refs/tags/MailDone" by hand and lose "do we have GIT_DIR" logic as well. Instead define MAILTAG=tags/MailDone or maybe refs/tags/MailDone and let "git rev-parse --default refs/tags/MailDone" figure out what to do when GIT_DIR is set or unset. - : send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html