X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/bf3deab7b07716b232f5be113cfa312e8263af6c..d6fd1f1cc878b5dffdfae30f6dfee77c235c438e:/doc/todo/Add_a_plugin_to_list_available_pre-processor_commands.mdwn 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..b8ef2409d 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,8 +113,29 @@ 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. +>>>>>>>> Can you explain the full/early list (why track both?) and generated parameter? + +>>>>>>>>> If you add in all the shortcuts you get quite a long list. My original idea +>>>>>>>>> was to just track the plugin commands. This is the early list. But then +>>>>>>>>> I thought that it might be nice for someone looking at wiki source and +>>>>>>>>> seeing a shortcut to know where it came from. So I decided to make +>>>>>>>>> displaying the full list an option, with the original concept as the default. + +>>>>>>>>> Another option here might be to generate the full list every time, but give +>>>>>>>>> generated pre-processor commands (e.g. shortcuts) a different css class. +>>>>>>>>> I'm not sure that is better than what I have though. + +>>>>>>>>> I keep track of both in the page state because if a command moves from +>>>>>>>>> a shortcut to the early list (or vice versa) it changes what should be +>>>>>>>>> displayed in the default use of the plugin. I thought about tracking just what +>>>>>>>>> was actually used on the page, but I don't know in the needsbuild hook whether the `generated` +>>>>>>>>> parameter has been supplied (or maybe the plugin is used twice on the page - +>>>>>>>>> once in each form). It was just easier to track both. + +>>>>>>>> Only code change I'd suggest is using `htmllink` rather than +>>>>>>>> generating a wikilink. + +>>>>>>>>> Yeah - that would make sense. done. -- [[Will]] #!/usr/bin/perl # Ikiwiki listpreprocessors plugin. @@ -126,8 +147,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,40 +166,64 @@ 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} } ); + if (defined $params{generated}) { + @pluginlist = @fullPluginList; } else { @pluginlist = @earlyPluginList; } my $result = '"; - - print $result; - return IkiWiki::preprocess($params{page}, $params{destpage}, - IkiWiki::filter($params{page}, $params{destpage}, $result)); + $result .= ""; + + return $result; } # }}} 1 @@ -366,3 +412,5 @@ This is what I was using for `preprocessor-description.tmpl`: The preprocessor command currently has no description. Maybe you should edit this page to add one. + +[[tag done]]