aboutsummaryrefslogtreecommitdiff
path: root/lapi.c
diff options
context:
space:
mode:
authorRoberto Ierusalimschy <roberto@inf.puc-rio.br>2014-02-19 10:52:42 -0300
committerRoberto Ierusalimschy <roberto@inf.puc-rio.br>2014-02-19 10:52:42 -0300
commitc86b9da02276652a22426b2a5a194ba1f070fcf4 (patch)
treea910fbba8cdae6ad2344205b6547e154b6a12dff /lapi.c
parenta4c6dcf999ddea865e295ea34926a838a1f97b61 (diff)
downloadlua-c86b9da02276652a22426b2a5a194ba1f070fcf4.tar.gz
lua-c86b9da02276652a22426b2a5a194ba1f070fcf4.tar.bz2
lua-c86b9da02276652a22426b2a5a194ba1f070fcf4.zip
userdata can have any Lua value as uservalue
Diffstat (limited to 'lapi.c')
-rw-r--r--lapi.c18
1 files changed, 5 insertions, 13 deletions
diff --git a/lapi.c b/lapi.c
index c0ba24c1..b50aff40 100644
--- a/lapi.c
+++ b/lapi.c
@@ -1,5 +1,5 @@
1/* 1/*
2** $Id: lapi.c,v 2.196 2014/02/14 16:43:14 roberto Exp roberto $ 2** $Id: lapi.c,v 2.197 2014/02/15 13:12:01 roberto Exp roberto $
3** Lua API 3** Lua API
4** See Copyright Notice in lua.h 4** See Copyright Notice in lua.h
5*/ 5*/
@@ -740,10 +740,7 @@ LUA_API void lua_getuservalue (lua_State *L, int idx) {
740 lua_lock(L); 740 lua_lock(L);
741 o = index2addr(L, idx); 741 o = index2addr(L, idx);
742 api_check(L, ttisfulluserdata(o), "full userdata expected"); 742 api_check(L, ttisfulluserdata(o), "full userdata expected");
743 if (uvalue(o)->env) { 743 getuservalue(L, rawuvalue(o), L->top);
744 sethvalue(L, L->top, uvalue(o)->env);
745 } else
746 setnilvalue(L->top);
747 api_incr_top(L); 744 api_incr_top(L);
748 lua_unlock(L); 745 lua_unlock(L);
749} 746}
@@ -878,13 +875,8 @@ LUA_API void lua_setuservalue (lua_State *L, int idx) {
878 api_checknelems(L, 1); 875 api_checknelems(L, 1);
879 o = index2addr(L, idx); 876 o = index2addr(L, idx);
880 api_check(L, ttisfulluserdata(o), "full userdata expected"); 877 api_check(L, ttisfulluserdata(o), "full userdata expected");
881 if (ttisnil(L->top - 1)) 878 setuservalue(L, rawuvalue(o), L->top - 1);
882 uvalue(o)->env = NULL; 879 luaC_barrier(L, gcvalue(o), L->top - 1);
883 else {
884 api_check(L, ttistable(L->top - 1), "table expected");
885 uvalue(o)->env = hvalue(L->top - 1);
886 luaC_objbarrier(L, gcvalue(o), hvalue(L->top - 1));
887 }
888 L->top--; 880 L->top--;
889 lua_unlock(L); 881 lua_unlock(L);
890} 882}
@@ -1189,7 +1181,7 @@ LUA_API void *lua_newuserdata (lua_State *L, size_t size) {
1189 Udata *u; 1181 Udata *u;
1190 lua_lock(L); 1182 lua_lock(L);
1191 luaC_checkGC(L); 1183 luaC_checkGC(L);
1192 u = luaS_newudata(L, size, NULL); 1184 u = luaS_newudata(L, size);
1193 setuvalue(L, L->top, u); 1185 setuvalue(L, L->top, u);
1194 api_incr_top(L); 1186 api_incr_top(L);
1195 lua_unlock(L); 1187 lua_unlock(L);