diff options
| author | Junio C Hamano <junkio@cox.net> | 2006-10-02 11:49:59 -0700 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-10-02 11:49:59 -0700 | 
| commit | ff989b8d466ee2ec42c69c02e6551add430b8497 (patch) | |
| tree | 50c0ef99605ec0967156a3d2074dd27bdd4655d2 /git-send-email.perl | |
| parent | 367337040d8d39294bf676672dfefc542717195b (diff) | |
| parent | 7a21632fa346df58d94d32f09625025931ef13ec (diff) | |
| download | git-ff989b8d466ee2ec42c69c02e6551add430b8497.tar.gz | |
Merge branch 'master' into lj/refs
* master: (99 commits)
  lock_ref_sha1_basic does not remove empty directories on BSD
  git-push: .git/remotes/ file does not require SP after colon
  git-mv: invalidate the removed path properly in cache-tree
  Makefile: install and clean merge-recur, still.
  GIT 1.4.3-rc1
  gitweb: tree view: hash_base and hash are now context sensitive
  git-diff -B output fix.
  fetch: Reset remote refs list each time fetch_main is called
  Remove -fPIC which was only needed for Git.xs
  Fix approxidate() to understand 12:34 AM/PM are 00:34 and 12:34
  git-diff -B output fix.
  Make cvsexportcommit remove files.
  diff --stat: ensure at least one '-' for deletions, and one '+' for additions
  diff --stat=width[,name-width]: allow custom diffstat output width.
  gitweb: History: blob and tree are first, then commitdiff, etc
  gitweb: Remove redundant "commit" from history
  http/ftp: optionally ask curl to not use EPSV command
  gitweb: Don't use quotemeta on internally generated strings
  gitweb: Add snapshot to shortlog
  gitweb: Factor out gitweb_have_snapshot()
  ...
Diffstat (limited to 'git-send-email.perl')
| -rwxr-xr-x | git-send-email.perl | 38 | 
1 files changed, 8 insertions, 30 deletions
| diff --git a/git-send-email.perl b/git-send-email.perl index 746c525079..4a20310841 100755 --- a/git-send-email.perl +++ b/git-send-email.perl @@ -21,6 +21,7 @@ use warnings;  use Term::ReadLine;  use Getopt::Long;  use Data::Dumper; +use Git;  package FakeTerm;  sub new { @@ -92,6 +93,7 @@ my $smtp_server;  # Example reply to:  #$initial_reply_to = ''; #<20050203173208.GA23964@foobar.com>'; +my $repo = Git->repository();  my $term = eval {  	new Term::ReadLine 'git-send-email';  }; @@ -132,33 +134,12 @@ foreach my $entry (@bcclist) {  # 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 @field = split(/\s+/, $val); -    return join(' ', @field[0...(@field-3)]); -} - -my ($author) = gitvar_ident('GIT_AUTHOR_IDENT'); -my ($committer) = gitvar_ident('GIT_COMMITTER_IDENT'); +my ($author) = $repo->ident_person('author'); +my ($committer) = $repo->ident_person('committer');  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>) { @@ -183,7 +164,7 @@ my %parse_alias = (  		}}}  ); -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); @@ -425,10 +406,7 @@ sub send_message  	my $date = format_2822_time($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 | 
