C APIを使用してネストされたLuaテーブルを作成する方法
質問
次のようなテーブルを作成したい
myTable = {
[0] = { ["a"] = 4, ["b"] = 2 },
[1] = { ["a"] = 13, ["b"] = 37 }
}
C APIを使用していますか
現在のアプローチは
lua_createtable(L, 0, 2);
int c = lua_gettop(L);
lua_pushstring(L, "a");
lua_pushnumber(L, 4);
lua_settable(L, c);
lua_pushstring(L, "b");
lua_pushnumber(L, 2);
lua_settable(L, c);
ループ内の内部テーブルを作成します。前に、このループを使用します
lua_createtable(L, 2, 0);
int outertable = lua_gettop(L);
2つの数値スロット用の外部テーブルを作成します。
しかし、内部テーブルを外部テーブルに保存するにはどうすればよいですか
解決
表をネストする方法を示す完全かつ最小限のプログラムです。基本的に不足しているのは、 lua_setfield
関数です
#include <stdio.h>
#include "lua.h"
#include "lauxlib.h"
#include "lualib.h"
int main()
{
int res;
lua_State *L = lua_open();
luaL_openlibs(L);
lua_newtable(L); /* bottom table */
lua_newtable(L); /* upper table */
lua_pushinteger(L, 4);
lua_setfield(L, -2, "four"); /* T[four] = 4 */
lua_setfield(L, -2, "T"); /* name upper table field T of bottom table */
lua_setglobal(L, "t"); /* set bottom table as global variable t */
res = luaL_dostring(L, "print(t.T.four == 4)");
if(res)
{
printf("Error: %s\n", lua_tostring(L, -1));
}
return 0;
}
プログラムは単に true
を出力します。
数値インデックスが必要な場合は、引き続き lua_settable
を使用しますa>:
#include <stdio.h>
#include "lua.h"
#include "lauxlib.h"
#include "lualib.h"
int main()
{
int res;
lua_State *L = lua_open();
luaL_openlibs(L);
lua_newtable(L); /* bottom table */
lua_newtable(L); /* upper table */
lua_pushinteger(L, 0);
lua_pushinteger(L, 4);
lua_settable(L, -3); /* uppertable[0] = 4; pops 0 and 4 */
lua_pushinteger(L, 0);
lua_insert(L, -2); /* swap uppertable and 0 */
lua_settable(L, -3); /* bottomtable[0] = uppertable */
lua_setglobal(L, "t"); /* set bottom table as global variable t */
res = luaL_dostring(L, "print(t[0][0] == 4)");
if(res)
{
printf("Error: %s\n", lua_tostring(L, -1));
}
return 0;
}
私がしたように0の絶対インデックスを使用するのではなく、 lua_objlenを使用することもできます。
でインデックスを生成します。
他のヒント
あなたが与えたような単純なコードについては、私の lua2c は正常に動作し、以下のコードを生成します。
/* This C code was generated by lua2c from the Lua code below.
myTable = {
[0] = { ["a"] = 4, ["b"] = 2 },
[1] = { ["a"] = 13, ["b"] = 37 }
}
*/
static int MAIN(lua_State *L)
{
lua_newtable(L);
lua_pushnumber(L,0);
lua_newtable(L);
lua_pushliteral(L,"a");
lua_pushnumber(L,4);
lua_pushliteral(L,"b");
lua_pushnumber(L,2);
lua_settable(L,-5);
lua_settable(L,-3);
lua_pushnumber(L,1);
lua_newtable(L);
lua_pushliteral(L,"a");
lua_pushnumber(L,13);
lua_pushliteral(L,"b");
lua_pushnumber(L,37);
lua_settable(L,-5);
lua_settable(L,-3);
lua_settable(L,-5);
lua_settable(L,-3);
lua_setglobal(L,"myTable");
return 0;
}
これは、lhfの答えに基づいて、同様の問題を解決するために思いついた一般的なものです。これにより、フォームのLuaテーブルが作成されます
{
{"foo"},
{"bar", "baz"}
}
任意のテーブル/サブテーブルの長さ。
int list_of_lists_to_lua(lua_State* L, const std::vector<std::vector<std::string>>& convertme) {
lua_newtable(L);
int counter = 0;
for (const std::vector<std::string>& list : convertme) {
lua_pushnumber(L, ++counter);
lua_newtable(L);
int counter2 = 0;
for (const std::string& item : list) {
lua_pushnumber(L, ++counter2);
lua_pushstring(L, item);
lua_settable(L,-3);
}
lua_settable(L,-3);
}
return 1;
}
所属していません StackOverflow