Browse Source

[PATCH] format-patch: always --mbox and show sane Date:

Make --mbox, --author, and --date options a no-op, and always
use --mbox output, and rewrite the commit log formatting in
Perl.  This makes it easier to output Date: header in RFC 2822
format, so do that as well.

Inspiration for this patch came from Andreas Ericsson's earlier
patch.

Signed-off-by: Junio C Hamano <junkio@cox.net>
maint
Junio C Hamano 19 years ago
parent
commit
36383a3df3
  1. 141
      git-format-patch.sh

141
git-format-patch.sh

@ -34,14 +34,12 @@ outdir=./
while case "$#" in 0) break;; esac while case "$#" in 0) break;; esac
do do
case "$1" in case "$1" in
-a|--a|--au|--aut|--auth|--autho|--author)
author=t ;;
-c|--c|--ch|--che|--chec|--check) -c|--c|--ch|--che|--chec|--check)
check=t ;; check=t ;;
-d|--d|--da|--dat|--date) -a|--a|--au|--aut|--auth|--autho|--author|\
date=t ;; -d|--d|--da|--dat|--date|\
-m|--m|--mb|--mbo|--mbox) -m|--m|--mb|--mbo|--mbox) # now noop
date=t author=t mbox=t ;; ;;
-k|--k|--ke|--kee|--keep|--keep-|--keep-s|--keep-su|--keep-sub|\ -k|--k|--ke|--kee|--keep|--keep-|--keep-s|--keep-su|--keep-sub|\
--keep-subj|--keep-subje|--keep-subjec|--keep-subject) --keep-subj|--keep-subje|--keep-subjec|--keep-subject)
keep_subject=t ;; keep_subject=t ;;
@ -173,80 +171,89 @@ titleScript='
q q
' '


whosepatchScript='
/^author /{
s/'\''/'\''\\'\'\''/g
s/author \(.*>\) \(.*\)$/au='\''\1'\'' ad='\''\2'\''/p
q
}'

process_one () { process_one () {
mailScript=' perl -w -e '
/./d my ($keep_subject, $num, $signoff, $commsg) = @ARGV;
/^$/n' my ($signoff_pattern, $done_header, $done_subject, $signoff_seen,
case "$keep_subject" in $last_was_signoff);
t) ;;
*)
mailScript="$mailScript"'
s|^\[PATCH[^]]*\] *||
s|^|[PATCH'"$num"'] |'
;;
esac
mailScript="$mailScript"'
s|^|Subject: |'
case "$mbox" in
t)
echo 'From nobody Mon Sep 17 00:00:00 2001' ;# UNIX "From" line
;;
esac


eval "$(sed -ne "$whosepatchScript" $commsg)" if ($signoff) {
test "$author,$au" = ",$me" || { $signoff = `git-var GIT_COMMITTER_IDENT`;
mailScript="$mailScript"' $signoff =~ s/>.*/>/;
a\ $signoff_pattern = quotemeta($signoff);
From: '"$au" }
}
test "$date,$au" = ",$me" || {
mailScript="$mailScript"'
a\
Date: '"$ad"
}


mailScript="$mailScript"' my @weekday_names = qw(Sun Mon Tue Wed Thu Fri Sat);
a\ my @month_names = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec);


: body sub show_date {
p my ($time, $tz) = @_;
n my $minutes = abs($tz);
b body' $minutes = ($minutes / 100) * 60 + ($minutes % 100);
if ($tz < 0) {
$minutes = -$minutes;
}
my $t = $time + $minutes * 60;
my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday) = gmtime($t);
return sprintf("%s %s %d %02d:%02d:%02d %d %+05d",
$weekday_names[$wday],
$month_names[$mon],
$mday, $hour, $min, $sec,
$year+1900, $tz);
}


(cat $commsg ; echo; echo) | print "From nobody Mon Sep 17 00:00:00 2001\n";
sed -ne "$mailScript" | open FH, "git stripspace <$commsg |" or die "open $commsg pipe";
git-stripspace while (<FH>) {
unless ($done_header) {
if (/^$/) {
$done_header = 1;
}
elsif (/^author (.*>) (.*)$/) {
my ($author_ident, $author_date) = ($1, $2);
my ($utc, $off) = ($author_date =~ /^(\d+) ([-+]?\d+)$/);
$author_date = show_date($utc, $off);


test "$signoff" = "t" && { print "From: $author_ident\n";
offsigner=`git-var GIT_COMMITTER_IDENT | sed -e 's/>.*/>/'` print "Date: $author_date\n";
line="Signed-off-by: $offsigner"
grep -q "^$line\$" $commsg || {
echo
echo "$line"
echo
}
} }
echo next;
echo '---' }
echo unless ($done_subject) {
unless ($keep_subject) {
s/^\[PATCH[^]]*\]\s*//;
s/^/[PATCH$num] /;
}
print "Subject: $_";
$done_subject = 1;
next;
}

$last_was_signoff = 0;
if (/Signed-off-by:/i) {
if ($signoff ne "" && /Signed-off-by:\s*$signoff_pattern$/i) {
$signoff_seen = 1;
}
}
print $_;
}
if (!$signoff_seen && $signoff ne "") {
if (!$last_was_signoff) {
print "\n";
}
print "$signoff\n";
}
print "\n---\n\n";
close FH or die "close $commsg pipe";
' "$keep_subject" "$num" "$signoff" $commsg

git-diff-tree -p $diff_opts "$commit" | git-apply --stat --summary git-diff-tree -p $diff_opts "$commit" | git-apply --stat --summary
echo echo
git-diff-tree -p $diff_opts "$commit" git-diff-tree -p $diff_opts "$commit"
echo "-- " echo "-- "
echo "@@GIT_VERSION@@" echo "@@GIT_VERSION@@"


case "$mbox" in echo
t)
echo
;;
esac
} }


total=`wc -l <$series | tr -dc "[0-9]"` total=`wc -l <$series | tr -dc "[0-9]"`

Loading…
Cancel
Save