43a9f2ca687284802c2935dff972c08e085c4f54
[ikiwiki.git] / doc / patchqueue / index.html_allowed.mdwn
1 Instead of having files foo.html "in front of" foo/, I prefer to have foo/index.html. This patch allows that. Specifically, foo/index.type is translated to $links{'foo/'}, and bestlink looks for either "foo" or "foo/" when linking to pages. There are other miscellaneous changes that go with that -- parentlinks for "foo/" are the same as for "foo", except one directory higher; basename of "foo/" is "foo"; links to "foo/" are translated to "foo/index.html" rather than "foo/.html". (Links to "foo/" might be preferred, but that causes an infinite loop in writefile, because apparently dirname("foo/") == "foo/" on my system for reasons that aren't clear to me.)
2
3 Looks like this copy got whitespace munged. I'm leaving a copy of the patch on [my site](http://www.betacantrips.com/attic/patch.diff), with correct whitespace, in case anyone else wants to apply it. It should apply cleanly to a freshly unpacked ikiwiki-1.38. --Ethan
4
5     diff -ur -x .svn ikiwiki-orig/IkiWiki/Render.pm ikiwiki/IkiWiki/Render.pm
6     --- ikiwiki-orig/IkiWiki/Render.pm  2006-11-08 01:02:33.000000000 -0500
7     +++ ikiwiki/IkiWiki/Render.pm       2006-11-08 01:02:46.000000000 -0500
8     @@ -57,6 +57,10 @@
9         my $path="";
10         my $skip=1;
11         return if $page eq 'index'; # toplevel
12     +   if ($page =~ m{/$}){
13     +           $page =~s{/$}{};
14     +           $path="..";
15     +   }
16         foreach my $dir (reverse split("/", $page)) {
17                 if (! $skip) {
18                         $path.="../";
19     diff -ur -x .svn ikiwiki-orig/IkiWiki.pm ikiwiki/IkiWiki.pm
20     --- ikiwiki-orig/IkiWiki.pm 2006-11-08 01:02:38.000000000 -0500
21     +++ ikiwiki/IkiWiki.pm      2006-11-08 01:02:48.000000000 -0500
22     @@ -174,6 +174,7 @@
23      sub basename ($) { #{{{
24         my $file=shift;
25
26     +   $file=~s!/$!!;
27         $file=~s!.*/+!!;
28         return $file;
29      } #}}}
30     @@ -200,12 +201,14 @@
31         my $type=pagetype($file);
32         my $page=$file;
33         $page=~s/\Q.$type\E*$// if defined $type;
34     +   $page=~s#index$## if $page=~m{/index$};
35         return $page;
36      } #}}}
37
38      sub htmlpage ($) { #{{{
39         my $page=shift;
40
41     +   return $page."index.html" if $page=~m{/$};
42         return $page.".html";
43      } #}}}
44
45     @@ -289,6 +292,7 @@
46         my $page=shift;
47         my $link=shift;
48
49     +   $page =~ s!/$!!;
50         my $cwd=$page;
51         do {
52                 my $l=$cwd;
53     @@ -298,6 +302,9 @@
54                 if (exists $links{$l}) {
55                         return $l;
56                 }
57     +           if (exists $links{$l.'/'}){
58     +                   return $l.'/';
59     +           }
60                 elsif (exists $pagecase{lc $l}) {
61                         return $pagecase{lc $l};
62                 }
63