У меня есть класс C++, к которому я хочу предоставить доступ в сценарии lua через глобальную переменную, однако, когда я пытаюсь его использовать, я получаю следующую ошибку:
terminate called after throwing an instance of 'luabind::error'
what(): lua runtime error
baz.lua:3: attempt to index global 'foo' (a nil value)Aborted (core dumped)
Мой Lua-скрипт (baz.lua) выглядит так:
-- baz.lua
frames = 0
bar = foo:createBar()
function baz()
frames = frames + 1
bar:setText("frame: " .. frames)
end
И я сделал простой и короткий (насколько я мог) main.cpp, воссоздающий эту проблему:
#include <memory>
#include <iostream>
extern "C" {
#include "lua.h"
#include "lualib.h"
#include "lauxlib.h"
}
#include <boost/ref.hpp>
#include <luabind/luabind.hpp>
class bar
{
public:
static void init(lua_State *L)
{
using luabind::module;
using luabind::class_;
module(L)
[
class_<bar>("bar")
.def("setText", &bar::setText)
];
}
void setText(const std::string &text)
{
std::cout << text << std::endl;
}
};
class foo
{
public:
foo() :
L(luaL_newstate())
{
int ret = luaL_dofile(L, "baz.lua");
if (ret != 0) {
std::cout << lua_tostring(L, -1);
}
luabind::open(L);
using luabind::module;
using luabind::class_;
module(L)
[
class_<foo>("bar")
.def("createBar", &foo::createBar)
];
bar::init(L);
luabind::globals(L)["foo"] = boost::ref(*this);
}
boost::reference_wrapper<bar> createBar()
{
auto b = std::make_shared<bar>();
bars_.push_back(b);
return boost::ref(*b.get());
}
void baz()
{
luabind::call_function<void>(L, "baz");
}
private:
lua_State *L;
std::vector<std::shared_ptr<bar>> bars_;
};
int main()
{
foo f;
while (true) {
f.baz();
}
}
Это скомпилировано с:
g++ -std=c++11 -llua -lluabind main.cpp
Я обнаружил, что если я помещу bar = foo:createBar()
в функцию baz()
, то это не приведет к ошибке, поэтому я предполагаю, что неправильно инициализирую глобальные переменные в глобальном пространстве имен? Мне не хватает функции luabind, которую мне нужно вызвать, прежде чем я смогу это сделать? Или это вообще невозможно...
Спасибо!