X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/299bb8bef3811b16d29a0e8ebb2c292c8dd11020..e163b037bf3c9fa68be0971752e6d6584f8d55fd:/IkiWiki/Plugin/pagestats.pm diff --git a/IkiWiki/Plugin/pagestats.pm b/IkiWiki/Plugin/pagestats.pm index 1d4d5ecdf..de4b7d068 100644 --- a/IkiWiki/Plugin/pagestats.pm +++ b/IkiWiki/Plugin/pagestats.pm @@ -7,21 +7,29 @@ # (default) # table: produces a table with the number of backlinks for each page # -# By Enrico Zini. +# by Enrico Zini package IkiWiki::Plugin::pagestats; use warnings; use strict; -use IkiWiki; +use IkiWiki 2.00; # Names of the HTML classes to use for the tag cloud our @classes = ('smallestPC', 'smallPC', 'normalPC', 'bigPC', 'biggestPC' ); sub import { #{{{ - IkiWiki::hook(type => "preprocess", id => "pagestats", - call => \&preprocess); + hook(type => "getsetup", id => "pagestats", call => \&getsetup); + hook(type => "preprocess", id => "pagestats", call => \&preprocess); } # }}} +sub getsetup () { #{{{ + return + plugin => { + safe => 1, + rebuild => undef, + }, +} #}}} + sub preprocess (@) { #{{{ my %params=@_; $params{pages}="*" unless defined $params{pages}; @@ -29,14 +37,14 @@ sub preprocess (@) { #{{{ # Needs to update whenever a page is added or removed, so # register a dependency. - IkiWiki::add_depends($params{page}, $params{pages}); + add_depends($params{page}, $params{pages}); my %counts; my $max = 0; - foreach my $page (%IkiWiki::links) { - if (IkiWiki::globlist_match($page, $params{pages})) { - my @bl = IkiWiki::backlinks($page); - $counts{$page} = scalar(@bl); + foreach my $page (keys %links) { + if (pagespec_match($page, $params{pages}, location => $params{page})) { + use IkiWiki::Render; + $counts{$page} = scalar(IkiWiki::backlinks($page)); $max = $counts{$page} if $counts{$page} > $max; } } @@ -45,19 +53,20 @@ sub preprocess (@) { #{{{ return "
". - IkiWiki::htmllink($params{page}, $params{destpage}, $_, 1). + htmllink($params{page}, $params{destpage}, $_, noimageinline => 1). " | ".$counts{$_}." |