2 # Provides a list of broken links.
3 package IkiWiki::Plugin::brokenlinks;
10 IkiWiki::register_plugin("preprocess", "brokenlinks", \&preprocess);
13 sub preprocess (@) { #{{{
15 $params{pages}="*" unless defined $params{pages};
17 # Needs to update whenever a page is added or removed, so
18 # register a dependency.
19 IkiWiki::add_depends($params{page}, $params{pages});
22 foreach my $page (%IkiWiki::links) {
23 if (IkiWiki::globlist_match($page, $params{pages})) {
24 foreach my $link (@{$IkiWiki::links{$page}}) {
25 next if $link =~ /.*\/discussion/i;
26 my $bestlink=IkiWiki::bestlink($page, $link);
27 next if length $bestlink;
29 IkiWiki::htmllink($page, $link, 1).
31 IkiWiki::htmllink($params{page}, $page, 1);
36 return "There are no broken links!" unless @broken;
37 return "<ul>\n".join("\n", map { "<li>$_</li>" } sort @broken)."</ul>\n";