我需要一个想法,如何存储 lua 闭包以便稍后异步调用它们。
- 我的第一个想法是
lua_tocfunction
闭包不是 cfunction,不能直接从 C 调用 - 第二个想法是将闭包保存在元表中,我可以推送它并稍后调用它,但似乎我无法复制闭包。(
Error: attempt to index a function value
)。
所以我需要你的帮助。我怎样才能储存闭包?
我承认,我不完全理解为什么__index
我的 lua ctor 中有一个字段,因为我从某个地方复制了该部分。
顺便说一句:该程序没有onrender
按预期工作。我正在使用 qt gui 并且在 qt 的主循环之后__gc
关闭了 lua 状态,因此在脚本之后不会删除创建的窗口。
引导程序.lua
local w = w_render() -- create window object
w:show()
w:onrender(function()
print('render')
end)
w_lua.cpp
// chlua_* are helper macros/templates/methods
// 1: self
// 2: render closure
int w_render_onrender(lua_State *L) {
auto *self = chlua_this<GLWindow *>(L, 1, w_render_table);
lua_pushvalue(L, 2); // copy closure to top
lua_setfield(L, 2, "onrender_cb"); // save closure in metatable
// !!! ERROR: attempt to index a function value
self->onrender([L](){
lua_getfield(L, 2, "onrender_cb");
qDebug() << "onrender";
lua_call(L, 0, 0);
});
return 0;
}
// Creates the object
int w_render(lua_State *L) {
auto *&self = chlua_newuserdata<GLWindow *>(L);
self = new GLWindow;
if (luaL_newmetatable(L, w_render_table)) {
luaL_setfuncs(L, w_render_methods, 0);
lua_pushvalue(L, -1);
lua_setfield(L, -2, "__index");
}
lua_setmetatable(L, -2);
return 1;
}