my $out = File::Temp->new() or die;
my $outname = $out->filename;
$out->autoflush(1);
+open ORIG_STDOUT, '>&', \*STDOUT;
close STDOUT;
open STDOUT, '>&', $out or die;
my $copy_of = scan_branches();
if (defined $copy_of) {
$subj .= " as a copy of $copy_of";
- print $out "Created branch $ref as a copy of $copy_of.\n";
+ print $out "Created branch $ref as a copy of $copy_of ($new).\n";
} else {
- print $out "Created branch $ref.\n\n";
+ print $out "Created branch $ref ($new).\n\n";
most_recent();
}
} elsif ($new =~ /^0+$/) {
# Deletion of a branch
$subj .= ' Branch deleted';
- print $out "Deleted branch $ref.\n\nPrevious tip was $old.\n";
+ print $out "Deleted branch $ref ($old).\n";
} else {
my $lca = `git merge-base $old $new`; die if $?;
chomp $lca;
chomp $c;
$c =~ s{^\S+\s+}{};
$subj .= " $c";
+ print $out "Push to branch $ref ($old -> $new)\n\n";
# If there are multiple commits, print an overall diffstat first
if (@commits > 1) {
my $pos_after_header = output_size();
# Show individual commits with diffs and stats
- system 'git', 'log', @rev_list_options, '--reverse', @diff_options, '-p', '--stat', "$old..$new";
+ system 'git', 'log', @rev_list_options, @diff_options, '-p', '--stat', "$old..$new";
# If the file is too long, truncate it and print just a summary
if (defined($max_diff_size) && output_size() > $max_diff_size) {
$out->truncate($pos_after_header);
output_size();
print $out "Diff was too long, printing just a summary.\n\n";
- system 'git', 'log', @rev_list_options, '--reverse', "$old..$new";
+ system 'git', 'log', @rev_list_options, "$old..$new";
}
} elsif ($lca eq $new) {
# Rewind
$subj .= ' Branch rewound';
- print $out "Rewound branch $ref to commit $new.\n\n";
+ print $out "Rewound branch $ref ($old -> $new).\n\n";
most_recent();
} else {
# Otherwise it is a rebase
$subj .= ' Branch rebased';
- print $out "Rebased branch $ref to commit $new.\n\n";
+ print $out "Rebased branch $ref ($old -> $new).\n\n";
print $out "Commits from common ancestor:\n\n";
system 'git', 'rev-list', @rev_list_options, $new, "^$old";
}
'-s', $subj,
$mail_to;
} else {
- print STDERR "Subject: $subj\n\n";
- `cat >&2 $outname`;
+ open STDOUT, '>&', \*ORIG_STDOUT;
+ print "Subject: $subj\n\n";
+ system 'cat', $outname;
}