Annotation of capa/capa51/GUITools/answers.c, revision 1.6

1.3       albertel    1: /* print out the set in a easily parsed format
                      2:    Copyright (C) 1992-2000 Michigan State University
                      3: 
                      4:    The CAPA system is free software; you can redistribute it and/or
1.6     ! albertel    5:    modify it under the terms of the GNU General Public License as
1.3       albertel    6:    published by the Free Software Foundation; either version 2 of the
                      7:    License, or (at your option) any later version.
                      8: 
                      9:    The CAPA system is distributed in the hope that it will be useful,
                     10:    but WITHOUT ANY WARRANTY; without even the implied warranty of
                     11:    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
1.6     ! albertel   12:    General Public License for more details.
1.3       albertel   13: 
1.6     ! albertel   14:    You should have received a copy of the GNU General Public
1.3       albertel   15:    License along with the CAPA system; see the file COPYING.  If not,
                     16:    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
                     17:    Boston, MA 02111-1307, USA.
                     18: 
                     19:    As a special exception, you have permission to link this program
                     20:    with the TtH/TtM library and distribute executables, as long as you
                     21:    follow the requirements of the GNU GPL in regard to all of the
                     22:    software in the executable aside from TtH/TtM.
                     23: */
1.1       albertel   24: /* ======================================================================== */
                     25: /*       Feb. 10 1997   Isaac Tsai                                          */
                     26: /* ======================================================================== */
                     27: 
                     28: #ifdef NeXT
                     29: #include <stdlib.h>
                     30: #include <sys/types.h>
                     31: #include <sys/stat.h>  
                     32: #include <bsd/curses.h>
                     33: #else
                     34: #include <curses.h>
                     35: #include <malloc.h>
                     36: double atof();
                     37: #endif
                     38: 
                     39: #include <stdio.h>
                     40: #include <ctype.h>
                     41: #include <sys/types.h>
                     42: #include <sys/stat.h>  
                     43: #include <signal.h>
                     44: #include <time.h>
                     45: #include <math.h>
                     46: #include <string.h>
                     47: 
                     48: 
                     49: #define   YES    1
                     50: 
1.5       albertel   51: #include "pProj/capaCommon.h"
1.1       albertel   52: 
                     53: char    *progname;
                     54: 
                     55: 
                     56: void
                     57: print_answer(FILE *o_fp,int ans_cnt,char *ans,char *lower,char *upper,char *unit)
                     58: {
                     59:   if (unit && (strlen(unit)>0)) 
                     60:     if(ans_cnt==2)  fprintf(o_fp,"ANS:%s %s %s %s\n",ans,lower,upper,unit); 
                     61:     else  fprintf(o_fp,"ANS:%s %s\n",lower,unit);
                     62:   else 
                     63:     if(ans_cnt==2)  fprintf(o_fp,"ANS:%s %s %s\n",ans,lower,upper); 
                     64:     else  fprintf(o_fp,"ANS:%s\n",lower);
                     65: }
                     66: 
                     67: void print_question (FILE *o_fp,char *question)
                     68: {
                     69:   fprintf(o_fp,"BQES:\n%s\nEQES:\n",question);
                     70: }
                     71: 
                     72: int main (int argc, char  **argv) 
                     73: {
                     74:   extern  int        Parsemode_f;
1.2       albertel   75:   extern  int        managermode;
                     76: 
1.1       albertel   77:   Problem_t  *first_prob,*p;
                     78:   int         q_cnt, num_answers, result, setIdx = 1, q_idx;
                     79:   char        lower[ANSWER_STRING_LENG], upper[ANSWER_STRING_LENG];
                     80:   int         StartSet = 1, EndSet = 1;
                     81:   char        tmp_str[ANSWER_STRING_LENG];
                     82:   double      tmp_ans;
                     83:   T_student   a_student;
                     84: 
                     85:   Parsemode_f=ASCII_MODE;
                     86:   if ( argc > 6 || argc < 5 ) {
1.2       albertel   87:     printf("USAGE: %s StudentNumber StudentName ?managermode? startSet [endSet]\n",
                     88: 	   argv[0]);
1.4       albertel   89:     printf("CAPA is licensed under the GNU GPL v2, see COPYING for details.\n");
1.1       albertel   90:     exit(-1);
                     91:   }
                     92:   strncpy(a_student.s_sn,argv[1],MAX_STUDENT_NUMBER);
                     93:   a_student.s_sn[MAX_STUDENT_NUMBER]='\0';
                     94:   strncpy(a_student.s_nm,argv[2],MAX_NAME_CHAR);
                     95:   a_student.s_nm[MAX_NAME_CHAR]='\0';
1.2       albertel   96:   managermode=atoi(argv[3]);
1.1       albertel   97:   
                     98:   StartSet=atoi(argv[4]);
                     99:   if ( argc == 6 ) {
                    100:     EndSet=atoi(argv[5]);
                    101:   } else {
                    102:     EndSet=StartSet;
                    103:   }
                    104:   for(setIdx=StartSet; setIdx <= EndSet; setIdx++) {
                    105:     printf("SET:%d\n",setIdx);
                    106:     result = capa_parse_student(setIdx, &first_prob, &a_student,&q_cnt,NULL);
                    107:     printf("\n");
                    108:     if ( result > 0 ) { 
                    109:       p = first_prob;
                    110:       for( q_idx = 0; q_idx < q_cnt; q_idx++ ) {
                    111: 	print_question(stdout,p->question);
                    112: 	if( p->ans_type == ANSWER_IS_SUBJECTIVE) {
                    113: 	  printf("ANS: Subjective Answers\n");
                    114: 	} else {
                    115: 	  if( p->ans_type == ANSWER_IS_FLOAT ) {
                    116: 	    tmp_ans = (double)atof(p->answer);
                    117: 	    sprintf(tmp_str, p->ans_fmt, tmp_ans);
                    118: 	  } else {
                    119: 	    strcpy(tmp_str,p->answer);
                    120: 	  }
                    121: 
                    122: 	  num_answers = calc_ansrange(p->ans_type, p->calc, p->answer, p->ans_fmt,
                    123: 				      p->tol_type, p->tolerance, lower, upper);
                    124: 	  print_answer(stdout,num_answers,tmp_str,lower,upper,p->unit_str);
                    125: 	}
                    126: 	p = p->next;
                    127:       }
                    128:     } else {
                    129:       printf("ERROR:for %s set %d\n",a_student.s_sn,setIdx);
                    130:     }
                    131:     free_problems(first_prob);
                    132:     if( setIdx < EndSet ) { 
                    133:       printf("\n"); 
                    134:     }
                    135:   }
                    136:   printf("\nDONE:%s\n",a_student.s_sn);
                    137:   return (0);
                    138: }
                    139: 
                    140: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>