From 90fb2e18e84075972d1937a6c0a3c2624756a3db Mon Sep 17 00:00:00 2001 From: Roberto Ierusalimschy Date: Thu, 17 Aug 2000 10:18:01 -0300 Subject: [PATCH] `pushref' is more efficient (and probably more useful) than `getref'. --- lref.c | 13 ++++++++----- lua.h | 10 +++++----- 2 files changed, 13 insertions(+), 10 deletions(-) diff --git a/lref.c b/lref.c index 7f144ba6..c3fc57af 100644 --- a/lref.c +++ b/lref.c @@ -1,5 +1,5 @@ /* -** $Id: lref.c,v 1.16 2000/08/07 20:21:34 roberto Exp roberto $ +** $Id: lref.c,v 1.17 2000/08/09 19:16:57 roberto Exp roberto $ ** reference mechanism ** See Copyright Notice in lua.h */ @@ -8,6 +8,7 @@ #include "lua.h" #include "lapi.h" +#include "ldo.h" #include "lmem.h" #include "lref.h" #include "lstate.h" @@ -47,14 +48,16 @@ void lua_unref (lua_State *L, int ref) { } -lua_Object lua_getref (lua_State *L, int ref) { +int lua_pushref (lua_State *L, int ref) { if (ref == LUA_REFNIL) - return luaA_putluaObject(L, &luaO_nilobject); + ttype(L->top) = TAG_NIL; else if (0 <= ref && ref < L->refSize && (L->refArray[ref].st == LOCK || L->refArray[ref].st == HOLD)) - return luaA_putluaObject(L, &L->refArray[ref].o); + *L->top = L->refArray[ref].o; else - return LUA_NOOBJECT; + return 0; + incr_top; + return 1; } diff --git a/lua.h b/lua.h index a655f29f..96f3597a 100644 --- a/lua.h +++ b/lua.h @@ -1,5 +1,5 @@ /* -** $Id: lua.h,v 1.57 2000/08/09 19:16:57 roberto Exp roberto $ +** $Id: lua.h,v 1.58 2000/08/14 19:10:14 roberto Exp roberto $ ** Lua - An Extensible Extension Language ** TeCGraf: Grupo de Tecnologia em Computacao Grafica, PUC-Rio, Brazil ** e-mail: lua@tecgraf.puc-rio.br @@ -122,7 +122,7 @@ int lua_next (lua_State *L, lua_Object o, int i); /* Out: index, value */ int lua_ref (lua_State *L, int lock); /* In: value */ -lua_Object lua_getref (lua_State *L, int ref); +int lua_pushref (lua_State *L, int ref); /* Out: value */ void lua_unref (lua_State *L, int ref); lua_Object lua_createtable (lua_State *L); @@ -140,7 +140,7 @@ long lua_collectgarbage (lua_State *L, long limit); #ifndef LUA_SINGLESTATE #define lua_call(L,name) lua_callfunction(L, lua_getglobal(L, name)) -#define lua_pushref(L,ref) lua_pushobject(L, lua_getref(L, ref)) +#define lua_getref(L, ref) (lua_pushref(L, ref) ? lua_pop(L) : LUA_NOOBJECT) #define lua_refobject(L,o,l) (lua_pushobject(L, o), lua_ref(L, l)) #define lua_register(L,n,f) (lua_pushcfunction(L, f), lua_setglobal(L, n)) #define lua_pushuserdata(L,u) lua_pushusertag(L, u, 0) @@ -150,7 +150,7 @@ long lua_collectgarbage (lua_State *L, long limit); #else #define lua_call(name) lua_callfunction(lua_getglobal(name)) -#define lua_pushref(ref) lua_pushobject(lua_getref(ref)) +#define lua_getref(ref) (lua_pushref(ref) ? lua_pop() : LUA_NOOBJECT) #define lua_refobject(o,l) (lua_pushobject(o), lua_ref(l)) #define lua_register(n,f) (lua_pushcfunction(f), lua_setglobal(n)) #define lua_pushuserdata(u) lua_pushusertag(u, 0) @@ -219,7 +219,7 @@ extern lua_State *lua_state; #define lua_tag(obj) (lua_tag)(lua_state, obj) #define lua_next(o,i) (lua_next)(lua_state, o,i) #define lua_ref(lock) (lua_ref)(lua_state, lock) -#define lua_getref(ref) (lua_getref)(lua_state, ref) +#define lua_pushref(ref) (lua_pushref)(lua_state, ref) #define lua_unref(ref) (lua_unref)(lua_state, ref) #define lua_createtable() (lua_createtable)(lua_state) #define lua_collectgarbage(limit) (lua_collectgarbage)(lua_state, limit)