[BACK]Return to primitive.c CVS log [TXT][DIR] Up to [local] / OpenXM / src / kan96xx / Kan

Diff for /OpenXM/src/kan96xx/Kan/primitive.c between version 1.14 and 1.17

version 1.14, 2004/09/12 08:55:36 version 1.17, 2004/09/16 02:22:03
Line 1 
Line 1 
 /* $OpenXM: OpenXM/src/kan96xx/Kan/primitive.c,v 1.13 2004/09/12 02:37:57 takayama Exp $ */  /* $OpenXM: OpenXM/src/kan96xx/Kan/primitive.c,v 1.16 2004/09/12 10:58:28 takayama Exp $ */
 /*   primitive.c */  /*   primitive.c */
 /*  The functions in this module were in stackmachine.c */  /*  The functions in this module were in stackmachine.c */
   
Line 40  static char *operatorType(type)
Line 40  static char *operatorType(type)
  return("Unknown operator");   return("Unknown operator");
 }  }
   
   #define evalEA(ob1) if (ob1.tag == SexecutableArray) {\
             executeExecutableArray(ob1,(char *)NULL,0); ob1 = Kpop();}
   
 /****** primitive functions *****************************************  /****** primitive functions *****************************************
   the values must be greater than 1. 0 is used for special purposes.*/    the values must be greater than 1. 0 is used for special purposes.*/
 #define Sadd              1  #define Sadd              1
Line 540  int executePrimitive(ob) 
Line 543  int executePrimitive(ob) 
   
     /* Postscript primitives :arithmetic */      /* Postscript primitives :arithmetic */
   case Sadd:    case Sadd:
     ob1 = Kpop();      ob1 = Kpop();
     ob2 = Kpop();      ob2 = Kpop();
       evalEA(ob1); evalEA(ob2);
     rob = KooAdd(ob1,ob2);      rob = KooAdd(ob1,ob2);
     Kpush(rob);      Kpush(rob);
     break;      break;
   case Ssub:    case Ssub:
     ob2 = Kpop();      ob2 = Kpop();
     ob1 = Kpop();      ob1 = Kpop();
       evalEA(ob1); evalEA(ob2);
     rob = KooSub(ob1,ob2);      rob = KooSub(ob1,ob2);
     Kpush(rob);      Kpush(rob);
     break;      break;
   case Smult:    case Smult:
     ob2 = Kpop();      ob2 = Kpop();
     ob1 = Kpop();      ob1 = Kpop();
       evalEA(ob1); evalEA(ob2);
     rob = KooMult(ob1,ob2);      rob = KooMult(ob1,ob2);
     Kpush(rob);      Kpush(rob);
     break;      break;
   case Sidiv:    case Sidiv:
     ob2 = Kpop(); ob1 = Kpop();      ob2 = Kpop(); ob1 = Kpop();
       evalEA(ob1); evalEA(ob2);
     rob = KooDiv(ob1,ob2);      rob = KooDiv(ob1,ob2);
     Kpush(rob);      Kpush(rob);
     break;      break;
   
   case Sdiv:    case Sdiv:
     ob2 = Kpop(); ob1 = Kpop();      ob2 = Kpop(); ob1 = Kpop();
       evalEA(ob1); evalEA(ob2);
     rob = KooDiv2(ob1,ob2);      rob = KooDiv2(ob1,ob2);
     Kpush(rob);      Kpush(rob);
     break;      break;
Line 609  int executePrimitive(ob) 
Line 617  int executePrimitive(ob) 
     /* Or;  [[a_00 ....] [a_10 ....] ....] [1 0] any put. MultiIndex. */      /* Or;  [[a_00 ....] [a_10 ....] ....] [1 0] any put. MultiIndex. */
     ob1 = Kpop(); ob2 = Kpop(); ob3 = Kpop();      ob1 = Kpop(); ob2 = Kpop(); ob3 = Kpop();
     switch(ob2.tag) {      switch(ob2.tag) {
       case SuniversalNumber:
         ob2 = Kto_int32(ob2); /* do not break and go to Sinteger */
     case Sinteger:      case Sinteger:
       switch(ob3.tag) {        switch(ob3.tag) {
       case Sarray:        case Sarray:
Line 643  int executePrimitive(ob) 
Line 653  int executePrimitive(ob) 
         if (ob5.tag != Sarray)          if (ob5.tag != Sarray)
           errorStackmachine("Object pointed by the multi-index is not array (put)\n");            errorStackmachine("Object pointed by the multi-index is not array (put)\n");
         ob4 = getoa(ob2,i);          ob4 = getoa(ob2,i);
           if (ob4.tag == SuniversalNumber) ob4 = Kto_int32(ob4);
         if (ob4.tag != Sinteger)          if (ob4.tag != Sinteger)
           errorStackmachine("Index has to be an integer. (put)\n");            errorStackmachine("Index has to be an integer. (put)\n");
         k = ob4.lc.ival;          k = ob4.lc.ival;
Line 745  int executePrimitive(ob) 
Line 756  int executePrimitive(ob) 
       break;        break;
     }      }
     while (1) {      while (1) {
       status = executeExecutableArray(ob1,(char *)NULL);        status = executeExecutableArray(ob1,(char *)NULL,1);
       if ((status & STATUS_BREAK) || GotoP) break;        if ((status & STATUS_BREAK) || GotoP) break;
       /* here, do not return 1. Do not propagate exit signal outside of the        /* here, do not return 1. Do not propagate exit signal outside of the
          loop. */           loop. */
Line 784  int executePrimitive(ob) 
Line 795  int executePrimitive(ob) 
         */          */
         for ( ; i<=lim; i += inc) {          for ( ; i<=lim; i += inc) {
           Kpush(KpoInteger(i));            Kpush(KpoInteger(i));
           status = executeExecutableArray(ob1,(char *)NULL);            status = executeExecutableArray(ob1,(char *)NULL,1);
           if ((status & STATUS_BREAK) || GotoP) goto xyz;            if ((status & STATUS_BREAK) || GotoP) goto xyz;
                 }                  }
       }else{        }else{
Line 793  int executePrimitive(ob) 
Line 804  int executePrimitive(ob) 
         */          */
         for ( ; i>=lim; i += inc) {          for ( ; i>=lim; i += inc) {
           Kpush(KpoInteger(i));            Kpush(KpoInteger(i));
           status = executeExecutableArray(ob1,(char *)NULL);            status = executeExecutableArray(ob1,(char *)NULL,1);
           if ((status & STATUS_BREAK) || GotoP) goto xyz;            if ((status & STATUS_BREAK) || GotoP) goto xyz;
         }          }
       }        }
Line 825  int executePrimitive(ob) 
Line 836  int executePrimitive(ob) 
   
     for (i=0; i<osize; i++) {      for (i=0; i<osize; i++) {
       Kpush(getoa(ob1,i));        Kpush(getoa(ob1,i));
       status = executeExecutableArray(ob2,(char *)NULL);        status = executeExecutableArray(ob2,(char *)NULL,0);
       if ((status & STATUS_BREAK) || GotoP) goto foor;        if (status & STATUS_BREAK) goto foor;
     }      }
     foor: ;      foor: ;
     /*KSexecuteString("]");*/      /*KSexecuteString("]");*/
Line 875  int executePrimitive(ob) 
Line 886  int executePrimitive(ob) 
       ob1 = ob2;        ob1 = ob2;
     }      }
     /* execute ob1 */      /* execute ob1 */
     status = executeExecutableArray(ob1,(char *)NULL);      status = executeExecutableArray(ob1,(char *)NULL,0);
     if (status & STATUS_BREAK) return(status);      if (status & STATUS_BREAK) return(status);
   
     break;      break;
Line 887  int executePrimitive(ob) 
Line 898  int executePrimitive(ob) 
     case SexecutableArray: break;      case SexecutableArray: break;
     default: errorStackmachine("Usage:exec");      default: errorStackmachine("Usage:exec");
     }      }
         status = executeExecutableArray(ob1,(char *)NULL);          status = executeExecutableArray(ob1,(char *)NULL,0);
     break;      break;
   
     /* Postscript primitives :dictionary */      /* Postscript primitives :dictionary */
Line 1467  int executePrimitive(ob) 
Line 1478  int executePrimitive(ob) 
     }      }
     /* normal exec. */      /* normal exec. */
     Kpush(ob2);      Kpush(ob2);
     status = executeExecutableArray(ob1,(char *)NULL);      status = executeExecutableArray(ob1,(char *)NULL,0);
   
     if (ccflag) {      if (ccflag) {
       contextControl(CCPOP); ccflag = 0; /* recover the Current context. */        contextControl(CCPOP); ccflag = 0; /* recover the Current context. */
Line 1579  int executePrimitive(ob) 
Line 1590  int executePrimitive(ob) 
     contextControl(CCPUSH); ccflag = 1;      contextControl(CCPUSH); ccflag = 1;
     CurrentContextp = PrimitiveContextp;      CurrentContextp = PrimitiveContextp;
     /* normal exec. */      /* normal exec. */
     status = executeExecutableArray(ob1,(char *)NULL);      status = executeExecutableArray(ob1,(char *)NULL,0);
     contextControl(CCPOP); /* recover the Current context. */      contextControl(CCPOP); /* recover the Current context. */
     break;      break;
   
Line 1624  int executePrimitive(ob) 
Line 1635  int executePrimitive(ob) 
     }      }
     /* normal exec. */      /* normal exec. */
     Kpush(ob2); Kpush(ob4);      Kpush(ob2); Kpush(ob4);
     status = executeExecutableArray(ob1,(char *)NULL);      status = executeExecutableArray(ob1,(char *)NULL,0);
     if (ccflag) {      if (ccflag) {
       contextControl(CCPOP); ccflag = 0; /* recover the Current context. */        contextControl(CCPOP); ccflag = 0; /* recover the Current context. */
     }      }
Line 1695  int executePrimitive(ob) 
Line 1706  int executePrimitive(ob) 
         n = ob2.lc.ival;          n = ob2.lc.ival;
         if (n > 0) {          if (n > 0) {
           signal(SIGALRM,ctrlC); alarm((unsigned int) n);            signal(SIGALRM,ctrlC); alarm((unsigned int) n);
       status = executeExecutableArray(ob1,(char *)NULL);        status = executeExecutableArray(ob1,(char *)NULL,0);
           cancelAlarm();            cancelAlarm();
         }else{          }else{
       before_real = time(&before_real);        before_real = time(&before_real);
       times(&before);        times(&before);
       status = executeExecutableArray(ob1,(char *)NULL);        status = executeExecutableArray(ob1,(char *)NULL,0);
       times(&after);        times(&after);
       after_real = time(&after_real);        after_real = time(&after_real);
           ob1 = newObjectArray(3);            ob1 = newObjectArray(3);

Legend:
Removed from v.1.14  
changed lines
  Added in v.1.17

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