--- trunk/OOPSE/libBASS/Globals.cpp 2003/08/13 19:21:53 693 +++ trunk/OOPSE/libBASS/Globals.cpp 2003/09/04 21:48:07 745 @@ -48,7 +48,10 @@ #define G_TAUBAROSTAT 27 #define G_ZCONSTIME 28 #define G_NZCONSTRAINTS 29 -#define G_ZCONSTOL 30 +#define G_ZCONSTOL 30 +#define G_ZCONSFORCEPOLICY 31 +#define G_SEED 32 +#define G_RESETTIME 33 Globals::Globals(){ @@ -76,6 +79,7 @@ Globals::Globals(){ addHash( "boxY", G_BOXY ); addHash( "boxZ", G_BOXZ ); addHash( "sampleTime", G_SAMPLETIME ); + addHash( "resetTime", G_RESETTIME ); addHash( "statusTime", G_STATUSTIME ); addHash( "electrostaticCutoffRadius", G_ECR ); addHash( "dielectric", G_DIELECTRIC ); @@ -90,8 +94,11 @@ Globals::Globals(){ addHash( "tauBarostat", G_TAUBAROSTAT); addHash( "zconsTime", G_ZCONSTIME); addHash( "nZconstraints", G_NZCONSTRAINTS); - addHash( "zconsTol", G_ZCONSTOL); + addHash( "zconsTol", G_ZCONSTOL); + addHash( "zconsForcePolicy", G_ZCONSFORCEPOLICY); + addHash( "seed", G_SEED); + // define some default values strcpy( mixingRule,"standard"); //default mixing rules to standard. @@ -116,6 +123,7 @@ Globals::Globals(){ have_box_z = 0; have_sample_time = 0; have_status_time = 0; + have_reset_time = 0; have_thermal_time = 0; have_ecr = 0; have_dielectric = 0; @@ -129,6 +137,7 @@ Globals::Globals(){ have_n_zConstraints = 0; have_zConstraints = 0; have_zcons_tol = 0; + have_seed = 0; } @@ -715,6 +724,35 @@ int Globals::globalAssign( event* the_event ){ default: the_event->err_msg = strdup( "Global error. statusTime unrecognized.\n" ); + return 0; + break; + } + break; + + case G_RESETTIME: + switch( the_type ){ + + case STRING: + the_event->err_msg = + strdup( "Global error. resetTime is not a double or int.\n" ); + return 0; + break; + + case DOUBLE: + resetTime = the_event->evt.asmt.rhs.dval; + have_reset_time = 1; + return 1; + break; + + case INT: + resetTime = (double)the_event->evt.asmt.rhs.ival; + have_reset_time = 1; + return 1; + break; + + default: + the_event->err_msg = + strdup( "Global error. resetTime unrecognized.\n" ); return 0; break; } @@ -1036,8 +1074,70 @@ int Globals::globalAssign( event* the_event ){ } break; + case G_ZCONSFORCEPOLICY: + switch( the_type ){ + + case STRING: + strcpy(zconsForcePolicy, the_event->evt.asmt.rhs.sval); + for(int i = 0; zconsForcePolicy[i] != '\0'; i++) + { + zconsForcePolicy[i] = toupper(zconsForcePolicy[i]); + } + have_zcons_force_policy = 1; + return 1; + break; + + case DOUBLE: + the_event->err_msg = + strdup( "Global error. zconsForcePolicy is not a double or int.\n" ); + return 0; + break; + + case INT: + the_event->err_msg = + strdup( "Global error. zconsForcePolicy is not a double or int.\n" ); + return 0; + break; + + default: + the_event->err_msg = + strdup( "Global error. zconsForcePolicy unrecognized.\n" ); + return 0; + break; + } + break; // add more token cases here. + case G_SEED: + switch( the_type ){ + + case STRING: + the_event->err_msg = + strdup( "Global error. seed is not a string.\n" ); + return 0; + return 0; + break; + + case DOUBLE: + have_seed = 1; + seed = (int)the_event->evt.asmt.rhs.dval; + return 1; + break; + + case INT: + have_seed = 1; + seed = the_event->evt.asmt.rhs.ival ; + return 1; + break; + + default: + the_event->err_msg = + strdup( "Global error. seed unrecognized.\n" ); + return 0; + break; + } + break; + // add more token cases here. } }