diff options
| author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2014-02-19 10:52:42 -0300 |
|---|---|---|
| committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2014-02-19 10:52:42 -0300 |
| commit | c86b9da02276652a22426b2a5a194ba1f070fcf4 (patch) | |
| tree | a910fbba8cdae6ad2344205b6547e154b6a12dff /lapi.c | |
| parent | a4c6dcf999ddea865e295ea34926a838a1f97b61 (diff) | |
| download | lua-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.c | 18 |
1 files changed, 5 insertions, 13 deletions
| @@ -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); |
