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;
|
package Git::SVN::GlobSpec;
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
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->{file_prop} = {};
|
||||||
$self->{absent_dir} = {};
|
$self->{absent_dir} = {};
|
||||||
$self->{absent_file} = {};
|
$self->{absent_file} = {};
|
||||||
|
require Git::IndexInfo;
|
||||||
$self->{gii} = $git_svn->tmp_index_do(sub { Git::IndexInfo->new });
|
$self->{gii} = $git_svn->tmp_index_do(sub { Git::IndexInfo->new });
|
||||||
$self->{pathnameencoding} = Git::config('svn.pathnameencoding');
|
$self->{pathnameencoding} = Git::config('svn.pathnameencoding');
|
||||||
$self;
|
$self;
|
||||||
|
@ -29,6 +29,7 @@ instdir_SQ = $(subst ','\'',$(prefix)/lib)
|
|||||||
|
|
||||||
modules += Git
|
modules += Git
|
||||||
modules += Git/I18N
|
modules += Git/I18N
|
||||||
|
modules += Git/IndexInfo
|
||||||
modules += Git/SVN
|
modules += Git/SVN
|
||||||
modules += Git/SVN/Memoize/YAML
|
modules += Git/SVN/Memoize/YAML
|
||||||
modules += Git/SVN/Fetcher
|
modules += Git/SVN/Fetcher
|
||||||
|
@ -3,10 +3,11 @@
|
|||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
use Test::More tests => 5;
|
use Test::More tests => 6;
|
||||||
|
|
||||||
require_ok 'Git::SVN';
|
require_ok 'Git::SVN';
|
||||||
require_ok 'Git::SVN::Utils';
|
require_ok 'Git::SVN::Utils';
|
||||||
require_ok 'Git::SVN::Ra';
|
require_ok 'Git::SVN::Ra';
|
||||||
require_ok 'Git::SVN::Log';
|
require_ok 'Git::SVN::Log';
|
||||||
require_ok 'Git::SVN::Migration';
|
require_ok 'Git::SVN::Migration';
|
||||||
|
require_ok 'Git::IndexInfo';
|
||||||
|
Loading…
Reference in New Issue
Block a user