=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/Kan/ext.c,v retrieving revision 1.4 retrieving revision 1.5 diff -u -p -r1.4 -r1.5 --- OpenXM/src/kan96xx/Kan/ext.c 2000/03/09 12:04:52 1.4 +++ OpenXM/src/kan96xx/Kan/ext.c 2001/05/04 01:06:23 1.5 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM/src/kan96xx/Kan/ext.c,v 1.3 2000/02/24 12:33:47 takayama Exp $ */ +/* $OpenXM: OpenXM/src/kan96xx/Kan/ext.c,v 1.4 2000/03/09 12:04:52 takayama Exp $ */ #include #include #include @@ -26,7 +26,7 @@ static void mywait() { for (i=0; i 0) Mycp--; } @@ -133,143 +133,143 @@ struct object Kextension(struct object obj) if (!( m == 0 || m == PROTECT || m == ABSOLUTE_PROTECT)) errorKan1("%s\n","The number must be 0, 1 or 2."); putUserDictionary2((char *)NULL,0,0,m | SET_ATTR_FOR_ALL_WORDS, - CurrentContextp->userDictionary); + CurrentContextp->userDictionary); }else if (strcmp(key,"keywords")==0) { if (size != 1) errorKan1("%s\n","[(keywords)] extension."); rob = showSystemDictionary(1); /* }else if (strcmp(key,"fork0")==0) { - if (size != 2) errorKan1("%s\n","[(fork0) sss] extension."); - m = fork(); - if (m>0) { rob = KpoInteger(m); } - else { - system(KopString(getoa(obj,1))); exit(0); - } */ - }else if (strcmp(key,"defaultPolyRing")==0) { - if (size != 2) errorKan1("%s\n","[(defaultPolyRing) n] extension."); - rob = KdefaultPolyRing(getoa(obj,1)); - }else if (strcmp(key,"getenv")==0) { - if (size != 2) errorKan1("%s\n","[(getenv) envstr] extension."); - obj1 = getoa(obj,1); - if (obj1.tag != Sdollar) errorKan1("%s\n","[(getenv) envstr] extension"); - abc = getenv(KopString(obj1)); - if (abc == NULL) { - rob = NullObject; - }else{ - abc2 = (char *)sGC_malloc(sizeof(char)*(strlen(abc)+2)); - strcpy(abc2,abc); - rob = KpoString(abc2); + if (size != 2) errorKan1("%s\n","[(fork0) sss] extension."); + m = fork(); + if (m>0) { rob = KpoInteger(m); } + else { + system(KopString(getoa(obj,1))); exit(0); + } */ + }else if (strcmp(key,"defaultPolyRing")==0) { + if (size != 2) errorKan1("%s\n","[(defaultPolyRing) n] extension."); + rob = KdefaultPolyRing(getoa(obj,1)); + }else if (strcmp(key,"getenv")==0) { + if (size != 2) errorKan1("%s\n","[(getenv) envstr] extension."); + obj1 = getoa(obj,1); + if (obj1.tag != Sdollar) errorKan1("%s\n","[(getenv) envstr] extension"); + abc = getenv(KopString(obj1)); + if (abc == NULL) { + rob = NullObject; + }else{ + abc2 = (char *)sGC_malloc(sizeof(char)*(strlen(abc)+2)); + strcpy(abc2,abc); + rob = KpoString(abc2); + } + }else if (strcmp(key,"stat")==0) { + if (size != 2) errorKan1("%s\n","[(stat) fname] extension."); + obj1 = getoa(obj,1); + if (obj1.tag != Sdollar) errorKan1("%s\n","[(stat) fname] extension ; string fname."); + m = stat(KopString(obj1),&buf); + rob = newObjectArray(2); + if (m == -1) { + /* fail */ + obj2 = NullObject; + putoa(rob,0,obj2); + obj3 = newObjectArray(2); + putoa(obj3,0,KpoString("error no")); + putoa(obj3,1,KpoInteger(errno)); + putoa(rob,1,obj3); + }else{ + /* success */ + putoa(rob,0,KpoInteger(0)); + obj3 = newObjectArray(1); + putoa(obj3,0,KpoInteger((int) buf.st_size)); + putoa(rob,1,obj3); /* We have not yet read buf fully */ + } + }else if (strcmp(key,"forkExec")==0) { + if (size != 4) errorKan1("%s\n","[(forkExec) argList fdList sigblock] extension."); + obj1 = getoa(obj,1); + if (obj1.tag != Sarray) errorKan1("%s\n","[(forkExec) argList fdList sigblock] extension. array argList."); + obj2 = getoa(obj,2); + if (obj2.tag != Sarray) errorKan1("%s\n","[(forkExec) argList fdList sigblock] extension. array fdList."); + obj3 = getoa(obj,3); + if (obj3.tag != Sinteger) errorKan1("%s\n","[(forkExec) argList fdList sigblock] extension. integer sigblock."); + m = KopInteger(obj3); /* m == 1 : block ctrl-C. */ + argListc = getoaSize(obj1); + fdListc = getoaSize(obj2); + if ((m = fork()) > 0) { + /* parent */ + signal(SIGCHLD,mywait); /* to kill Zombie */ + Mychildren[Mycp++] = m; + if (Mycp >= MYCP_SIZE-1) { + errorKan1("%s\n","Child process table is full.\n"); + Mycp = 0; } - }else if (strcmp(key,"stat")==0) { - if (size != 2) errorKan1("%s\n","[(stat) fname] extension."); - obj1 = getoa(obj,1); - if (obj1.tag != Sdollar) errorKan1("%s\n","[(stat) fname] extension ; string fname."); - m = stat(KopString(obj1),&buf); - rob = newObjectArray(2); - if (m == -1) { - /* fail */ - obj2 = NullObject; - putoa(rob,0,obj2); - obj3 = newObjectArray(2); - putoa(obj3,0,KpoString("error no")); - putoa(obj3,1,KpoInteger(errno)); - putoa(rob,1,obj3); - }else{ - /* success */ - putoa(rob,0,KpoInteger(0)); - obj3 = newObjectArray(1); - putoa(obj3,0,KpoInteger((int) buf.st_size)); - putoa(rob,1,obj3); /* We have not yet read buf fully */ + rob = KpoInteger(m); + /* Done */ + }else{ + /* Child */ + for (i=0; i 0) { - /* parent */ - signal(SIGCHLD,mywait); /* to kill Zombie */ - Mychildren[Mycp++] = m; - if (Mycp >= MYCP_SIZE-1) { - errorKan1("%s\n","Child process table is full.\n"); - Mycp = 0; - } - rob = KpoInteger(m); - /* Done */ - }else{ - /* Child */ - for (i=0; ilc).ival,(obj2.rc.op->rc).ival, - m,CurrentContextp->userDictionary); + for (i=0; ilc).ival,(obj2.rc.op->rc).ival, + m,CurrentContextp->userDictionary); + } #include "plugin.hh" else{ errorKan1("%s\n","Unknown tag for extension.");