=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/Kan/ext.c,v retrieving revision 1.22 retrieving revision 1.28 diff -u -p -r1.22 -r1.28 --- OpenXM/src/kan96xx/Kan/ext.c 2004/02/25 23:14:35 1.22 +++ OpenXM/src/kan96xx/Kan/ext.c 2004/09/11 23:49:34 1.28 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM/src/kan96xx/Kan/ext.c,v 1.21 2003/12/06 02:49:22 takayama Exp $ */ +/* $OpenXM: OpenXM/src/kan96xx/Kan/ext.c,v 1.27 2004/09/11 12:13:41 takayama Exp $ */ #include #include #include @@ -17,18 +17,20 @@ #include #include "ox_pathfinder.h" +extern int Quiet; extern char **environ; #define MYCP_SIZE 100 static int Mychildren[MYCP_SIZE]; static int Mycp = 0; +static int Verbose_mywait = 0; static void mywait() { int status; int pid; int i,j; /* signal(SIGCHLD,SIG_IGN); */ pid = wait(&status); - fprintf(stderr,"Child process %d is exiting.\n",pid); + if ((!Quiet) && (Verbose_mywait)) fprintf(stderr,"Child process %d is exiting.\n",pid); for (i=0; iuserDictionary); }else if (strcmp(key,"keywords")==0) { @@ -314,10 +318,20 @@ struct object Kextension(struct object obj) if (obj1.tag != Sinteger) errorKan1("%s\n","[(chattr) num symbol] extension."); if (obj2.tag != Sstring) errorKan1("%s\n","[(chattr) num symbol] extension."); m = KopInteger(obj1); - if (!( m == 0 || m == PROTECT || m == ABSOLUTE_PROTECT)) - errorKan1("%s\n","The number must be 0, 1 or 2."); + /* if (!( m == 0 || m == PROTECT || m == ABSOLUTE_PROTECT || m == ATTR_INFIX)) + errorKan1("%s\n","The number must be 0, 1 or 2.");*/ putUserDictionary2(obj2.lc.str,(obj2.rc.op->lc).ival,(obj2.rc.op->rc).ival, m,CurrentContextp->userDictionary); + }else if (strcmp(key,"getattr")==0) { + if (size != 2) errorKan1("%s\n","[(getattr) symbol] extension."); + obj1 = getoa(obj,1); + if (obj1.tag != Sstring) errorKan1("%s\n","[(getattr) symbol] extension."); + rob = KfindUserDictionary(obj1.lc.str); + if (rob.tag != NoObject.tag) { + if (strcmp(UD_str,obj1.lc.str) == 0) { + rob = KpoInteger(UD_attr); + }else errorKan1("%s\n","getattr: internal error."); + }else rob = NullObject; }else if (strcmp(key,"getServerEnv")==0) { if (size != 2) errorKan1("%s\n","[(getServerEnv) serverName] extension."); obj1 = getoa(obj,1); @@ -363,6 +377,15 @@ struct object Kextension(struct object obj) obj1 = getoa(obj,1); obj2 = getoa(obj,2); rob = KooPower(obj1,obj2); + }else if (strcmp(key,"Krest")==0) { + if (size != 2) errorKan1("%s\n","[(Krest) a] extension b"); + obj1 = getoa(obj,1); + rob = Krest(obj1); + }else if (strcmp(key,"Kjoin")==0) { + if (size != 3) errorKan1("%s\n","[(Kjoin) a b] extension c"); + obj1 = getoa(obj,1); + obj2 = getoa(obj,2); + rob = Kjoin(obj1,obj2); }else if (strcmp(key,"ostype")==0) { rob = newObjectArray(1); /* Hard encode the OS type. */ @@ -371,6 +394,17 @@ struct object Kextension(struct object obj) #else putoa(rob,0,KpoString("unix")); #endif + }else if (strcmp(key,"traceClearStack")==0) { + traceClearStack(); + rob = NullObject; + }else if (strcmp(key,"traceShowStack")==0) { + char *ssst; + ssst = traceShowStack(); + if (ssst != NULL) { + rob = KpoString(ssst); + }else{ + rob = NullObject; + } } #include "plugin.hh" #include "Kclass/tree.hh"