From: ShadowNinja Date: Sun, 8 Mar 2015 01:01:59 +0000 (-0500) Subject: Don't use luaL_checkstring to read node names, it's only for arguments X-Git-Tag: 0.4.13~514 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=d75a0a73941259ea3ebac297803838094c7d458f;p=oweals%2Fminetest.git Don't use luaL_checkstring to read node names, it's only for arguments This caused confusing error messages like "argument #4 to set_node is not a string." --- diff --git a/src/script/common/c_content.cpp b/src/script/common/c_content.cpp index ff9aee8ed..8bb22186b 100644 --- a/src/script/common/c_content.cpp +++ b/src/script/common/c_content.cpp @@ -546,22 +546,23 @@ NodeBox read_nodebox(lua_State *L, int index) MapNode readnode(lua_State *L, int index, INodeDefManager *ndef) { lua_getfield(L, index, "name"); - const char *name = luaL_checkstring(L, -1); + if (!lua_isstring(L, -1)) + throw LuaError("Node name is not set or is not a string!"); + const char *name = lua_tostring(L, -1); lua_pop(L, 1); - u8 param1; + + u8 param1 = 0; lua_getfield(L, index, "param1"); - if(lua_isnil(L, -1)) - param1 = 0; - else + if (!lua_isnil(L, -1)) param1 = lua_tonumber(L, -1); lua_pop(L, 1); - u8 param2; + + u8 param2 = 0; lua_getfield(L, index, "param2"); - if(lua_isnil(L, -1)) - param2 = 0; - else + if (!lua_isnil(L, -1)) param2 = lua_tonumber(L, -1); lua_pop(L, 1); + return MapNode(ndef, name, param1, param2); }