=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/Kan/option.c,v retrieving revision 1.8 retrieving revision 1.16 diff -u -p -r1.8 -r1.16 --- OpenXM/src/kan96xx/Kan/option.c 2003/07/17 23:37:02 1.8 +++ OpenXM/src/kan96xx/Kan/option.c 2005/06/16 05:07:23 1.16 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM/src/kan96xx/Kan/option.c,v 1.7 2003/07/17 07:33:03 takayama Exp $ */ +/* $OpenXM: OpenXM/src/kan96xx/Kan/option.c,v 1.15 2004/09/17 02:42:57 takayama Exp $ */ #include #include "datatype.h" #include "stackm.h" @@ -45,6 +45,7 @@ struct object KsystemVariable(ob) extern int Homogenize_vec; extern int CmoDMSOutputOption; extern int DebugReductionRed; /* hidden option */ + extern int DebugReductionEcart; extern char *VersionString; extern int AvoidTheSameRing; extern char *LeftBracket; @@ -52,9 +53,17 @@ struct object KsystemVariable(ob) extern int SecureMode; extern int Ecart; extern int EcartAutomaticHomogenization; + extern int TraceLift; + extern int DoCancel; + extern int DebugContentReduction; + extern int QuoteMode; + extern int RestrictedMode, RestrictedMode_saved; int n,i; - struct object ob1,ob2,ob3,ob4; + struct object ob1 = OINIT; + struct object ob2 = OINIT; + struct object ob3 = OINIT; + struct object ob4 = OINIT; struct object rob = NullObject; switch (getoaSize(ob)) { case 1: /* get the value */ @@ -179,10 +188,20 @@ struct object KsystemVariable(ob) rob = KpoString(RightBracket); }else if (strcmp(ob1.lc.str,"SecureMode")==0) { rob = KpoInteger(SecureMode); + }else if (strcmp(ob1.lc.str,"RestrictedMode")==0) { + rob = KpoInteger(RestrictedMode); }else if (strcmp(ob1.lc.str,"Ecart")==0) { rob = KpoInteger(Ecart); }else if (strcmp(ob1.lc.str,"EcartAutomaticHomogenization")==0) { rob = KpoInteger(EcartAutomaticHomogenization); + }else if (strcmp(ob1.lc.str,"TraceLift")==0) { + rob = KpoInteger(TraceLift); + }else if (strcmp(ob1.lc.str,"DoCancel")==0) { + rob = KpoInteger(DoCancel); + }else if (strcmp(ob1.lc.str,"DebugContentReduction")==0) { + rob = KpoInteger(DebugContentReduction); + }else if (strcmp(ob1.lc.str,"QuoteMode")==0) { + rob = KpoInteger(QuoteMode); }else{ warningKan("KsystemVariable():Unknown key word.\n"); } @@ -288,6 +307,9 @@ struct object KsystemVariable(ob) }else if (strcmp(ob1.lc.str,"DebugReductionRed") == 0) { DebugReductionRed = KopInteger(ob2); rob = KpoInteger(DebugReductionRed); + }else if (strcmp(ob1.lc.str,"DebugReductionEcart") == 0) { + DebugReductionEcart = KopInteger(ob2); + rob = KpoInteger(DebugReductionEcart); }else if (strcmp(ob1.lc.str,"AvoidTheSameRing") == 0) { AvoidTheSameRing = KopInteger(ob2); rob = KpoInteger(AvoidTheSameRing); @@ -298,12 +320,32 @@ struct object KsystemVariable(ob) errorKan1("%s\n","You cannot weaken the security level."); } rob = KpoInteger(SecureMode); + }else if (strcmp(ob1.lc.str,"RestrictedMode") == 0) { + if (KopInteger(ob2) >= RestrictedMode) { + RestrictedMode = KopInteger(ob2); + RestrictedMode_saved = RestrictedMode; + }else{ + errorKan1("%s\n","You cannot weaken the RestrictedMode level."); + } + rob = KpoInteger(RestrictedMode); }else if (strcmp(ob1.lc.str,"Ecart") == 0) { Ecart = KopInteger(ob2); rob = KpoInteger(Ecart); }else if (strcmp(ob1.lc.str,"EcartAutomaticHomogenization") == 0) { - Ecart = KopInteger(ob2); + EcartAutomaticHomogenization = KopInteger(ob2); rob = KpoInteger(EcartAutomaticHomogenization); + }else if (strcmp(ob1.lc.str,"TraceLift") == 0) { + TraceLift = KopInteger(ob2); + rob = KpoInteger(TraceLift); + }else if (strcmp(ob1.lc.str,"DoCancel") == 0) { + DoCancel = KopInteger(ob2); + rob = KpoInteger(DoCancel); + }else if (strcmp(ob1.lc.str,"DebugContentReduction") == 0) { + DebugContentReduction = KopInteger(ob2); + rob = KpoInteger(DebugContentReduction); + }else if (strcmp(ob1.lc.str,"QuoteMode") == 0) { + QuoteMode = KopInteger(ob2); + rob = KpoInteger(QuoteMode); }else{ warningKan("KsystemVariable():Unknown key word.\n"); }