Fixed broken config dialogs

Originally committed to SVN as r1258.
This commit is contained in:
Niels Martin Hansen 2007-06-19 02:20:50 +00:00
parent 4a63ffe94a
commit 0aaedd7b49

View file

@ -287,6 +287,7 @@ static int Auto3ParseConfigData(lua_State *L, struct Auto3Interpreter *script, c
// expect it to be a string // expect it to be a string
if (lua_isstring(L, -1)) { if (lua_isstring(L, -1)) {
opt->default_val.stringval = strdup(lua_tostring(L, -1)); opt->default_val.stringval = strdup(lua_tostring(L, -1));
opt->value.stringval = strdup(opt->default_val.stringval);
} else { } else {
// not a string, baaaad scripter // not a string, baaaad scripter
opt->kind = COK_INVALID; opt->kind = COK_INVALID;
@ -296,6 +297,7 @@ static int Auto3ParseConfigData(lua_State *L, struct Auto3Interpreter *script, c
// expect it to be a number // expect it to be a number
if (lua_isnumber(L, -1)) { if (lua_isnumber(L, -1)) {
opt->default_val.intval = (int)lua_tonumber(L, -1); opt->default_val.intval = (int)lua_tonumber(L, -1);
opt->value.intval = opt->default_val.intval;
} else { } else {
opt->kind = COK_INVALID; opt->kind = COK_INVALID;
} }
@ -304,6 +306,7 @@ static int Auto3ParseConfigData(lua_State *L, struct Auto3Interpreter *script, c
// expect it to be a number // expect it to be a number
if (lua_isnumber(L, -1)) { if (lua_isnumber(L, -1)) {
opt->default_val.floatval = (float)lua_tonumber(L, -1); opt->default_val.floatval = (float)lua_tonumber(L, -1);
opt->value.floatval = opt->default_val.floatval;
} else { } else {
opt->kind = COK_INVALID; opt->kind = COK_INVALID;
} }
@ -312,6 +315,7 @@ static int Auto3ParseConfigData(lua_State *L, struct Auto3Interpreter *script, c
// expect it to be a bool // expect it to be a bool
if (lua_isboolean(L, -1)) { if (lua_isboolean(L, -1)) {
opt->default_val.intval = lua_toboolean(L, -1); opt->default_val.intval = lua_toboolean(L, -1);
opt->value.intval = opt->default_val.intval;
} else { } else {
opt->kind = COK_INVALID; opt->kind = COK_INVALID;
} }
@ -319,7 +323,6 @@ static int Auto3ParseConfigData(lua_State *L, struct Auto3Interpreter *script, c
case COK_INVALID: case COK_INVALID:
break; break;
} }
memcpy(&opt->value, &opt->default_val, sizeof(opt->value));
lua_pop(L, 1); lua_pop(L, 1);
} }
@ -332,6 +335,7 @@ static int Auto3ParseConfigData(lua_State *L, struct Auto3Interpreter *script, c
// Such that the current key is on top, and we can get the next // Such that the current key is on top, and we can get the next
} }
// Remove 'config' table from stack // Remove 'config' table from stack
lua_pop(L, 1); lua_pop(L, 1);
@ -466,7 +470,7 @@ AUTO3_API struct Auto3Interpreter *CreateAuto3Script(const filename_t filename,
// Parse the config data // Parse the config data
lua_getglobal(L, "config"); lua_getglobal(L, "configuration");
if (Auto3ParseConfigData(L, script, error)) { if (Auto3ParseConfigData(L, script, error)) {
goto faildescription; goto faildescription;
} }