summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 52e7787)
raw | patch | inline | side by side (parent: 52e7787)
author | Michael Lai <myllai@gmail.com> | |
Mon, 9 Mar 2009 18:45:47 +0000 (11:45 -0700) | ||
committer | Eric Wong <normalperson@yhbt.net> | |
Mon, 9 Mar 2009 21:52:12 +0000 (14:52 -0700) |
For repositories laid out like the following:
[svn-remote "svn"]
url = http://foo.com/svn/repos/bar
fetch = myproject/trunk:refs/remotes/trunk
branches = bar/myproject/branches/*:refs/remotes/*
tags = bar/myproject/tags/*:refs/remotes/tags/*
The "bar" component above is considered the intermediate path
and was not handled correctly.
Signed-off-by: Michael Lai <myllai@gmail.com>
Acked-by: Eric Wong <normalperson@yhbt.net>
[svn-remote "svn"]
url = http://foo.com/svn/repos/bar
fetch = myproject/trunk:refs/remotes/trunk
branches = bar/myproject/branches/*:refs/remotes/*
tags = bar/myproject/tags/*:refs/remotes/tags/*
The "bar" component above is considered the intermediate path
and was not handled correctly.
Signed-off-by: Michael Lai <myllai@gmail.com>
Acked-by: Eric Wong <normalperson@yhbt.net>
git-svn.perl | patch | blob | history |
diff --git a/git-svn.perl b/git-svn.perl
index 959eb52f3fbe01c5f13eeb169549da98b0b9d64f..8be6be00c6cc76bcf2fc2d9b1fe331ec5e81fd2e 100755 (executable)
--- a/git-svn.perl
+++ b/git-svn.perl
if (my $path = $paths->{"/$self->{path}"}) {
return ($path->{action} eq 'D') ? 0 : 1;
}
- $self->{path_regex} ||= qr/^\/\Q$self->{path}\E\//;
+ my $repos_root = $self->ra->{repos_root};
+ my $extended_path = $self->{url} . '/' . $self->{path};
+ $extended_path =~ s#^\Q$repos_root\E(/|$)##;
+ $self->{path_regex} ||= qr/^\/\Q$extended_path\E\//;
if (grep /$self->{path_regex}/, keys %$paths) {
return 1;
}