* aggregate: Fork a child process to handle the aggregation. This simplifies

the code, since that process can change internal state as needed, and
  it will automatically be cleaned up for the parent process, which proceeds
  to render the changes.
master
Joey Hess 2008-01-24 17:22:39 -05:00
parent 39ee5fb8c6
commit 4f872b5633
2 changed files with 23 additions and 14 deletions

View File

@ -37,14 +37,25 @@ sub checkconfig () { #{{{
debug("wiki is locked by another process, not aggregating");
exit 1;
}
loadstate();
IkiWiki::loadindex();
aggregate();
expire();
savestate();
clearstate();
# Fork a child process to handle the aggregation.
# The parent process will then handle building the result.
# This avoids messy code to clear state accumulated while
# aggregating.
defined(my $pid = fork) or error("Cant fork: $!");
if (! $pid) {
loadstate();
IkiWiki::loadindex();
aggregate();
expire();
savestate();
exit 0;
}
waitpid($pid,0);
if ($?) {
error "aggregation failed with code $?";
}
IkiWiki::unlockwiki();
}
} #}}}
@ -211,12 +222,6 @@ sub savestate () { #{{{
error("rename $newfile: $!", $cleanup);
} #}}}
sub clearstate () { #{{{
%feeds=();
%guids=();
$state_loaded=0;
} #}}}
sub expire () { #{{{
foreach my $feed (values %feeds) {
next unless $feed->{expireage} || $feed->{expirecount};

4
debian/changelog vendored
View File

@ -5,6 +5,10 @@ ikiwiki (2.21) UNRELEASED; urgency=low
those older versions too.
* aggregate: Don't let feeds set creation times for pages in the future.
* Add full parser for git diff-tree output (Brian Downing)
* aggregate: Fork a child process to handle the aggregation. This simplifies
the code, since that process can change internal state as needed, and
it will automatically be cleaned up for the parent process, which proceeds
to render the changes.
-- Joey Hess <joeyh@debian.org> Fri, 11 Jan 2008 15:09:37 -0500