2 # Ikiwiki listdirectives plugin.
3 package IkiWiki
::Plugin
::listdirectives
;
10 add_underlay
("directives");
11 hook
(type
=> "getsetup", id
=> "listdirectives", call
=> \
&getsetup
);
12 hook
(type
=> "checkconfig", id
=> "listdirectives", call
=> \
&checkconfig
);
13 hook
(type
=> "needsbuild", id
=> "listdirectives", call
=> \
&needsbuild
);
14 hook
(type
=> "preprocess", id
=> "listdirectives", call
=> \
&preprocess
);
24 directive_description_dir
=> {
26 description
=> "directory in srcdir that contains directive descriptions",
27 example
=> "ikiwiki/directive",
38 if (! defined $config{directive_description_dir
}) {
39 $config{directive_description_dir
} = "ikiwiki/directive";
42 $config{directive_description_dir
} =~ s/\/+$//;
49 @fulllist = grep { ! /^_/ } sort keys %{$IkiWiki::hooks
{preprocess
}};
50 @shortlist = grep { ! $IkiWiki::hooks
{preprocess
}{$_}{shortcut
} } @fulllist;
51 $pluginstring = join(' ', @shortlist) . " : " . join(' ', @fulllist);
53 foreach my $page (keys %pagestate) {
54 if (exists $pagestate{$page}{listdirectives
}{shown
}) {
55 if ($pagestate{$page}{listdirectives
}{shown
} ne $pluginstring) {
56 push @
$needsbuild, $pagesources{$page};
58 if (exists $pagesources{$page} &&
59 grep { $_ eq $pagesources{$page} } @
$needsbuild) {
60 # remove state, will be re-added if
61 # the [[!listdirectives]] is still there during the
63 delete $pagestate{$page}{listdirectives
}{shown
};
74 $pagestate{$params{destpage
}}{listdirectives
}{shown
}=$pluginstring;
78 if (defined $params{generated
}) {
79 @pluginlist = @fulllist;
82 @pluginlist = @shortlist;
85 my $result = '<ul class="listdirectives">';
87 foreach my $plugin (@pluginlist) {
88 $result .= '<li class="listdirectives">';
89 my $link=linkpage
($config{directive_description_dir
}."/".$plugin);
90 add_depends
($params{page
}, $link, deptype
("presence"));
91 $result .= htmllink
($params{page
}, $params{destpage
}, $link);