// 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): // // This is a framework for an assimilator. // You need to link with with an (application-specific) function // assimilate_handler() // in order to make a complete program. // #include #include #include #include #include #include "boinc_db.h" #include "parse.h" #include "util.h" #include "sched_config.h" #include "sched_util.h" #include "sched_msgs.h" #include "assimilate_handler.h" using std::vector; #define LOCKFILE "assimilator.out" #define PIDFILE "assimilator.pid" SCHED_CONFIG config; bool update_db = true; bool noinsert = false; #define SLEEP_INTERVAL 10 // assimilate all WUs that need it // return nonzero if did anything // bool do_pass(APP& app) { DB_WORKUNIT wu; DB_RESULT canonical_result, result; bool did_something = false; char buf[256]; int retval; int num_assimilated=0; check_stop_daemons(); sprintf(buf, "where appid=%d and assimilate_state=%d limit 1000", app.id, ASSIMILATE_READY); while (!wu.enumerate(buf)) { vector results; // must be inside while()! // for testing purposes, pretend we did nothing // if (update_db) { did_something = true; } log_messages.printf(SCHED_MSG_LOG::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; } } retval = assimilate_handler(wu, results, canonical_result); if (retval) { log_messages.printf(SCHED_MSG_LOG::CRITICAL, "[%s] handler returned error %d; exiting\n", wu.name, retval ); } if (update_db) { sprintf( buf, "assimilate_state=%d, transition_time=%d", ASSIMILATE_DONE, (int)time(0) ); retval = wu.update_field(buf); if (retval) { log_messages.printf(SCHED_MSG_LOG::CRITICAL, "[%s] update failed: %d\n", wu.name, retval ); exit(1); } } num_assimilated++; } if (did_something) { boinc_db.commit_transaction(); } if (num_assimilated) { log_messages.printf(SCHED_MSG_LOG::NORMAL, "Assimilated %d workunits.\n", num_assimilated ); } return did_something; } int main(int argc, char** argv) { int retval; bool asynch = false, one_pass = false; DB_APP app; int i; char buf[256]; check_stop_daemons(); for (i=1; i