version 1.4.39b
[polyglot.git] / option.c
index 96ff50e..44d5c83 100644 (file)
--- a/option.c
+++ b/option.c
@@ -25,6 +25,9 @@ option_t DefaultOptions[] = {
 \r
    // options\r
 \r
+    { "SaveSettingsOnExit","check","0","0",      "true"     , NULL,0,NNB,  PG|XBOARD}, \r
+    { "SaveFile",         "string","0","0",     "<empty>"   , NULL,0,NNB,  PG|XBOARD},\r
+    \r
     { "EngineName",       "string","0","0",     "<empty>"   , NULL,0,NNB,  PG}, \r
     { "EngineDir",        "string","0","0",     "."         , NULL,0,NNB,  PG}, \r
     { "EngineCommand",    "string","0","0",     "<empty>"   , NULL,0,NNB,  PG}, \r
@@ -37,7 +40,7 @@ option_t DefaultOptions[] = {
     { "UseNice",          "check","0","0",      "false"     , NULL,0,NNB,  PG|XBOARD|UCI}, \r
     { "NiceValue",        "spin", "0","20",     "5"         , NULL,0,NNB,  PG|XBOARD|UCI}, \r
 \r
-    { "Chess960",         "check","0","0",      "false"     , NULL,0,NNB,  PG|XBOARD}, \r
+    { "Chess960",         "check","0","0",      "false"     , NULL,0,NNB,  PG}, \r
 \r
     { "Resign",           "check","0","0",      "false"     , NULL,0,NNB,  PG|XBOARD}, \r
     { "ResignMoves",      "spin","0","10000",    "3"        , NULL,0,NNB,  PG|XBOARD}, \r
@@ -183,7 +186,7 @@ bool option_set_default(option_list_t *option,
    opt = option_find(option,name);\r
    if (opt == NULL) return FALSE;\r
 \r
-   opt->default_=my_strdup(value);\r
+   my_string_set(&opt->default_,value);\r
 \r
    if (UseDebug) my_log("POLYGLOT OPTION DEFAULT SET \"%s\" -> \"%s\"\n",opt->name,opt->default_);\r
 \r
@@ -293,10 +296,14 @@ option_t * option_find(option_list_t *option, const char name[]) {
    return NULL;\r
 }\r
 \r
+// option_start_iter()\r
+\r
 void option_start_iter(option_list_t *option){\r
     option->iter=0;\r
 }\r
 \r
+// option_next()\r
+\r
 option_t * option_next(option_list_t *option){\r
     ASSERT(option->iter<=option->option_nb);\r
     if(option->iter==option->option_nb){\r
@@ -321,6 +328,8 @@ void option_free(option_t *option){
       option->mode=0;\r
 }\r
 \r
+// option_clear()\r
+\r
 void option_clear(option_list_t *option){\r
     int i;\r
     for (i = 0; i < option->option_nb; i++) {\r
@@ -329,5 +338,18 @@ void option_clear(option_list_t *option){
    option->option_nb=0;\r
 }\r
 \r
+// option_from_ini()\r
+\r
+void option_from_ini(option_list_t *option,\r
+                     ini_t *ini,\r
+                     const char *section){\r
+    ini_entry_t *entry;\r
+    ini_start_iter(ini);\r
+    while((entry=ini_next(ini))){\r
+        option_set(option,entry->name,entry->value);\r
+        option_set_default(option,entry->name,entry->value);\r
+    }\r
+}\r
+\r
 // end of option.cpp\r
 \r