X-Git-Url: https://sipb.mit.edu/gitweb.cgi/ikiwiki.git/blobdiff_plain/65d0aee407f81db9ca2261fc8ecb1958f62302a9..93c6d2c340b9529eedf611d6e753030cc9c29ae9:/IkiWiki/Plugin/brokenlinks.pm diff --git a/IkiWiki/Plugin/brokenlinks.pm b/IkiWiki/Plugin/brokenlinks.pm index deee58222..fa34a7008 100644 --- a/IkiWiki/Plugin/brokenlinks.pm +++ b/IkiWiki/Plugin/brokenlinks.pm @@ -4,11 +4,10 @@ package IkiWiki::Plugin::brokenlinks; use warnings; use strict; -use IkiWiki; +use IkiWiki 2.00; sub import { #{{{ - IkiWiki::hook(type => "preprocess", id => "brokenlinks", - call => \&preprocess); + hook(type => "preprocess", id => "brokenlinks", call => \&preprocess); } # }}} sub preprocess (@) { #{{{ @@ -17,24 +16,25 @@ 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 @broken; - foreach my $page (%IkiWiki::links) { - if (IkiWiki::globlist_match($page, $params{pages})) { - foreach my $link (@{$IkiWiki::links{$page}}) { - next if $link =~ /.*\/discussion/i && $IkiWiki::config{discussion}; - my $bestlink=IkiWiki::bestlink($page, $link); + foreach my $page (keys %links) { + if (pagespec_match($page, $params{pages}, location => $params{page})) { + my $discussion=gettext("discussion"); + foreach my $link (@{$links{$page}}) { + next if $link =~ /.*\/\Q$discussion\E/i && $config{discussion}; + my $bestlink=bestlink($page, $link); next if length $bestlink; push @broken, - IkiWiki::htmllink($page, $page, $link, 1). - " in ". - IkiWiki::htmllink($params{page}, $params{page}, $page, 1); + htmllink($page, $params{destpage}, $link, noimageinline => 1). + " from ". + htmllink($params{page}, $params{destpage}, $page, noimageinline => 1); } } } - return "There are no broken links!" unless @broken; + return gettext("There are no broken links!") unless @broken; my %seen; return "\n"; } # }}}