X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/2df8696b5f234095a89182e53279fb6c61258711..97e21ae21caa2418015ae512755e8078a0bc5ccf:/IkiWiki/Plugin/aggregate.pm?ds=sidebyside diff --git a/IkiWiki/Plugin/aggregate.pm b/IkiWiki/Plugin/aggregate.pm index e93492863..e000bc864 100644 --- a/IkiWiki/Plugin/aggregate.pm +++ b/IkiWiki/Plugin/aggregate.pm @@ -120,46 +120,52 @@ sub htmlize (@) { #{{{ return $params{content}; } #}}} +# Used by ikiwiki-transition aggregateinternal. sub migrate_to_internal { #{{{ - if (! lockaggregate()) { - error("an aggregation process is already running"); - return; + error("an aggregation process is currently running"); } IkiWiki::lockwiki(); loadstate(); + $config{verbose}=1; foreach my $data (values %guids) { next unless $data->{page}; - + next if $data->{expired}; + $config{aggregateinternal} = 0; my $oldname = pagefile($data->{page}); - + my $oldoutput = $config{destdir}."/".IkiWiki::htmlpage($data->{page}); + $config{aggregateinternal} = 1; my $newname = pagefile($data->{page}); - - print "I: $oldname -> $newname\n"; + + debug "moving $oldname -> $newname"; if (-e $newname) { if (-e $oldname) { error("$newname already exists"); } else { - print STDERR - "W: already renamed to $newname?\n"; + debug("already renamed to $newname?"); } } elsif (-e $oldname) { rename($oldname, $newname) || error("$!"); } else { - print "W: $oldname not found\n"; + debug("$oldname not found"); + } + if (-e $oldoutput) { + require IkiWiki::Render; + debug("removing output file $oldoutput"); + IkiWiki::prune($oldoutput); } } - + savestate(); IkiWiki::unlockwiki; - + unlockaggregate(); } #}}}