summaryrefslogtreecommitdiff
path: root/IkiWiki.pm
diff options
context:
space:
mode:
authorJoey Hess <joey@kitenet.net>2010-04-23 14:44:37 -0400
committerJoey Hess <joey@kitenet.net>2010-04-23 14:44:37 -0400
commit54898d16d4c86fddcb1b5588eac67a729c14deeb (patch)
treefd401da58dda87274edd5b0eac308c86819c3564 /IkiWiki.pm
parent011d88052d6dacb6a9d84b1489d37eefeb992da1 (diff)
allow a bare page name to be specified as a template
Diffstat (limited to 'IkiWiki.pm')
-rw-r--r--IkiWiki.pm31
1 files changed, 21 insertions, 10 deletions
diff --git a/IkiWiki.pm b/IkiWiki.pm
index 0aaf60569..03441b594 100644
--- a/IkiWiki.pm
+++ b/IkiWiki.pm
@@ -1653,9 +1653,18 @@ sub saveindex () {
sub template_file ($) {
my $name=shift;
+
+ my $tpage="templates/$name";
+ if ($name !~ /\.tmpl$/ && exists $pagesources{$tpage}) {
+ $tpage=$pagesources{$tpage};
+ $name.=".tmpl";
+ }
- my $template=srcfile("templates/$name", 1);
- return $template if defined $template;
+ my $template=srcfile($tpage, 1);
+ if (defined $template) {
+ return $template, $tpage if wantarray;
+ return $template;
+ }
foreach my $dir ($config{templatedir},
"$installdir/share/ikiwiki/templates") {
@@ -1664,18 +1673,16 @@ sub template_file ($) {
return;
}
-sub template ($;@) {
- template_depends(shift, undef, @_);
-}
-
sub template_depends ($$;@) {
my $name=shift;
my $page=shift;
-
- if (defined $page) {
- add_depends($page, "templates/$name");
+
+ my ($filename, $tpage)=template_file($name);
+ if (defined $page && defined $tpage) {
+ add_depends($page, $tpage);
}
- my $filename=template_file($name);
+
+ return unless defined $filename;
require HTML::Template;
return HTML::Template->new(
@@ -1691,6 +1698,10 @@ sub template_depends ($$;@) {
);
}
+sub template ($;@) {
+ template_depends(shift, undef, @_);
+}
+
sub misctemplate ($$;@) {
my $title=shift;
my $pagebody=shift;