Skip to content

Commit 6d523a3

Browse files
author
Eric Wong
committed
git-svn: skip mergeinfo handling with --no-follow-parent
For repositories without parent following enabled, finding git parents through svn:mergeinfo or svk::parents can be expensive and pointless. Reported-by: Александр Овчинников <proff@proff.email> http://mid.gmane.org/4094761466408188@web24o.yandex.ru Signed-off-by: Eric Wong <e@80x24.org>
1 parent ab7797d commit 6d523a3

File tree

1 file changed

+16
-9
lines changed

1 file changed

+16
-9
lines changed

perl/Git/SVN.pm

Lines changed: 16 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1905,15 +1905,22 @@ sub make_log_entry {
19051905

19061906
my @parents = @$parents;
19071907
my $props = $ed->{dir_prop}{$self->path};
1908-
if ( $props->{"svk:merge"} ) {
1909-
$self->find_extra_svk_parents($props->{"svk:merge"}, \@parents);
1910-
}
1911-
if ( $props->{"svn:mergeinfo"} ) {
1912-
my $mi_changes = $self->mergeinfo_changes
1913-
($parent_path, $parent_rev,
1914-
$self->path, $rev,
1915-
$props->{"svn:mergeinfo"});
1916-
$self->find_extra_svn_parents($mi_changes, \@parents);
1908+
if ($self->follow_parent) {
1909+
my $tickets = $props->{"svk:merge"};
1910+
if ($tickets) {
1911+
$self->find_extra_svk_parents($tickets, \@parents);
1912+
}
1913+
1914+
my $mergeinfo_prop = $props->{"svn:mergeinfo"};
1915+
if ($mergeinfo_prop) {
1916+
my $mi_changes = $self->mergeinfo_changes(
1917+
$parent_path,
1918+
$parent_rev,
1919+
$self->path,
1920+
$rev,
1921+
$mergeinfo_prop);
1922+
$self->find_extra_svn_parents($mi_changes, \@parents);
1923+
}
19171924
}
19181925

19191926
open my $un, '>>', "$self->{dir}/unhandled.log" or croak $!;

0 commit comments

Comments
 (0)