=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/Kan/extern.h,v retrieving revision 1.22 retrieving revision 1.36 diff -u -p -r1.22 -r1.36 --- OpenXM/src/kan96xx/Kan/extern.h 2004/09/04 11:25:58 1.22 +++ OpenXM/src/kan96xx/Kan/extern.h 2020/10/06 11:33:46 1.36 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM/src/kan96xx/Kan/extern.h,v 1.21 2004/08/31 05:30:20 takayama Exp $ */ +/* $OpenXM: OpenXM/src/kan96xx/Kan/extern.h,v 1.35 2006/02/01 00:30:05 takayama Exp $ */ /*********** global variables for module stackmachine***************/ extern int VerboseStack; extern int DebugStack; @@ -19,8 +19,8 @@ struct tokens *decomposeToTokens(char *str,int *size); struct tokens getokenSM(); struct tokens *decomposeToTokens(); char *getLOAD_SM1_PATH(); +char *traceShowScannerBuf(); - /* stackmachine.c object */ struct object *newObject(void); struct object newObjectArray(int size); @@ -72,6 +72,7 @@ int isLiteral(char *str); void lockCtrlCForOx(); void unlockCtrlCForOx(); void restoreCtrlCForOx(); +int executeExecutableArray(struct object ob,char *fname,int withGotoP); /* stackmachine.c export */ int KSdefineMacros(void); @@ -81,6 +82,7 @@ char * KSstringPop(void); int KSstackPointer(void); struct object KSdupErrors(void); struct object KSpeek(int k); +struct object KSnewObjectArray(int k); /* stackmachine.c context */ struct context *newContext0(struct context *super,char *name); @@ -95,9 +97,10 @@ void tracePushName(char *s); void traceClearStack(void); char *tracePopName(void); char *traceShowStack(void); +struct object *traceNameStackToArrayp(void); /* kclass.c */ -int initClassDataBase(); +void initClassDataBase(); void fprintClass(FILE *fp,struct object ob); int KclassEqualQ(struct object ob1,struct object ob2); struct object KcreateClassIncetance(struct object ob1, @@ -128,9 +131,18 @@ struct object *cdr(struct object *list); void printObjectList(struct object *op); int memberQ(struct object *list1,struct object list2); +struct object KvJoin(struct object listo1,struct object listo2); +struct object Kcar(struct object listo); +struct object Kcdr(struct object listo); +struct object KlistToArray(struct object listo); +struct object KarrayToList(struct object ob); + /* list:conversion */ struct object listToArray(struct object *op); struct object *arrayToList(struct object ob); +struct object newByteArray(int size,struct object obj); +struct object newByteArrayFromStr(char *s,int size); +struct object byteArrayToArray(struct object obj); /* kanExport0.c */ /** arithmetic **/ @@ -185,6 +197,8 @@ struct object KintToUniversalNumber(int n); #define Knumerator(o) ( (o).lc.op ) #define Kdenominator(o) ( (o).rc.op ) #define KopDouble(ob) (*((ob).lc.dbl)) +#define KopByteArray(o) ( (o).lc.bytes ) +#define getByteArraySize(o) ( (o).rc.ival ) char *KPOLYToString(POLY f); /** conversion 2 **/ struct object arrayOfPOLYToArray(struct arrayOfPOLY *aa); @@ -215,14 +229,16 @@ struct object Khead(struct object ob); int KpolyLength(POLY f); struct object KsetOutputOrder(struct object obj,struct ring *rp); struct object KsetVariableNames(struct object obj,struct ring *rp); +/* KgetRingInfo has not yet been implemented. */ +struct object KgetRingInfo(struct object ringObj, struct object ofunc); - /* :eval */ struct object Keval(struct object obj); /** misc **/ struct object KtoRecords(struct object ob1); struct object KstringToArgv(struct object ob1); +struct object KstringToArgv2(struct object ob1,struct object ob2); void Kclose(void); int warningKan(char *s); int warningKanNoStrictMode(char *s); @@ -231,12 +247,23 @@ struct object test(struct object ob); struct object Kextension(struct object ob); struct object KgbExtension(struct object ob); struct object KmpzExtension(struct object ob); +struct object Krest(struct object ob); +struct object Kjoin(struct object ob1, struct object ob2); +struct object Kget(struct object ob1, struct object ob2); /** Utilities */ char *KremoveSpace(char *s); int KtoArgvbyCurryBrace(char *str,char *argv[],int limit); +/** Attribute */ +struct object KgetAttributeList(struct object ob); +struct object KsetAttributeList(struct object ob,struct object attr); +struct object KgetAttribute(struct object ob,struct object key); +struct object KsetAttribute(struct object ob,struct object key,struct object value); +/* ob (key) (value) setAttribute /ob set. They are not destructive. */ + + /** kanExport1.c */ /* :ring :kan */ struct object Kreduction(struct object f,struct object set); @@ -291,3 +318,13 @@ int objToInteger(struct object ob); struct object KoxWhich(struct object cmdo,struct object patho); struct object KoxShell(struct object ob); void KoxShellHelp(char *key,FILE *fp); + +/* ---- */ +void KinitKan(void); +int stackmachine_close(void); +void stackmachine_init(void); +int memberQ(struct object *list1,struct object obj2); +int warningStackmachine(char *str); +void errorStackmachine(char *str); +int putPrimitiveFunction(char *str,int number); +