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>
This commit is contained in:
Eric Wong 2016-06-20 21:52:53 +00:00
parent ab7797dbe9
commit 6d523a3ab7

View File

@ -1905,15 +1905,22 @@ sub make_log_entry {
my @parents = @$parents;
my $props = $ed->{dir_prop}{$self->path};
if ( $props->{"svk:merge"} ) {
$self->find_extra_svk_parents($props->{"svk:merge"}, \@parents);
}
if ( $props->{"svn:mergeinfo"} ) {
my $mi_changes = $self->mergeinfo_changes
($parent_path, $parent_rev,
$self->path, $rev,
$props->{"svn:mergeinfo"});
$self->find_extra_svn_parents($mi_changes, \@parents);
if ($self->follow_parent) {
my $tickets = $props->{"svk:merge"};
if ($tickets) {
$self->find_extra_svk_parents($tickets, \@parents);
}
my $mergeinfo_prop = $props->{"svn:mergeinfo"};
if ($mergeinfo_prop) {
my $mi_changes = $self->mergeinfo_changes(
$parent_path,
$parent_rev,
$self->path,
$rev,
$mergeinfo_prop);
$self->find_extra_svn_parents($mi_changes, \@parents);
}
}
open my $un, '>>', "$self->{dir}/unhandled.log" or croak $!;