// The contents of this file are subject to the BOINC Public License // Version 1.0 (the "License"); you may not use this file except in // compliance with the License. You may obtain a copy of the License at // http://boinc.berkeley.edu/license_1.0.txt // // Software distributed under the License is distributed on an "AS IS" // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the // License for the specific language governing rights and limitations // under the License. // // The Original Code is the Berkeley Open Infrastructure for Network Computing. // // The Initial Developer of the Original Code is the SETI@home project. // Portions created by the SETI@home project are Copyright (C) 2002 // University of California at Berkeley. All Rights Reserved. // // Contributor(s): // #include #include #include #include #include #include "boinc_db.h" #include "parse.h" #include "util.h" #include "config.h" #include "sched_util.h" #include "assimilate_handler.h" #define LOCKFILE "assimilator.out" #define PIDFILE "assimilator.pid" CONFIG config; // assimilate all WUs that need it // return nonzero if did anything // bool do_pass(APP& app) { DB_WORKUNIT wu; DB_RESULT canonical_result, result; vector results; bool did_something = false, delete_inputs, delete_outputs; char buf[MAX_BLOB_SIZE]; unsigned int i; check_stop_trigger(); sprintf(buf, "where appid=%d and assimilate_state=%d", app.id, ASSIMILATE_READY); while (!wu.enumerate(buf)) { did_something = true; log_messages.printf(SchedMessages::DEBUG, "[%s] assimilating; state=%d\n", wu.name, wu.assimilate_state); sprintf(buf, "where workunitid=%d", wu.id); while (!result.enumerate(buf)) { results.push_back(result); if (result.id == wu.canonical_resultid) { canonical_result = result; } } assimilate_handler(wu, results, canonical_result); delete_outputs = true; delete_inputs = true; for (i=0; i