2013-11-14 22:41:54 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2013 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
*/
|
|
|
|
#include "util/debug.h"
|
|
|
|
#include "bindings/lua/util.h"
|
2013-11-14 23:50:56 +00:00
|
|
|
#include "bindings/lua/lref.h"
|
2013-11-14 22:41:54 +00:00
|
|
|
|
|
|
|
namespace lean {
|
2013-11-14 23:50:56 +00:00
|
|
|
lref::lref(lua_State * L, int i) {
|
2013-11-14 22:41:54 +00:00
|
|
|
lean_assert(L);
|
|
|
|
m_state = L;
|
|
|
|
lua_pushvalue(m_state, i);
|
|
|
|
m_ref = luaL_ref(m_state, LUA_REGISTRYINDEX);
|
|
|
|
}
|
|
|
|
|
2013-11-14 23:50:56 +00:00
|
|
|
lref::lref(lref const & r) {
|
2013-11-14 22:41:54 +00:00
|
|
|
m_state = r.m_state;
|
|
|
|
if (m_state) {
|
|
|
|
r.push();
|
|
|
|
m_ref = luaL_ref(m_state, LUA_REGISTRYINDEX);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-14 23:50:56 +00:00
|
|
|
lref::lref(lref && r) {
|
2013-11-14 22:41:54 +00:00
|
|
|
m_state = r.m_state;
|
|
|
|
m_ref = r.m_ref;
|
|
|
|
r.m_state = nullptr;
|
|
|
|
}
|
|
|
|
|
2013-11-14 23:50:56 +00:00
|
|
|
lref::~lref() {
|
2013-11-14 22:41:54 +00:00
|
|
|
if (m_state)
|
|
|
|
luaL_unref(m_state, LUA_REGISTRYINDEX, m_ref);
|
|
|
|
}
|
|
|
|
|
2013-11-14 23:50:56 +00:00
|
|
|
lref & lref::operator=(lref const & r) {
|
2013-11-14 22:41:54 +00:00
|
|
|
if (m_ref == r.m_ref)
|
|
|
|
return *this;
|
|
|
|
if (m_state)
|
|
|
|
luaL_unref(m_state, LUA_REGISTRYINDEX, m_ref);
|
|
|
|
m_state = r.m_state;
|
|
|
|
if (m_state) {
|
|
|
|
r.push();
|
|
|
|
m_ref = luaL_ref(m_state, LUA_REGISTRYINDEX);
|
|
|
|
}
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2013-11-14 23:50:56 +00:00
|
|
|
void lref::push() const {
|
2013-11-14 22:41:54 +00:00
|
|
|
lean_assert(m_state);
|
|
|
|
lua_rawgeti(m_state, LUA_REGISTRYINDEX, m_ref);
|
|
|
|
}
|
|
|
|
|
2013-11-14 23:50:56 +00:00
|
|
|
int lref_lt_proc::operator()(lref const & r1, lref const & r2) const {
|
2013-11-14 22:41:54 +00:00
|
|
|
lean_assert(r1.get_state() == r2.get_state());
|
|
|
|
lua_State * L = r1.get_state();
|
|
|
|
r1.push();
|
|
|
|
r2.push();
|
|
|
|
int r;
|
|
|
|
if (lessthan(L, -2, -1)) {
|
|
|
|
r = -1;
|
|
|
|
} else if (lessthan(L, -1, -2)) {
|
|
|
|
r = 1;
|
|
|
|
} else if (equal(L, -2, -1)) {
|
|
|
|
r = 0;
|
|
|
|
} else {
|
|
|
|
throw exception("'<' is not a total order for the elements inserted on the table");
|
|
|
|
}
|
|
|
|
lua_pop(L, 2);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
}
|