diff options
| author | Karl Hasselström <kha@treskal.com> | 2006-02-28 00:08:19 +0100 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-02-27 15:27:24 -0800 | 
| commit | d3cac2c95a1600c9269c821153cbad681b66a8d2 (patch) | |
| tree | 1a4b4c517eab764cd6bd213aa4fc6946179912fa /git-svnimport.perl | |
| parent | 80804d0af8f5bfa8ce87b5ef72cd2c5eb64c8f40 (diff) | |
| download | git-d3cac2c95a1600c9269c821153cbad681b66a8d2.tar.gz | |
Save username -> Full Name <email@addr.es> map file
When the user specifies a username -> Full Name <email@addr.es> map
file with the -A option, save a copy of that file as
$git_dir/svn-authors. When running git-svnimport with an existing GIT
directory, use $git_dir/svn-authors (if it exists) unless a file was
explicitly specified with -A.
Signed-off-by: Karl Hasselström <kha@treskal.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'git-svnimport.perl')
| -rwxr-xr-x | git-svnimport.perl | 25 | 
1 files changed, 20 insertions, 5 deletions
| diff --git a/git-svnimport.perl b/git-svnimport.perl index 86837edbdd..639aa41861 100755 --- a/git-svnimport.perl +++ b/git-svnimport.perl @@ -13,6 +13,7 @@  use strict;  use warnings;  use Getopt::Std; +use File::Copy;  use File::Spec;  use File::Temp qw(tempfile);  use File::Path qw(mkpath); @@ -68,10 +69,16 @@ if ($opt_M) {  	push (@mergerx, qr/$opt_M/);  } +# Absolutize filename now, since we will have chdir'ed by the time we +# get around to opening it. +$opt_A = File::Spec->rel2abs($opt_A) if $opt_A; +  our %users = (); -if ($opt_A) { -	die "Cannot open $opt_A\n" unless -f $opt_A; -	open(my $authors,$opt_A); +our $users_file = undef; +sub read_users($) { +	$users_file = File::Spec->rel2abs(@_); +	die "Cannot open $users_file\n" unless -f $users_file; +	open(my $authors,$users_file);  	while(<$authors>) {  		chomp;  		next unless /^(\S+?)\s*=\s*(.+?)\s*<(.+)>\s*$/; @@ -302,6 +309,14 @@ EOM  -d $git_dir  	or die "Could not create git subdir ($git_dir).\n"; +my $default_authors = "$git_dir/svn-authors"; +if ($opt_A) { +	read_users($opt_A); +	copy($opt_A,$default_authors) or die "Copy failed: $!"; +} else { +	read_users($default_authors) if -f $default_authors; +} +  open BRANCHES,">>", "$git_dir/svn2git";  sub node_kind($$$) { @@ -498,8 +513,8 @@ sub commit {  	if (not defined $author) {  		$author_name = $author_email = "unknown"; -	} elsif ($opt_A) { -		die "User $author is not listed in $opt_A\n" +	} elsif (defined $users_file) { +		die "User $author is not listed in $users_file\n"  		    unless exists $users{$author};  		($author_name,$author_email) = @{$users{$author}};  	} elsif ($author =~ /^(.*?)\s+<(.*)>$/) { | 
