git-svn: don't attempt to minimize URLs by default
commit4a1bb4c3f87f355dd52fcd0babcbd005d59d7ed6
authorEric Wong <normalperson@yhbt.net>
Sun, 13 May 2007 16:58:14 +0000 (13 09:58 -0700)
committerJunio C Hamano <junkio@cox.net>
Sun, 13 May 2007 19:10:43 +0000 (13 12:10 -0700)
tree7ec45387787a384d1cc1383de20a4b7031a639e0
parent4c03c3eb4e31c2d1f88ca0c7106c647a246e81ff
git-svn: don't attempt to minimize URLs by default

For tracking branches and tags, git-svn prefers to connect
to the root of the repository or at least the level that
houses branches and tags as well as trunk.  However, users
that are accustomed to tracking a single directory have
no use for this feature.

As pointed out by Junio, users may not have permissions to
connect to connect to a higher-level path in the repository.

While the current minimize_url() function detects lack of
permissions to certain paths _after_ successful logins, it
cannot effectively determine if it is trying to access a
login-only portion of a repo when the user expects to
connect to a part where anonymous access is allowed.

For people used to the git-svnimport switches of
--trunk, --tags, --branches, they'll already pass the
repository root (or root+subdirectory), so minimize URL
isn't of too much use to them, either.

For people *not* used to git-svnimport, git-svn also
supports:

 git svn init --minimize-url \
  --trunk http://repository-root/foo/trunk \
  --branches http://repository-root/foo/branches \
  --tags http://repository-root/foo/tags

And this is where the new --minimize-url command-line switch
comes in to allow for this behavior to continue working.
git-svn.perl
t/t9100-git-svn-basic.sh
t/t9104-git-svn-follow-parent.sh
t/t9105-git-svn-commit-diff.sh
t/t9110-git-svn-use-svm-props.sh
t/t9111-git-svn-use-svnsync-props.sh