From cd5afe22a22c4d018c579abc768726005477158a Mon Sep 17 00:00:00 2001 From: "http://www.cse.unsw.edu.au/~willu/" Date: Sun, 24 Aug 2008 03:19:39 -0400 Subject: Might help to put the right version in... --- ...n_to_list_available_pre-processor_commands.mdwn | 49 +++++++++++++++------- 1 file changed, 35 insertions(+), 14 deletions(-) diff --git a/doc/todo/Add_a_plugin_to_list_available_pre-processor_commands.mdwn b/doc/todo/Add_a_plugin_to_list_available_pre-processor_commands.mdwn index fd2961c21..765f2c622 100644 --- a/doc/todo/Add_a_plugin_to_list_available_pre-processor_commands.mdwn +++ b/doc/todo/Add_a_plugin_to_list_available_pre-processor_commands.mdwn @@ -113,9 +113,6 @@ I've found myself wanting to know which [[plugins]] are switched on so I know wh >>>>>>> pages get linked correctly, and missing pages get normal creation >>>>>>> links. The old patch is still here if you decide you prefer that. -- [[Will]] -Note that because there are double square brackets in the source, this might not -display quite right. - #!/usr/bin/perl # Ikiwiki listpreprocessors plugin. package IkiWiki::Plugin::listpreprocessors; @@ -126,8 +123,9 @@ display quite right. sub import { #{{{ hook(type => "getsetup", id => "listpreprocessors", call => \&getsetup); - hook(type => "preprocess", id => "listpreprocessors", call => \&preprocess); hook(type => "checkconfig", id => "listpreprocessors", call => \&checkconfig); + hook(type => "needsbuild", id => "listpreprocessors", call => \&needsbuild); + hook(type => "preprocess", id => "listpreprocessors", call => \&preprocess); } # }}} sub getsetup () { #{{{ @@ -144,37 +142,60 @@ display quite right. }, } #}}} + my @fullPluginList; my @earlyPluginList; + my $pluginString; sub checkconfig () { #{{{ + if (!defined $config{plugin_description_dir}) { + $config{plugin_description_dir} = "ikiwiki/plugin/"; + } - if (!defined $config{plugin_description_dir}) { - $config{plugin_description_dir} = "ikiwiki/plugin/"; - } - - @earlyPluginList = sort( keys %{ $IkiWiki::hooks{preprocess} } ); + @earlyPluginList = sort( keys %{ $IkiWiki::hooks{preprocess} } ); } #}}} + sub needsbuild (@) { #{{{ + my $needsbuild=shift; + + @fullPluginList = sort( keys %{ $IkiWiki::hooks{preprocess} } ); + $pluginString = join (' ', @earlyPluginList) . " : ". join (' ', @fullPluginList); + + foreach my $page (keys %pagestate) { + if (exists $pagestate{$page}{listpreprocessors}{shown}) { + if ($pagestate{$page}{listpreprocessors}{shown} ne $pluginString) { + push @$needsbuild, $pagesources{$page}; + } + if (exists $pagesources{$page} && + grep { $_ eq $pagesources{$page} } @$needsbuild) { + # remove state, will be re-added if + # the [[!listpreprocessors]] is still there during the + # rebuild + delete $pagestate{$page}{listpreprocessors}{shown}; + } + } + } + } # }}} + sub preprocess (@) { #{{{ my %params=@_; + $pagestate{$params{destpage}}{listpreprocessors}{shown}=$pluginString; + my @pluginlist; if (! defined $params{generated}) { - @pluginlist = sort( keys %{ $IkiWiki::hooks{preprocess} } ); + @pluginlist = @fullPluginList; } else { @pluginlist = @earlyPluginList; } my $result = '"; - print $result; + $result .= ""; return IkiWiki::preprocess($params{page}, $params{destpage}, IkiWiki::filter($params{page}, $params{destpage}, $result)); -- cgit v1.2.3