aboutsummaryrefslogtreecommitdiff
path: root/lapi.c
diff options
context:
space:
mode:
authorRoberto Ierusalimschy <roberto@inf.puc-rio.br>2018-11-12 14:15:50 -0200
committerRoberto Ierusalimschy <roberto@inf.puc-rio.br>2018-11-12 14:15:50 -0200
commit5fda30b4f9f82b901113a6e666c797f835c708eb (patch)
treea8011434f8c2ccee920d955db05ba4917a00e5f8 /lapi.c
parent9eafe9c053ef17a0980ab32082bf229bd58e963b (diff)
downloadlua-5fda30b4f9f82b901113a6e666c797f835c708eb.tar.gz
lua-5fda30b4f9f82b901113a6e666c797f835c708eb.tar.bz2
lua-5fda30b4f9f82b901113a6e666c797f835c708eb.zip
'lua_toclose' gets the index to be closed as an argument
Sometimes it is useful to mark to-be-closed an index that is not at the top of the stack (e.g., if the value to be closed came from a function call returning multiple values).
Diffstat (limited to 'lapi.c')
-rw-r--r--lapi.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/lapi.c b/lapi.c
index 91a6e389..da866a66 100644
--- a/lapi.c
+++ b/lapi.c
@@ -1207,12 +1207,19 @@ LUA_API int lua_next (lua_State *L, int idx) {
1207} 1207}
1208 1208
1209 1209
1210LUA_API void lua_toclose (lua_State *L) { 1210LUA_API void lua_toclose (lua_State *L, int idx) {
1211 int nresults = L->ci->nresults; 1211 int nresults;
1212 luaF_newtbcupval(L, L->top - 1); /* create new to-be-closed upvalue */ 1212 StkId o;
1213 lua_lock(L);
1214 o = index2stack(L, idx);
1215 nresults = L->ci->nresults;
1216 api_check(L, L->openupval == NULL || uplevel(L->openupval) < o,
1217 "there is an already marked index below");
1218 luaF_newtbcupval(L, o); /* create new to-be-closed upvalue */
1213 if (!hastocloseCfunc(nresults)) /* function not marked yet? */ 1219 if (!hastocloseCfunc(nresults)) /* function not marked yet? */
1214 L->ci->nresults = codeNresults(nresults); /* mark it */ 1220 L->ci->nresults = codeNresults(nresults); /* mark it */
1215 lua_assert(hastocloseCfunc(L->ci->nresults)); 1221 lua_assert(hastocloseCfunc(L->ci->nresults));
1222 lua_unlock(L);
1216} 1223}
1217 1224
1218 1225