Move Git::IndexInfo into its own file.
Straight cut & paste. Didn't require any fixing. Signed-off-by: Eric Wong <normalperson@yhbt.net>
This commit is contained in:
parent
e96cdba110
commit
10c2aa5928
32
git-svn.perl
32
git-svn.perl
@ -2040,38 +2040,6 @@ sub gc_directory {
|
||||
}
|
||||
|
||||
|
||||
package Git::IndexInfo;
|
||||
use strict;
|
||||
use warnings;
|
||||
use Git qw/command_input_pipe command_close_pipe/;
|
||||
|
||||
sub new {
|
||||
my ($class) = @_;
|
||||
my ($gui, $ctx) = command_input_pipe(qw/update-index -z --index-info/);
|
||||
bless { gui => $gui, ctx => $ctx, nr => 0}, $class;
|
||||
}
|
||||
|
||||
sub remove {
|
||||
my ($self, $path) = @_;
|
||||
if (print { $self->{gui} } '0 ', 0 x 40, "\t", $path, "\0") {
|
||||
return ++$self->{nr};
|
||||
}
|
||||
undef;
|
||||
}
|
||||
|
||||
sub update {
|
||||
my ($self, $mode, $hash, $path) = @_;
|
||||
if (print { $self->{gui} } $mode, ' ', $hash, "\t", $path, "\0") {
|
||||
return ++$self->{nr};
|
||||
}
|
||||
undef;
|
||||
}
|
||||
|
||||
sub DESTROY {
|
||||
my ($self) = @_;
|
||||
command_close_pipe($self->{gui}, $self->{ctx});
|
||||
}
|
||||
|
||||
package Git::SVN::GlobSpec;
|
||||
use strict;
|
||||
use warnings;
|
||||
|
33
perl/Git/IndexInfo.pm
Normal file
33
perl/Git/IndexInfo.pm
Normal file
@ -0,0 +1,33 @@
|
||||
package Git::IndexInfo;
|
||||
use strict;
|
||||
use warnings;
|
||||
use Git qw/command_input_pipe command_close_pipe/;
|
||||
|
||||
sub new {
|
||||
my ($class) = @_;
|
||||
my ($gui, $ctx) = command_input_pipe(qw/update-index -z --index-info/);
|
||||
bless { gui => $gui, ctx => $ctx, nr => 0}, $class;
|
||||
}
|
||||
|
||||
sub remove {
|
||||
my ($self, $path) = @_;
|
||||
if (print { $self->{gui} } '0 ', 0 x 40, "\t", $path, "\0") {
|
||||
return ++$self->{nr};
|
||||
}
|
||||
undef;
|
||||
}
|
||||
|
||||
sub update {
|
||||
my ($self, $mode, $hash, $path) = @_;
|
||||
if (print { $self->{gui} } $mode, ' ', $hash, "\t", $path, "\0") {
|
||||
return ++$self->{nr};
|
||||
}
|
||||
undef;
|
||||
}
|
||||
|
||||
sub DESTROY {
|
||||
my ($self) = @_;
|
||||
command_close_pipe($self->{gui}, $self->{ctx});
|
||||
}
|
||||
|
||||
1;
|
@ -57,6 +57,7 @@ sub new {
|
||||
$self->{file_prop} = {};
|
||||
$self->{absent_dir} = {};
|
||||
$self->{absent_file} = {};
|
||||
require Git::IndexInfo;
|
||||
$self->{gii} = $git_svn->tmp_index_do(sub { Git::IndexInfo->new });
|
||||
$self->{pathnameencoding} = Git::config('svn.pathnameencoding');
|
||||
$self;
|
||||
|
@ -29,6 +29,7 @@ instdir_SQ = $(subst ','\'',$(prefix)/lib)
|
||||
|
||||
modules += Git
|
||||
modules += Git/I18N
|
||||
modules += Git/IndexInfo
|
||||
modules += Git/SVN
|
||||
modules += Git/SVN/Memoize/YAML
|
||||
modules += Git/SVN/Fetcher
|
||||
|
@ -3,10 +3,11 @@
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use Test::More tests => 5;
|
||||
use Test::More tests => 6;
|
||||
|
||||
require_ok 'Git::SVN';
|
||||
require_ok 'Git::SVN::Utils';
|
||||
require_ok 'Git::SVN::Ra';
|
||||
require_ok 'Git::SVN::Log';
|
||||
require_ok 'Git::SVN::Migration';
|
||||
require_ok 'Git::IndexInfo';
|
||||
|
Loading…
Reference in New Issue
Block a user