--- capa/capa51/pProj/capalogin.c 1999/10/13 18:45:28 1.2 +++ capa/capa51/pProj/capalogin.c 2000/03/22 21:08:03 1.4 @@ -777,7 +777,8 @@ int type; set_score, /* Score on a set */ term_score=0, /* Total points received */ term_total=0, /* Total points possible */ - result; + result, + tot_num_sets=0; T_entry entry; /* Database entry for a set */ char buf[MAX_BUFFER_SIZE], buf2[MAX_BUFFER_SIZE]; T_header header; /* Problem set header */ @@ -796,6 +797,9 @@ int type; probs_in_set[0]= 0; for (set_idx=1; set_idx<=set; set_idx++) { if (capa_get_header(&header,set_idx)) return; + if ( capa_check_date(CHECK_OPEN_DATE,student_number,*section,set_idx) < 0 ) + continue; + tot_num_sets++; capa_get_entry(&entry,student_number,set_idx); sscanf(header.num_questions,"%d", &(probs_in_set[set_idx]) ); start_at[set_idx] = start_at[set_idx-1]+2*(1+probs_in_set[set_idx-1]/50); @@ -840,8 +844,12 @@ int type; /* SHOW TOTALS */ /* if capalogin_show_summary_score is set to none don't show it */ - sprintf(buf,"%d sets, total=%3d/%3d (%d%%)", set, term_score, term_total, - 100*term_score/term_total); + if (term_total > 0 ) { + sprintf(buf,"%d sets, total=%3d/%3d (%d%%)", tot_num_sets, term_score, term_total, + 100*term_score/term_total); + } else { + sprintf(buf,"%d sets, total=%3d/%3d", tot_num_sets, term_score, term_total); + } result=read_capa_config("capalogin_show_summary_score",buf2); if (result != 0 && result != -1) { if (strcasecmp(buf2,"none")==0) { @@ -860,7 +868,8 @@ int type; /* don't show summary for set if inhibit response is set*/ inhibit_response=capa_check_option(OPTION_INHIBIT_RESPONSE,set_idx,*section); if (inhibit_response > 0) continue; - + if ( capa_check_date(CHECK_OPEN_DATE,student_number,*section,set_idx) < 0 ) + continue; set_score=0; set_start_line=line; /* Stop if not enough lines to summarize set */ @@ -1133,9 +1142,9 @@ int give_response(Problem_t *p,char **a { int can_answer; char tmp_str[MAX_BUFFER_SIZE], *c_answer_str; + char *error=NULL; - - switch( capa_check_answers(p,a,cnt) ) { + switch( capa_check_answers(p,a,cnt,&error) ) { case EXACT_ANS: move(A_ROW,S_COL); clrtoeol(); mvaddstr(A_ROW,S_COL,"*Yes Computer gets:"); @@ -1163,17 +1172,24 @@ int give_response(Problem_t *p,char **a *log_char='Y'; can_answer=NAY; if(*tried < TRY_BOUND) (*tried)++; break; + case WANTED_NUMERIC: move(S_ROW,S_COL); clrtoeol(); + mvaddstr(S_ROW,S_COL,"*Enter a Number Ans"); + *log_char='S'; can_answer=YAK; + break; case SIG_FAIL: move(S_ROW,S_COL); clrtoeol(); mvaddstr(S_ROW,S_COL,"*Adjust Sig. Figs. "); *log_char='S'; can_answer=YAK; + capa_mfree(error); break; case UNIT_FAIL: move(S_ROW,S_COL); clrtoeol(); mvaddstr(S_ROW,S_COL,"*Units incorrect "); *log_char='U'; can_answer=YAK; + capa_mfree(error); break; case UNIT_NOTNEEDED: move(S_ROW,S_COL); clrtoeol(); mvaddstr(S_ROW,S_COL,"*Only a number required"); *log_char='U'; can_answer=YAK; + capa_mfree(error); break; case NO_UNIT: move(S_ROW,S_COL); clrtoeol(); mvaddstr(S_ROW,S_COL,"*Units required "); @@ -1218,19 +1234,20 @@ int give_inhibited_response(Problem_t * { int can_answer; char tmp_str[MAX_BUFFER_SIZE]; + char *error=NULL; - - switch( capa_check_answers(p,a,cnt) ) { + switch( capa_check_answers(p,a,cnt,&error) ) { case EXACT_ANS: *log_char='Y'; break; case APPROX_ANS: *log_char='Y'; break; - case SIG_FAIL: *log_char='S'; break; - case UNIT_FAIL: *log_char='U'; break; - case UNIT_NOTNEEDED: *log_char='U'; break; + case SIG_FAIL: *log_char='S'; capa_mfree(error); break; + case UNIT_FAIL: *log_char='U'; capa_mfree(error); break; + case UNIT_NOTNEEDED: *log_char='U'; capa_mfree(error); break; case NO_UNIT: *log_char='u'; break; case BAD_FORMULA:*log_char='F'; break; case INCORRECT: *log_char='N'; break; + case WANTED_NUMERIC: *log_char='s'; break; case ANS_CNT_NOT_MATCH: *log_char='C'; break; }