Code

gitweb: do not choke on recursive symlink
authorJunio C Hamano <gitster@pobox.com>
Fri, 27 Jul 2007 08:23:03 +0000 (01:23 -0700)
committerJunio C Hamano <gitster@pobox.com>
Fri, 3 Aug 2007 08:35:36 +0000 (01:35 -0700)
If somebody used to advertise his repository that physically
resides at /pub/lic.git/ as:

git://git.example.com/pub/lic.git/

but now wants to use --base-path to allow:

git://git.example.com/lic.git/

she can start git-daemon with --base-path option, like this:

git-daemon --base-path=/pub --export-all

During the transition, however, she would also want to allow
older URL as well.  One natural way to achieve that is to create
a symlink:

ln -s /pub /pub/pub

so that a request to git://git.example.com/pub/lic.git/ is first
translated by --base-path to a request to /pub/pub/lic.git/
which goes to /pub/lic.git, thanks to the symlink.

So far so good.

However, gitweb chokes if there is such a symlink (File::Find
barfs with "/pub/pub is a recursive symbolic link").  Make the
code ignore such a symlink.

Signed-off-by: Junio C Hamano <gitster@pobox.com>
gitweb/gitweb.perl

index 498b936dd48bef9a788b56c2ddbbacb63d1e29b6..077eb2f4ca3b597c155a464567f0235a129daa50 100755 (executable)
@@ -1515,6 +1515,7 @@ sub git_get_projects_list {
 
                File::Find::find({
                        follow_fast => 1, # follow symbolic links
+                       follow_skip => 2, # ignore duplicates
                        dangling_symlinks => 0, # ignore dangling symlinks, silently
                        wanted => sub {
                                # skip project-list toplevel, if we get it.