*** empty log message ***

svn path=/trunk/boinc/; revision=2323
This commit is contained in:
Karl Chen 2003-09-11 09:35:19 +00:00
parent 78061e98b1
commit a52bce39d4
2 changed files with 23 additions and 19 deletions

View File

@ -6251,6 +6251,8 @@ Karl 2003/09/07
Karl 2003/09/10
- fixed transitioner bug where canonical result output files got deleted.
- changed all forms of "DB_RESULT result = results[I]" to "DB_RESULTS&
result = results[I]"
Sched/
transitioner.C

View File

@ -48,22 +48,25 @@ SCHED_CONFIG config;
R_RSA_PRIVATE_KEY key;
void handle_wu(DB_WORKUNIT& wu) {
vector<RESULT> results;
DB_RESULT result;
DB_RESULT canonical_result;
vector<DB_RESULT> results;
DB_RESULT* p_canonical_result = NULL;
int nerrors, retval, ninprogress, nsuccess;
int nunsent, ncouldnt_send, nover;
unsigned int i, n;
char buf[256], suffix[256], result_template[MAX_BLOB_SIZE];
char suffix[256], result_template[MAX_BLOB_SIZE];
time_t now = time(0), x;
bool all_over, have_result_to_validate, do_delete;
{
char buf[256];
// scan the results for the WU
//
DB_RESULT result;
sprintf(buf, "where workunitid=%d", wu.id);
while (!result.enumerate(buf)) {
results.push_back(result);
}
}
log_messages.printf(
SchedMessages::DEBUG, "[WU#%d %s] handling WU: enumerated %d results\n",
@ -81,7 +84,7 @@ void handle_wu(DB_WORKUNIT& wu) {
ncouldnt_send = 0;
have_result_to_validate = false;
for (i=0; i<results.size(); i++) {
result = results[i];
DB_RESULT& result = results[i];
switch (result.server_state) {
case RESULT_SERVER_STATE_UNSENT:
@ -164,7 +167,7 @@ void handle_wu(DB_WORKUNIT& wu) {
//
if (wu.error_mask) {
for (i=0; i<results.size(); i++) {
result = results[i];
DB_RESULT& result = results[i];
if (result.server_state == RESULT_SERVER_STATE_UNSENT) {
result.server_state = RESULT_SERVER_STATE_OVER;
result.outcome = RESULT_OUTCOME_DIDNT_NEED;
@ -202,17 +205,16 @@ void handle_wu(DB_WORKUNIT& wu) {
// scan results, see if all over, look for canonical result
//
all_over = true;
canonical_result.id = 0;
for (i=0; i<results.size(); i++) {
result = results[i];
DB_RESULT& result = results[i];
if (result.server_state != RESULT_SERVER_STATE_OVER) {
all_over = false;
}
if (result.id == wu.canonical_resultid) {
canonical_result = result;
p_canonical_result = &result;
}
}
if (wu.canonical_resultid && canonical_result.id == 0) {
if (wu.canonical_resultid && p_canonical_result == 0) {
log_messages.printf(
SchedMessages::CRITICAL,
"[WU#%d %s] can't find canonical result\n",
@ -246,10 +248,10 @@ void handle_wu(DB_WORKUNIT& wu) {
// output of success results can be deleted if validated
//
for (i=0; i<results.size(); i++) {
result = results[i];
DB_RESULT& result = results[i];
// can delete canonical result outputs only if all successful
// results have been validated
if (result.id == canonical_result.id && !all_over) continue;
if (&result == p_canonical_result && !all_over) continue;
do_delete = false;
switch(result.outcome) {
@ -269,7 +271,7 @@ void handle_wu(DB_WORKUNIT& wu) {
wu.transition_time = MAXINT;
for (i=0; i<results.size(); i++) {
result = results[i];
DB_RESULT& result = results[i];
if (result.server_state == RESULT_SERVER_STATE_IN_PROGRESS) {
x = result.sent_time + wu.delay_bound;
if (x < wu.transition_time) {