2006-05-02 04:34:33 +02:00
|
|
|
#!/usr/bin/perl
|
|
|
|
# Provides a list of broken links.
|
|
|
|
package IkiWiki::Plugin::brokenlinks;
|
|
|
|
|
|
|
|
use warnings;
|
|
|
|
use strict;
|
2006-05-02 08:53:33 +02:00
|
|
|
use IkiWiki;
|
2006-05-02 04:34:33 +02:00
|
|
|
|
|
|
|
sub import { #{{{
|
2006-05-03 21:58:58 +02:00
|
|
|
IkiWiki::hook(type => "preprocess", id => "brokenlinks",
|
|
|
|
call => \&preprocess);
|
2006-05-02 04:34:33 +02:00
|
|
|
} # }}}
|
|
|
|
|
|
|
|
sub preprocess (@) { #{{{
|
|
|
|
my %params=@_;
|
|
|
|
$params{pages}="*" unless defined $params{pages};
|
|
|
|
|
|
|
|
# Needs to update whenever a page is added or removed, so
|
|
|
|
# register a dependency.
|
|
|
|
IkiWiki::add_depends($params{page}, $params{pages});
|
|
|
|
|
|
|
|
my @broken;
|
|
|
|
foreach my $page (%IkiWiki::links) {
|
|
|
|
if (IkiWiki::globlist_match($page, $params{pages})) {
|
|
|
|
foreach my $link (@{$IkiWiki::links{$page}}) {
|
2006-05-05 20:20:52 +02:00
|
|
|
next if $link =~ /.*\/discussion/i && $IkiWiki::config{discussion};
|
2006-05-02 04:34:33 +02:00
|
|
|
my $bestlink=IkiWiki::bestlink($page, $link);
|
|
|
|
next if length $bestlink;
|
|
|
|
push @broken,
|
2006-05-26 18:11:53 +02:00
|
|
|
IkiWiki::htmllink($page, $page, $link, 1).
|
2006-05-02 04:34:33 +02:00
|
|
|
" in ".
|
2006-05-26 18:11:53 +02:00
|
|
|
IkiWiki::htmllink($params{page}, $params{page}, $page, 1);
|
2006-05-02 04:34:33 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return "There are no broken links!" unless @broken;
|
2006-05-06 05:57:43 +02:00
|
|
|
my %seen;
|
|
|
|
return "<ul>\n".join("\n", map { "<li>$_</li>" } grep { ! $seen{$_}++ } sort @broken)."</ul>\n";
|
2006-05-02 04:34:33 +02:00
|
|
|
} # }}}
|
|
|
|
|
|
|
|
1
|