aboutsummaryrefslogtreecommitdiff
path: root/IkiWiki.pm
diff options
context:
space:
mode:
authorJoey Hess <joey@kitenet.net>2010-04-17 12:50:23 -0400
committerJoey Hess <joey@kitenet.net>2010-04-17 12:50:23 -0400
commit54f600af14bf6dc067ffc30ec6f22d517001fe99 (patch)
treeddd20f6f03bc376700f8ebac24f360bf1fe3b269 /IkiWiki.pm
parent7fcc0faf8367c5ae64a3ff06d0d74baa063c4dfc (diff)
parent981400177d68a279f485727be3f013e68f0bf691 (diff)
downloadikiwiki-54f600af14bf6dc067ffc30ec6f22d517001fe99.tar
ikiwiki-54f600af14bf6dc067ffc30ec6f22d517001fe99.tar.gz
Merge remote branch 'davrieb/autotag' into autotag
Conflicts: IkiWiki.pm IkiWiki/Plugin/tag.pm
Diffstat (limited to 'IkiWiki.pm')
-rw-r--r--IkiWiki.pm29
1 files changed, 27 insertions, 2 deletions
diff --git a/IkiWiki.pm b/IkiWiki.pm
index b37b1f344..2f26a16ce 100644
--- a/IkiWiki.pm
+++ b/IkiWiki.pm
@@ -14,7 +14,8 @@ use open qw{:utf8 :std};
use vars qw{%config %links %oldlinks %pagemtime %pagectime %pagecase
%pagestate %wikistate %renderedfiles %oldrenderedfiles
%pagesources %destsources %depends %depends_simple %hooks
- %forcerebuild %loaded_plugins %typedlinks %oldtypedlinks};
+ %forcerebuild %loaded_plugins %typedlinks %oldtypedlinks
+ %autofiles %del_hash};
use Exporter q{import};
our @EXPORT = qw(hook debug error template htmlpage deptype
@@ -22,7 +23,7 @@ our @EXPORT = qw(hook debug error template htmlpage deptype
htmllink readfile writefile pagetype srcfile pagename
displaytime will_render gettext ngettext urlto targetpage
add_underlay pagetitle titlepage linkpage newpagefile
- inject add_link
+ inject add_link add_autofile
%config %links %pagestate %wikistate %renderedfiles
%pagesources %destsources %typedlinks);
our $VERSION = 3.00; # plugin interface version, next is ikiwiki version
@@ -2020,6 +2021,30 @@ sub sortspec_translate ($$) {
return eval 'sub { '.$code.' }';
}
+sub add_autofile ($$) {
+ my $autofile=shift;
+ my $plugin=shift;
+
+ if (srcfile($autofile, 1)) {
+ return 0;
+ }
+
+ my ($file, $page) = verify_src_file("$config{srcdir}/$autofile", $config{srcdir});
+
+ if ((!defined $file) ||
+ (exists $pagestate{$page}{$plugin}{autofile_deleted})) {
+ return 0;
+ }
+
+ if (exists $del_hash{$file}) {
+ $pagestate{$page}{$plugin}{autofile_deleted}=1;
+ return 0;
+ }
+
+ $autofiles{$file}=$plugin;
+ return 1;
+}
+
sub pagespec_translate ($) {
my $spec=shift;