Browse Source

contrib/git-svn: several small bug fixes and changes

* Fixed manually-edited commit messages not going to
   remotes/git-svn on sequential commits after the sequential
   commit optimization.
 * format help correctly after adding 'show-ignore'
 * sha1_short regexp matches down to 4 hex characters
   (from git-rev-parse --short documentation)
 * Print the first line of the commit message when we commit to
   SVN next to the sha1.
 * Document 'T' (type change) in the comments

Signed-off-by: Eric Wong <normalperson@yhbt.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>
maint
Eric Wong 19 years ago committed by Junio C Hamano
parent
commit
ac8e0b910c
  1. 27
      contrib/git-svn/git-svn.perl

27
contrib/git-svn/git-svn.perl

@ -32,7 +32,7 @@ use Getopt::Long qw/:config gnu_getopt no_ignore_case auto_abbrev/;
use File::Spec qw//; use File::Spec qw//;
use POSIX qw/strftime/; use POSIX qw/strftime/;
my $sha1 = qr/[a-f\d]{40}/; my $sha1 = qr/[a-f\d]{40}/;
my $sha1_short = qr/[a-f\d]{6,40}/; my $sha1_short = qr/[a-f\d]{4,40}/;
my ($_revision,$_stdin,$_no_ignore_ext,$_no_stop_copy,$_help,$_rmdir,$_edit, my ($_revision,$_stdin,$_no_ignore_ext,$_no_stop_copy,$_help,$_rmdir,$_edit,
$_find_copies_harder, $_l, $_version, $_upgrade); $_find_copies_harder, $_l, $_version, $_upgrade);
my (@_branch_from, %tree_map); my (@_branch_from, %tree_map);
@ -90,12 +90,12 @@ Usage: $0 <command> [options] [arguments]\n
Available commands: Available commands:


foreach (sort keys %cmd) { foreach (sort keys %cmd) {
print $fd ' ',pack('A10',$_),$cmd{$_}->[1],"\n"; print $fd ' ',pack('A13',$_),$cmd{$_}->[1],"\n";
} }
print $fd <<""; print $fd <<"";
\nGIT_SVN_ID may be set in the environment to an arbitrary identifier if \nGIT_SVN_ID may be set in the environment to an arbitrary identifier if
you're tracking multiple SVN branches/repositories in one git repository you're tracking multiple SVN branches/repositories in one git repository
and want to keep them separate. and want to keep them separate. See git-svn(1) for more information.


exit $exit; exit $exit;
} }
@ -245,7 +245,7 @@ sub commit {
print "Reading from stdin...\n"; print "Reading from stdin...\n";
@commits = (); @commits = ();
while (<STDIN>) { while (<STDIN>) {
if (/\b([a-f\d]{6,40})\b/) { if (/\b($sha1_short)\b/) {
unshift @commits, $1; unshift @commits, $1;
} }
} }
@ -267,7 +267,6 @@ sub commit {
chdir $SVN_WC or croak $!; chdir $SVN_WC or croak $!;
my $svn_current_rev = svn_info('.')->{'Last Changed Rev'}; my $svn_current_rev = svn_info('.')->{'Last Changed Rev'};
foreach my $c (@revs) { foreach my $c (@revs) {
print "Committing $c\n";
my $mods = svn_checkout_tree($svn_current_rev, $c); my $mods = svn_checkout_tree($svn_current_rev, $c);
if (scalar @$mods == 0) { if (scalar @$mods == 0) {
print "Skipping, no changes detected\n"; print "Skipping, no changes detected\n";
@ -514,7 +513,7 @@ sub svn_checkout_tree {
my ($svn_rev, $treeish) = @_; my ($svn_rev, $treeish) = @_;
my $from = file_to_s("$REV_DIR/$svn_rev"); my $from = file_to_s("$REV_DIR/$svn_rev");
assert_svn_wc_clean($svn_rev,$from); assert_svn_wc_clean($svn_rev,$from);
print "diff-tree '$from' '$treeish'\n"; print "diff-tree $from $treeish\n";
my $pid = open my $diff_fh, '-|'; my $pid = open my $diff_fh, '-|';
defined $pid or croak $!; defined $pid or croak $!;
if ($pid == 0) { if ($pid == 0) {
@ -525,7 +524,7 @@ sub svn_checkout_tree {
} }
my $mods = parse_diff_tree($diff_fh); my $mods = parse_diff_tree($diff_fh);
unless (@$mods) { unless (@$mods) {
# git can do empty commits, SVN doesn't allow it... # git can do empty commits, but SVN doesn't allow it...
return $mods; return $mods;
} }
my ($rm, $add) = precommit_check($mods); my ($rm, $add) = precommit_check($mods);
@ -612,7 +611,7 @@ sub svn_commit_tree {
my ($svn_rev, $commit) = @_; my ($svn_rev, $commit) = @_;
my $commit_msg = "$GIT_DIR/$GIT_SVN/.svn-commit.tmp.$$"; my $commit_msg = "$GIT_DIR/$GIT_SVN/.svn-commit.tmp.$$";
my %log_msg = ( msg => '' ); my %log_msg = ( msg => '' );
open my $msg, '>', $commit_msg or croak $!; open my $msg, '>', $commit_msg or croak $!;


chomp(my $type = `git-cat-file -t $commit`); chomp(my $type = `git-cat-file -t $commit`);
if ($type eq 'commit') { if ($type eq 'commit') {
@ -627,7 +626,6 @@ sub svn_commit_tree {
if (!$in_msg) { if (!$in_msg) {
$in_msg = 1 if (/^\s*$/); $in_msg = 1 if (/^\s*$/);
} else { } else {
$log_msg{msg} .= $_;
print $msg $_ or croak $!; print $msg $_ or croak $!;
} }
} }
@ -639,6 +637,15 @@ sub svn_commit_tree {
my $editor = $ENV{VISUAL} || $ENV{EDITOR} || 'vi'; my $editor = $ENV{VISUAL} || $ENV{EDITOR} || 'vi';
system($editor, $commit_msg); system($editor, $commit_msg);
} }

# file_to_s removes all trailing newlines, so just use chomp() here:
open $msg, '<', $commit_msg or croak $!;
{ local $/; chomp($log_msg{msg} = <$msg>); }
close $msg or croak $!;

my ($oneline) = ($log_msg{msg} =~ /([^\n\r]+)/);
print "Committing $commit: $oneline\n";

my @ci_output = safe_qx(qw(svn commit -F),$commit_msg); my @ci_output = safe_qx(qw(svn commit -F),$commit_msg);
my ($committed) = grep(/^Committed revision \d+\./,@ci_output); my ($committed) = grep(/^Committed revision \d+\./,@ci_output);
unlink $commit_msg; unlink $commit_msg;
@ -1037,7 +1044,7 @@ diff-index line ($m hash)
mode_a => first column of diff-index output, no leading ':', mode_a => first column of diff-index output, no leading ':',
mode_b => second column of diff-index output, mode_b => second column of diff-index output,
sha1_b => sha1sum of the final blob, sha1_b => sha1sum of the final blob,
chg => change type [MCRAD], chg => change type [MCRADT],
file_a => original file name of a file (iff chg is 'C' or 'R') file_a => original file name of a file (iff chg is 'C' or 'R')
file_b => new/current file name of a file (any chg) file_b => new/current file name of a file (any chg)
} }

Loading…
Cancel
Save