X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/be02a80b7a19f3c33a8ea42c0750d94e0a91206f..e258575c12be1594be8d4740ec3ba84bfe7f96a6:/IkiWiki/Plugin/meta.pm diff --git a/IkiWiki/Plugin/meta.pm b/IkiWiki/Plugin/meta.pm index 1a9f94a12..b857f453e 100644 --- a/IkiWiki/Plugin/meta.pm +++ b/IkiWiki/Plugin/meta.pm @@ -179,6 +179,17 @@ sub preprocess (@) { '" title="'.encode_entities($title). "\" type=\"text/css\" />", $page, $destpage); } + elsif ($key eq 'script') { + my $defer=exists $params{defer} ? ' defer="defer"' : ''; + my $async=exists $params{async} ? ' async="async"' : ''; + my $js=bestlink($page, $value.".js"); + if (! length $js) { + error gettext("script not found"); + } + push @{$metaheaders{$page}}, scrub('', + $page, $destpage); + } elsif ($key eq 'openid') { my $delegate=0; # both by default if (exists $params{delegate}) { @@ -206,6 +217,13 @@ sub preprocess (@) { 'content="'.encode_entities($url).'" />'; } } + elsif ($key eq 'foaf') { + if (safeurl($value)) { + push @{$metaheaders{$page}}, ''; + } + } elsif ($key eq 'redir') { return "" if $page ne $destpage; my $safe=0; @@ -289,7 +307,8 @@ sub pagetemplate (@) { $template->param(meta => join("\n", grep { (! $seen{$_}) && ($seen{$_}=1) } @{$metaheaders{$page}})); } if (exists $pagestate{$page}{meta}{title} && $template->query(name => "title")) { - $template->param(title => HTML::Entities::encode_numeric($pagestate{$page}{meta}{title})); + eval q{use HTML::Entities}; + $template->param(title => encode_numeric($pagestate{$page}{meta}{title})); $template->param(title_overridden => 1); } @@ -304,7 +323,8 @@ sub pagetemplate (@) { } foreach my $field (qw{description}) { - $template->param($field => HTML::Entities::encode_numeric($pagestate{$page}{meta}{$field})) + eval q{use HTML::Entities}; + $template->param($field => encode_numeric($pagestate{$page}{meta}{$field})) if exists $pagestate{$page}{meta}{$field} && $template->query(name => $field); }