=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/Kan/parser.c,v retrieving revision 1.4 retrieving revision 1.13 diff -u -p -r1.4 -r1.13 --- OpenXM/src/kan96xx/Kan/parser.c 2002/02/24 10:27:18 1.4 +++ OpenXM/src/kan96xx/Kan/parser.c 2020/10/06 11:33:46 1.13 @@ -1,15 +1,17 @@ -/* $OpenXM: OpenXM/src/kan96xx/Kan/parser.c,v 1.3 2001/05/04 01:06:24 takayama Exp $ */ +/* $OpenXM: OpenXM/src/kan96xx/Kan/parser.c,v 1.12 2015/10/08 11:49:37 takayama Exp $ */ /* parser.c parser for poly.c */ #include +#include #include "datatype.h" #include "setjmp.h" #include "stackm.h" #include "extern.h" #include "extern2.h" + #define NUM 1 /* NUM means struct Bignum */ #define POL 0 @@ -38,8 +40,8 @@ static int Spv = 0; /* stack pointer */ #define SSIZE 20000 static int TagStack[SSIZE]; static union valObject ValStack[SSIZE]; -#define NAME_MAX 2000 -static char Name[NAME_MAX]; +#define MY_NAME_MAX 2000 +static char Name[MY_NAME_MAX]; static union valObject ValTmp; @@ -123,9 +125,9 @@ POLY stringToPOLY(s,ringp) Ring0.p = 0; Ring0.next = (struct ring *)NULL; #if defined(__CYGWIN__) - if (sigsetjmp(EnvOfParser,1)) { + if (MYSIGSETJMP(EnvOfParser,1)) { #else - if (setjmp(EnvOfParser)) { + if (MYSETJMP(EnvOfParser)) { #endif fprintf(stderr,"\nERROR: You have syntax errors in the expression: %s\n",s); errorKan1("%s\n"," parser.c : Syntax error in the input polynomial."); @@ -220,7 +222,7 @@ static int getoken() { i = 0; do { Name[i] = Ch; Name[i+1] = '\0'; i++; - if (i+2 >= NAME_MAX) { + if (i+2 >= MY_NAME_MAX) { errorParser("Too long name begining with @."); } Ch = getcharFromStr(); @@ -410,6 +412,7 @@ static void term() { }else { if (ftype == NUM && gtype == NUM) { + errorParser("num/num is not supported yet.\n"); mpz_div(f,f,g); utmp.ival = f; push(NUM,utmp); @@ -485,7 +488,7 @@ static void factor() { static void monom() { union valObject utmp; - struct object obj; + struct object obj = OINIT; POLY f; extern struct context *CurrentContextp; if (Symbol == 'x' || Symbol == 'd') { @@ -566,8 +569,11 @@ static void errorParser(s) char s[]; { extern char *GotoLabel; extern int GotoP; extern int ErrorMessageMode; + extern int RestrictedMode, RestrictedMode_saved; int j; char tmpc[1024]; + RestrictedMode = RestrictedMode_saved; + cancelAlarm(); if (ErrorMessageMode == 1 || ErrorMessageMode == 2) { sprintf(tmpc,"\nError(parser.c): "); if (strlen(s) < 1000-strlen(tmpc)) { @@ -596,9 +602,9 @@ static void errorParser(s) char s[]; { GotoP = 0; } #if defined(__CYGWIN__) - siglongjmp(EnvOfParser,1); + MYSIGLONGJMP(EnvOfParser,1); #else - longjmp(EnvOfParser,1); + MYLONGJMP(EnvOfParser,1); #endif }