sched/assimilate.C
with an application-specific function of the form
int assimilate_handler(
WORKUNIT& wu, vector<RESULT>& results, RESULT& canononical_result
);
This is called when either
- The workunit has a nonzero
error mask
(indicating, for example, too many error results).
In this case the handler might write a message to a log
or send an email to the application developer.
- The workunit has a canonical result.
In this case wu.canonical_resultid will be nonzero,
canonical_result will contain the canonical result.
Your handler might, for example, parse the canonical result's
output file and write its contents to a separate database.
In both cases the 'results' vector will be populated with
all the workunit's results (including unsuccessful and unsent ones).
All files (both input and output) will generally be on disk.
It's possible that both conditions might hold.
If assimilate_handler() returns zero,
the workunit record will be marked as assimilated.
If assimilate_handler() returns nonzero,
the assimilator will print an error message and exit.
Typically you should do this in any error situation.
You can use BOINC's
back-end utility functions
to get file pathnames and open files.
";
page_tail();
?>