|
@@ -22,6 +22,8 @@
|
|
|
|
|
|
namespace love
|
|
namespace love
|
|
{
|
|
{
|
|
|
|
+ const char REFERENCE_TABLE_NAME[] = "love-references";
|
|
|
|
+
|
|
Reference::Reference()
|
|
Reference::Reference()
|
|
: L(0), idx(LUA_REFNIL)
|
|
: L(0), idx(LUA_REFNIL)
|
|
{
|
|
{
|
|
@@ -42,14 +44,19 @@ namespace love
|
|
{
|
|
{
|
|
unref(); // Just to be safe.
|
|
unref(); // Just to be safe.
|
|
this->L = L;
|
|
this->L = L;
|
|
- idx = luaL_ref(L, LUA_GLOBALSINDEX);
|
|
|
|
|
|
+ luax_insist(L, LUA_REGISTRYINDEX, REFERENCE_TABLE_NAME);
|
|
|
|
+ lua_insert(L, -2); // Move reference table behind value.
|
|
|
|
+ idx = luaL_ref(L, -2);
|
|
|
|
+ lua_pop(L, 1);
|
|
}
|
|
}
|
|
|
|
|
|
void Reference::unref()
|
|
void Reference::unref()
|
|
{
|
|
{
|
|
if (idx != LUA_REFNIL)
|
|
if (idx != LUA_REFNIL)
|
|
{
|
|
{
|
|
- luaL_unref(L, LUA_GLOBALSINDEX, idx);
|
|
|
|
|
|
+ luax_insist(L, LUA_REGISTRYINDEX, REFERENCE_TABLE_NAME);
|
|
|
|
+ luaL_unref(L, -1, idx);
|
|
|
|
+ lua_pop(L, 1);
|
|
idx = LUA_REFNIL;
|
|
idx = LUA_REFNIL;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -57,7 +64,11 @@ namespace love
|
|
void Reference::push()
|
|
void Reference::push()
|
|
{
|
|
{
|
|
if (idx != LUA_REFNIL)
|
|
if (idx != LUA_REFNIL)
|
|
- lua_rawgeti(L, LUA_GLOBALSINDEX, idx);
|
|
|
|
|
|
+ {
|
|
|
|
+ luax_insist(L, LUA_REGISTRYINDEX, REFERENCE_TABLE_NAME);
|
|
|
|
+ lua_rawgeti(L, -1, idx);
|
|
|
|
+ lua_remove(L, -2);
|
|
|
|
+ }
|
|
else
|
|
else
|
|
lua_pushnil(L);
|
|
lua_pushnil(L);
|
|
}
|
|
}
|