// The contents of this file are subject to the Mozilla 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://www.mozilla.org/MPL/ // // 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 ASSIMILATOR_LOCKFILE "assimilator.out" 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; sprintf(buf, "Assimilating WU %s, assim state %d\n", wu.name, wu.assimilate_state ); write_log(buf, MSG_DEBUG); 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