aboutsummaryrefslogtreecommitdiff
path: root/IkiWiki/Render.pm
diff options
context:
space:
mode:
authorintrigeri <intrigeri@boum.org>2010-07-30 16:05:07 +0200
committerintrigeri <intrigeri@boum.org>2010-07-30 16:14:23 +0200
commit25447bccae0439ea56da7a788482a4807c7c459d (patch)
tree21d63415d77cc97890a493b035a083970fb09b84 /IkiWiki/Render.pm
parent1fe87a0808ee4d19d97956d48447644c69334f8a (diff)
downloadikiwiki-25447bccae0439ea56da7a788482a4807c7c459d.tar
ikiwiki-25447bccae0439ea56da7a788482a4807c7c459d.tar.gz
Added a rescan hook.
This is needed for the po plugin vs. e.g. meta titles. In order to get rid of the ugly "rebuilding all pages to fix meta titles" thing, Joey suggested to make "po, at scan time, re-run the scan hooks, passing them modified content (either converted from po to mdwn or with the escaped stuff cheaply de-escaped)". This would unfortunately not work, as the meta plugin gathers its data using the preprocess hook in scan mode: it would overwrite with buggy data the correct data we would have forced it to gather in po's scan hook. We then need a hook that runs *after* the preprocess hook has been run in scan mode, but *before* any page rendering is started. Hence this one.
Diffstat (limited to 'IkiWiki/Render.pm')
-rw-r--r--IkiWiki/Render.pm8
1 files changed, 8 insertions, 0 deletions
diff --git a/IkiWiki/Render.pm b/IkiWiki/Render.pm
index a653ab2da..5ce802317 100644
--- a/IkiWiki/Render.pm
+++ b/IkiWiki/Render.pm
@@ -183,6 +183,14 @@ sub scan ($) {
# Preprocess in scan-only mode.
preprocess($page, $page, $content, 1);
+
+ run_hooks(rescan => sub {
+ shift->(
+ page => $page,
+ content => $content,
+ );
+ });
+
}
else {
will_render($file, $file, 1);