return @ret;
} #}}}
-sub preprocess ($$$;$) { #{{{
+my %preprocessing;
+sub preprocess ($$$) { #{{{
my $page=shift; # the page the data comes from
my $destpage=shift; # the page the data will appear in (different for inline)
my $content=shift;
- my $onlystrip=shift || 0; # strip directives without processing
my $handle=sub {
my $escape=shift;
if (length $escape) {
return "[[$command $params]]";
}
- elsif ($onlystrip) {
- return "";
+ elsif ($preprocessing{$page}) {
+ # Avoid loops of preprocessed pages preprocessing
+ # other pages that preprocess them, etc.
+ return "[[$command would cause preprocessing loop]]";
}
elsif (exists $hooks{preprocess}{$command}) {
# Note: preserve order of params, some plugins may
push @params, $val, '';
}
}
- return $hooks{preprocess}{$command}{call}->(
+ $preprocessing{$page}=1;
+ my $ret=$hooks{preprocess}{$command}{call}->(
@params,
page => $page,
destpage => $destpage,
);
+ delete $preprocessing{$page};
+ return $ret;
}
else {
return "[[$command not processed]]";