diff options
author | Joey Hess <joey@kitenet.net> | 2013-07-21 13:51:35 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2013-07-21 13:51:35 -0400 |
commit | 4c88a4d9d8fb62e8e4bea068a2546059bd1fa306 (patch) | |
tree | 8e2512a7df7fe530083dca2203b08eb4c6d2e111 /IkiWiki/Plugin/meta.pm | |
parent | 7d938559cb9994211d2917491c503f729d220abb (diff) | |
parent | 5c0a18e75a5bf9d6ce9da3a1a525117fe9ee8e47 (diff) | |
download | ikiwiki-4c88a4d9d8fb62e8e4bea068a2546059bd1fa306.tar ikiwiki-4c88a4d9d8fb62e8e4bea068a2546059bd1fa306.tar.gz |
Merge remote-tracking branch 'schmonz/fancypodcast'
Diffstat (limited to 'IkiWiki/Plugin/meta.pm')
-rw-r--r-- | IkiWiki/Plugin/meta.pm | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/IkiWiki/Plugin/meta.pm b/IkiWiki/Plugin/meta.pm index 7ea70b5d1..e7b96bdf1 100644 --- a/IkiWiki/Plugin/meta.pm +++ b/IkiWiki/Plugin/meta.pm @@ -121,6 +121,18 @@ sub preprocess (@) { add_link($page, $value); return ""; } + elsif ($key eq 'enclosure') { + my $link=bestlink($page, $value); + if (! length $link) { + error gettext("enclosure not found") + } + add_depends($page, $link, deptype("presence")); + + $value=urlto($link, $page, 1); + $pagestate{$page}{meta}{enclosure}=$value; + $pagestate{$page}{meta}{enclosurefile}=$link; + # fallthrough + } elsif ($key eq 'author') { $pagestate{$page}{meta}{author}=$value; if (exists $params{sortas}) { @@ -318,6 +330,10 @@ sub pagetemplate (@) { $template->param(title_overridden => 1); } + if (exists $pagestate{$page}{meta}{enclosure}) { + $template->param(enclosure => HTML::Entities::encode_entities(IkiWiki::urlabs($pagestate{$page}{meta}{enclosure}, $config{url}))); + } + foreach my $field (qw{authorurl}) { eval q{use HTML::Entities}; $template->param($field => HTML::Entities::encode_entities($pagestate{$page}{meta}{$field})) |