File:  [LON-CAPA] / capa / capa51 / pProj / setdbheader.c
Revision 1.4: download - view: text, annotated - select for diffs
Mon Aug 7 20:47:29 2000 UTC (23 years, 8 months ago) by albertel
Branches: MAIN
CVS tags: version_2_9_X, version_2_9_99_0, version_2_9_1, version_2_9_0, version_2_8_X, version_2_8_99_1, version_2_8_99_0, version_2_8_2, version_2_8_1, version_2_8_0, version_2_7_X, version_2_7_99_1, version_2_7_99_0, version_2_7_1, version_2_7_0, version_2_6_X, version_2_6_99_1, version_2_6_99_0, version_2_6_3, version_2_6_2, version_2_6_1, version_2_6_0, version_2_5_X, version_2_5_99_1, version_2_5_99_0, version_2_5_2, version_2_5_1, version_2_5_0, version_2_4_X, version_2_4_99_0, version_2_4_2, version_2_4_1, version_2_4_0, version_2_3_X, version_2_3_99_0, version_2_3_2, version_2_3_1, version_2_3_0, version_2_2_X, version_2_2_99_1, version_2_2_99_0, version_2_2_2, version_2_2_1, version_2_2_0, version_2_1_X, version_2_1_99_3, version_2_1_99_2, version_2_1_99_1, version_2_1_99_0, version_2_1_3, version_2_1_2, version_2_1_1, version_2_1_0, version_2_12_X, version_2_11_X, version_2_11_4_uiuc, version_2_11_4_msu, version_2_11_4, version_2_11_3_uiuc, version_2_11_3_msu, version_2_11_3, version_2_11_2_uiuc, version_2_11_2_msu, version_2_11_2_educog, version_2_11_2, version_2_11_1, version_2_11_0_RC3, version_2_11_0_RC2, version_2_11_0_RC1, version_2_11_0, version_2_10_X, version_2_10_1, version_2_10_0_RC2, version_2_10_0_RC1, version_2_10_0, version_2_0_X, version_2_0_99_1, version_2_0_2, version_2_0_1, version_2_0_0, version_1_99_3, version_1_99_2, version_1_99_1_tmcc, version_1_99_1, version_1_99_0_tmcc, version_1_99_0, version_1_3_X, version_1_3_3, version_1_3_2, version_1_3_1, version_1_3_0, version_1_2_X, version_1_2_99_1, version_1_2_99_0, version_1_2_1, version_1_2_0, version_1_1_X, version_1_1_99_5, version_1_1_99_4, version_1_1_99_3, version_1_1_99_2, version_1_1_99_1, version_1_1_99_0, version_1_1_3, version_1_1_2, version_1_1_1, version_1_1_0, version_1_0_99_3, version_1_0_99_2, version_1_0_99_1, version_1_0_99, version_1_0_3, version_1_0_2, version_1_0_1, version_1_0_0, version_0_99_5, version_0_99_4, version_0_99_3, version_0_99_2, version_0_99_1, version_0_99_0, version_0_6_2, version_0_6, version_0_5_1, version_0_5, version_0_4, stable_2002_spring, stable_2002_july, stable_2002_april, stable_2001_fall, release_5-1-3, loncapaMITrelate_1, language_hyphenation_merge, language_hyphenation, conference_2003, bz6209-base, bz6209, STABLE, HEAD, GCI_3, GCI_2, GCI_1, CAPA_5-1-6, CAPA_5-1-5, CAPA_5-1-4_RC1, BZ4492-merge, BZ4492-feature_horizontal_radioresponse, BZ4492-feature_Support_horizontal_radioresponse, BZ4492-Support_horizontal_radioresponse
- fixed license notices the reference the GNU GPL rather than the GNU LGPL

/* broken start on an command line method for setting the DB Header
   Copyright (C) 1992-2000 Michigan State University

   The CAPA system is free software; you can redistribute it and/or
   modify it under the terms of the GNU General Public License as
   published by the Free Software Foundation; either version 2 of the
   License, or (at your option) any later version.

   The CAPA system is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   General Public License for more details.

   You should have received a copy of the GNU General Public
   License along with the CAPA system; see the file COPYING.  If not,
   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
   Boston, MA 02111-1307, USA.

   As a special exception, you have permission to link this program
   with the TtH/TtM library and distribute executables, as long as you
   follow the requirements of the GNU GPL in regard to all of the
   software in the executable aside from TtH/TtM.
*/

#include <stdio.h>
#include <ctype.h>
#include <unistd.h>
#include "capaCommon.h"

void printUsage(char* progname)
{
  printf("USAGE: %s [-opendate opendate] [-opentime opentime] \n\
           [-duedate duedate]   [-duetime duetime]  \n\
           [-ansdate ansdate]   [-anstime anstime]  \n\
           [-set setnumber] [-dir class-directory] [-h] \n", progname);
  printf("       -h              : prints this message\n");
  printf("       CAPA version %s, %s\n",CAPA_VER,COMPILE_DATE);
}

/*stolen from quizzer.funct.c*/
int checkDate(char* date)
{ 
  if (date==NULL) goto wrong;
  if (strlen(date)!=8) goto wrong;

  switch(date[0]) {
  case '0':
    if (!isdigit(date[1])) goto wrong;
    break;
  case '1':
    if (!(
	  (date[1]=='0') ||
	  (date[1]=='1') ||
	  (date[1]=='2')
	  )
	) goto wrong;
    break;
  case '2':
    if (!(
	  (date[1]=='0') ||
	  (date[1]=='1') ||
	  (date[1]=='2') ||
	  (date[1]=='3') ||
	  (date[1]=='4')
	  )
	) goto wrong;
    break;
  default:
    goto wrong;
    break;
  }
  if (date[2] != '/') goto wrong;
  switch(date[3]) {
  case '0':
  case '1':
  case '2':
    if (!isdigit(date[4])) goto wrong;
    break;
  case '3':
    if (!(
	  (date[4]=='0') ||
	  (date[4]=='1') 
	  )
	) goto wrong;
    break;
  default:
    goto wrong;
    break;
  }
  if (date[5] != '/') goto wrong;
  if (!isdigit(date[6])) goto wrong;
  if (!isdigit(date[7])) goto wrong;
  goto right;
wrong:
  return 0;
right:
  return 1;
}

/* stolen from quizzer.funct.c*/
int checkTime(char* time)
{
  if (time==NULL) goto wrong;
  if (strlen(time)!=5) goto wrong;

  switch(time[0]) {
  case '0':
    if (!isdigit(time[1])) goto wrong;
    break;
  case '1':
    if (!(isdigit(time[1])))
      goto wrong;
    break;
  case '2':
    switch(time[1])
      {
      case '0':
      case '1':
      case '2':
      case '3':
      case '4':
	break;
      default:
	goto wrong;
	break;
      }
    break;
  default:
    goto wrong;
    break;
  }
  if (time[2] != ':') goto wrong;
  switch (time[3]) {
  case '0':
  case '1':
  case '2':
  case '3':
  case '4':
  case '5':
    break;
  default:
    goto wrong;
    break;
  }
  if (!isdigit(time[4])) goto wrong;
  goto right;
  
wrong:
  return 0;
right:
  return 1;
}

int main(int argc, char** argv) 
{
  char *openDate="01/01/98",*openTime="01/01/98",
    *dueDate="01/01/99",*dueTime="01/01/99",
    *ansDate="01/01/99",*ansTime="01/01/99";
  char *directory=NULL,*class=NULL,cwd[FILE_NAME_LENGTH];
  char *problemWeights;
  char *partialCredit;
  int numQuestions=0,set=1,result,i=0;  
  T_header header;
  T_student student;
  Problem_t *headProblem,*currentProblem;

  for(i=1;i<argc-1;i++) {
    if        (0==strcmp(argv[i],"-opendate")  ) { if (checkDate(argv[i+1])) openDate=argv[i+1];
    } else if (0==strcmp(argv[i],"-opentime")  ) { if (checkTime(argv[i+1])) openTime=argv[i+1];
    } else if (0==strcmp(argv[i],"-duedate")   ) { if (checkDate(argv[i+1])) dueDate=argv[i+1];
    } else if (0==strcmp(argv[i],"-duetime")   ) { if (checkTime(argv[i+1])) dueTime=argv[i+1];
    } else if (0==strcmp(argv[i],"-answerdate")) { if (checkDate(argv[i+1])) ansDate=argv[i+1];
    } else if (0==strcmp(argv[i],"-answertime")) { if (checkTime(argv[i+1])) ansTime=argv[i+1];
    } else if (0==strcmp(argv[i],"-set")       ) { set=atoi(argv[i+1]); 
    } else if (0==strcmp(argv[i],"-dir")       ) { directory=(argv[i+1]); 
    } else { printUsage(argv[0]);exit(0); }
  }

  if (directory) { chdir(directory); }

#if defined(NeXT) || defined(linux)
   class = getwd(cwd);
   if( class == NULL ) { class = cwd; }
#else
   class = getcwd(NULL,255);   
#endif

  printf("Creating set%d.db file in %s/records",set,class);

  result=capa_pick_student(0,&student);
  if (result==-1 || result==0 ) {
    printf("Unable to find a classl file.\n");
    exit(-1);
  }
  
  result = capa_parse(set,&headProblem,student.s_sn,&numQuestions);
  if (result==-1) {
    printf("Unable to parse the set.\n");
    exit(-2);
  }
  
  i=0;
  problemWeights=capa_malloc(numQuestions, sizeof(char));
  partialCredit=capa_malloc(numQuestions, sizeof(char));
  currentProblem=headProblem;
  while (currentProblem!=NULL) {
    problemWeights[i]=((char)(currentProblem->weight))+'0';
    partialCredit[i]=((char)(currentProblem->partial_cdt))+'0';
    currentProblem=currentProblem->next;
    i++;
  }
  
  sprintf(header.open_date,"%s %s",openDate,openTime);
  sprintf(header.due_date, "%s %s",dueDate, dueTime);
  sprintf(header.answer_date,"%s %s",ansDate,ansTime);
  sprintf(header.num_questions,"%d",numQuestions);
  
  result=capa_set_header(&header,set,problemWeights,partialCredit);

  return 0;
}






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