Browse Source

git-svn: re-enable repacking flags

Signed-off-by: Eric Wong <normalperson@yhbt.net>
maint
Eric Wong 18 years ago
parent
commit
ecc712ddc4
  1. 26
      git-svn.perl

26
git-svn.perl

@ -52,7 +52,6 @@ my $_optimize_commits = 1 unless $ENV{GIT_SVN_NO_OPTIMIZE_COMMITS};
$sha1 = qr/[a-f\d]{40}/; $sha1 = qr/[a-f\d]{40}/;
$sha1_short = qr/[a-f\d]{4,40}/; $sha1_short = qr/[a-f\d]{4,40}/;
my ($_stdin, $_help, $_edit, my ($_stdin, $_help, $_edit,
$_repack, $_repack_nr, $_repack_flags,
$_message, $_file, $_message, $_file,
$_template, $_shared, $_template, $_shared,
$_version, $_version,
@ -64,10 +63,11 @@ my %remote_opts = ( 'username=s' => \$Git::SVN::Prompt::_username,
'no-auth-cache' => \$Git::SVN::Prompt::_no_auth_cache ); 'no-auth-cache' => \$Git::SVN::Prompt::_no_auth_cache );
my %fc_opts = ( 'follow-parent|follow' => \$Git::SVN::_follow_parent, my %fc_opts = ( 'follow-parent|follow' => \$Git::SVN::_follow_parent,
'authors-file|A=s' => \$_authors, 'authors-file|A=s' => \$_authors,
'repack:i' => \$_repack, 'repack:i' => \$Git::SVN::_repack,
'no-metadata' => \$Git::SVN::_no_metadata, 'no-metadata' => \$Git::SVN::_no_metadata,
'quiet|q' => \$_q, 'quiet|q' => \$_q,
'repack-flags|repack-args|repack-opts=s' => \$_repack_flags, 'repack-flags|repack-args|repack-opts=s' =>
\$Git::SVN::_repack_flags,
%remote_opts ); %remote_opts );


my ($_trunk, $_tags, $_branches); my ($_trunk, $_tags, $_branches);
@ -158,6 +158,7 @@ load_authors() if $_authors;
unless ($cmd =~ /^(?:init|multi-init|commit-diff)$/) { unless ($cmd =~ /^(?:init|multi-init|commit-diff)$/) {
Git::SVN::Migration::migration_check(); Git::SVN::Migration::migration_check();
} }
Git::SVN::init_vars();
eval { eval {
Git::SVN::verify_remotes_sanity(); Git::SVN::verify_remotes_sanity();
$cmd{$cmd}->[0]->(@ARGV); $cmd{$cmd}->[0]->(@ARGV);
@ -626,11 +627,13 @@ sub cmt_metadata {
package Git::SVN; package Git::SVN;
use strict; use strict;
use warnings; use warnings;
use vars qw/$default_repo_id $default_ref_id $_no_metadata $_follow_parent/; use vars qw/$default_repo_id $default_ref_id $_no_metadata $_follow_parent
$_repack $_repack_flags/;
use Carp qw/croak/; use Carp qw/croak/;
use File::Path qw/mkpath/; use File::Path qw/mkpath/;
use IPC::Open3; use IPC::Open3;


my $_repack_nr;
# properties that we do not log: # properties that we do not log:
my %SKIP_PROP; my %SKIP_PROP;
BEGIN { BEGIN {
@ -676,6 +679,14 @@ sub read_all_remotes {
$r; $r;
} }


sub init_vars {
if (defined $_repack) {
$_repack = 1000 if ($_repack <= 0);
$_repack_nr = $_repack;
$_repack_flags ||= '-d';
}
}

sub verify_remotes_sanity { sub verify_remotes_sanity {
return unless -d $ENV{GIT_DIR}; return unless -d $ENV{GIT_DIR};
my %seen; my %seen;
@ -1025,6 +1036,13 @@ sub do_git_commit {
$self->{last_rev} = $log_entry->{revision}; $self->{last_rev} = $log_entry->{revision};
$self->{last_commit} = $commit; $self->{last_commit} = $commit;
print "r$log_entry->{revision} = $commit ($self->{ref_id})\n"; print "r$log_entry->{revision} = $commit ($self->{ref_id})\n";
if (defined $_repack && (--$_repack_nr == 0)) {
$_repack_nr = $_repack;
# repack doesn't use any arguments with spaces in them, does it?
print "Running git repack $_repack_flags ...\n";
command_noisy('repack', split(/\s+/, $_repack_flags));
print "Done repacking\n";
}
return $commit; return $commit;
} }



Loading…
Cancel
Save