]> sipb.mit.edu Git - ikiwiki.git/blob - IkiWiki/Plugin/orphans.pm
bugs
[ikiwiki.git] / IkiWiki / Plugin / orphans.pm
1 #!/usr/bin/perl
2 # Provides a list of pages no other page links to.
3 package IkiWiki::Plugin::orphans;
4
5 use warnings;
6 use strict;
7 use IkiWiki;
8
9 sub import { #{{{
10         hook(type => "preprocess", id => "orphans", call => \&preprocess);
11 } # }}}
12
13 sub preprocess (@) { #{{{
14         my %params=@_;
15         $params{pages}="*" unless defined $params{pages};
16         
17         # Needs to update whenever a page is added or removed, so
18         # register a dependency.
19         add_depends($params{page}, $params{pages});
20         
21         my %linkedto;
22         foreach my $p (keys %links) {
23                 map { $linkedto{bestlink($p, $_)}=1 if length $_ }
24                         @{$links{$p}};
25         }
26         
27         my @orphans;
28         foreach my $page (keys %renderedfiles) {
29                 next if $linkedto{$page};
30                 next unless pagespec_match($page, $params{pages});
31                 # If the page has a link to some other page, it's
32                 # indirectly linked to a page via that page's backlinks.
33                 next if grep { 
34                         length $_ &&
35                         ($_ !~ /\/Discussion$/i || ! $config{discussion}) &&
36                         bestlink($page, $_) !~ /^($page|)$/ 
37                 } @{$links{$page}};
38                 push @orphans, $page;
39         }
40         
41         return "All pages are linked to by other pages." unless @orphans;
42         return "<ul>\n".join("\n", map { "<li>".htmllink($params{page}, $params{destpage}, $_, 1)."</li>" } sort @orphans)."</ul>\n";
43 } # }}}
44
45 1