Skip to content

Commit

Permalink
Convert git-send-email to use Git.pm
Browse files Browse the repository at this point in the history
Signed-off-by: Petr Baudis <pasky@suse.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>
  • Loading branch information
Petr Baudis authored and Junio C Hamano committed Jul 4, 2006
1 parent dc2613d commit 3cb8caf
Showing 1 changed file with 8 additions and 22 deletions.
30 changes: 8 additions & 22 deletions git-send-email.perl
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
use Term::ReadLine;
use Getopt::Long;
use Data::Dumper;
use Git;

# most mail servers generate the Date: header, but not all...
$ENV{LC_ALL} = 'C';
Expand All @@ -46,6 +47,8 @@
# Example reply to:
#$initial_reply_to = ''; #<20050203173208.GA23964@foobar.com>';

my $repo = Git->repository();

my $term = new Term::ReadLine 'git-send-email';

# Begin by accumulating all the variables (defined above), that we will end up
Expand Down Expand Up @@ -81,23 +84,9 @@

# Now, let's fill any that aren't set in with defaults:

sub gitvar {
my ($var) = @_;
my $fh;
my $pid = open($fh, '-|');
die "$!" unless defined $pid;
if (!$pid) {
exec('git-var', $var) or die "$!";
}
my ($val) = <$fh>;
close $fh or die "$!";
chomp($val);
return $val;
}

sub gitvar_ident {
my ($name) = @_;
my $val = gitvar($name);
my $val = $repo->command('var', $name);
my @field = split(/\s+/, $val);
return join(' ', @field[0...(@field-3)]);
}
Expand All @@ -106,8 +95,8 @@ sub gitvar_ident {
my ($committer) = gitvar_ident('GIT_COMMITTER_IDENT');

my %aliases;
chomp(my @alias_files = `git-repo-config --get-all sendemail.aliasesfile`);
chomp(my $aliasfiletype = `git-repo-config sendemail.aliasfiletype`);
my @alias_files = $repo->config('sendemail.aliasesfile');
my $aliasfiletype = $repo->config('sendemail.aliasfiletype');
my %parse_alias = (
# multiline formats can be supported in the future
mutt => sub { my $fh = shift; while (<$fh>) {
Expand All @@ -132,7 +121,7 @@ sub gitvar_ident {
}}}
);

if (@alias_files && defined $parse_alias{$aliasfiletype}) {
if (@alias_files and $aliasfiletype and defined $parse_alias{$aliasfiletype}) {
foreach my $file (@alias_files) {
open my $fh, '<', $file or die "opening $file: $!\n";
$parse_alias{$aliasfiletype}->($fh);
Expand Down Expand Up @@ -374,10 +363,7 @@ sub send_message
my $date = strftime('%a, %d %b %Y %H:%M:%S %z', localtime($time++));
my $gitversion = '@@GIT_VERSION@@';
if ($gitversion =~ m/..GIT_VERSION../) {
$gitversion = `git --version`;
chomp $gitversion;
# keep only what's after the last space
$gitversion =~ s/^.* //;
$gitversion = Git::version();
}

my $header = "From: $from
Expand Down

0 comments on commit 3cb8caf

Please sign in to comment.