]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blobdiff - IkiWiki/Plugin/pedigree.pm
Merge branch 'master' into pedigree
[git.ikiwiki.info.git] / IkiWiki / Plugin / pedigree.pm
index b051a6da2f29bf59ab63d935e866042f8edb580f..f91ea94b484a1ce3bde2966b10878aa593c319f2 100644 (file)
@@ -26,7 +26,8 @@ sub pedigree ($) { #{{{
                push @ret, {
                            url => urlto($path, $page),
                            page => $title,
                push @ret, {
                            url => urlto($path, $page),
                            page => $title,
-                           level => $i,
+                           absdepth => $i,
+                           distance => ($pagedepth - $i),
                            is_root => ($i eq 0),
                            is_second_ancestor => ($i eq 1),
                            is_grand_mother => ($i eq ($pagedepth - 2)),
                            is_root => ($i eq 0),
                            is_second_ancestor => ($i eq 1),
                            is_grand_mother => ($i eq ($pagedepth - 2)),
@@ -39,14 +40,50 @@ sub pedigree ($) { #{{{
        return @ret;
 } #}}}
 
        return @ret;
 } #}}}
 
+sub forget_oldest ($@) { #{{{
+       my $offset=shift;
+       my @pedigree=@_;
+       my @ret;
+       my $parent;
+       unless ($offset ge scalar(@pedigree)) {
+               for (my $i=0; $i < $offset; $i++) {
+                       shift @pedigree;
+               }
+               while (@pedigree) {
+                       # Doing so does not modify the original @pedigree, we've
+                       # got our own copy of its "content" (i.e. a pile of
+                       # references to hashes)...
+                       $parent=shift @pedigree;
+                       # ... but we have no copy of the referenced hashes, so we
+                       # actually are modifying them in-place, which
+                       # means the second (and following) calls to
+                       # this function overwrite the previous one's
+                       # reldepth values => known bug if PEDIGREE_BUT_ROOT and
+                       # PEDIGREE_BUT_TWO_OLDEST are used in the same template
+                       $parent->{reldepth}=($parent->{absdepth} - $offset);
+                       push @ret, $parent;
+               }
+       }
+       return @ret;
+} #}}}
+
 sub pagetemplate (@) { #{{{
        my %params=@_;
         my $page=$params{page};
         my $template=$params{template};
 
 sub pagetemplate (@) { #{{{
        my %params=@_;
         my $page=$params{page};
         my $template=$params{template};
 
-       if ($template->query(name => "pedigree")) {
-               $template->param(pedigree => [pedigree($page)]);
-       }
+       my @pedigree=pedigree($page)
+         if ($template->query(name => "pedigree")
+             or $template->query(name => "pedigree_but_root")
+             or $template->query(name => "pedigree_but_two_oldest")
+            );
+
+       $template->param(pedigree => \@pedigree)
+         if ($template->query(name => "pedigree"));
+       $template->param(pedigree_but_root => [forget_oldest(1, @pedigree)])
+         if ($template->query(name => "pedigree_but_root"));
+       $template->param(pedigree_but_two_oldest => [forget_oldest(2, @pedigree)])
+         if ($template->query(name => "pedigree_but_two_oldest"));
 
 } # }}}
 
 
 } # }}}