mirror of https://github.com/rusefi/lua.git
userdata are removed from weaktables before invoking their GC fallbacks
This commit is contained in:
parent
35707e94f3
commit
9d6556fd87
6
lgc.c
6
lgc.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: lgc.c,v 1.137 2002/06/20 20:41:46 roberto Exp roberto $
|
** $Id: lgc.c,v 1.138 2002/06/24 17:19:43 roberto Exp roberto $
|
||||||
** Garbage Collector
|
** Garbage Collector
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -215,7 +215,7 @@ static void traversetable (GCState *st, Table *h) {
|
||||||
int weakvalue = 0;
|
int weakvalue = 0;
|
||||||
marktable(st, h->metatable);
|
marktable(st, h->metatable);
|
||||||
lua_assert(h->lsizenode || h->node == G(st->L)->dummynode);
|
lua_assert(h->lsizenode || h->node == G(st->L)->dummynode);
|
||||||
mode = fasttm(st->L, h->metatable, TM_WEAKMODE);
|
mode = fasttm(st->L, h->metatable, TM_MODE);
|
||||||
if (mode && ttype(mode) == LUA_TSTRING) { /* weak table? */
|
if (mode && ttype(mode) == LUA_TSTRING) { /* weak table? */
|
||||||
h->mark = st->toclear; /* must be cleared after GC, ... */
|
h->mark = st->toclear; /* must be cleared after GC, ... */
|
||||||
st->toclear = h; /* ...put in the appropriate list */
|
st->toclear = h; /* ...put in the appropriate list */
|
||||||
|
@ -458,10 +458,10 @@ void luaC_collectgarbage (lua_State *L) {
|
||||||
st.toclear = NULL;
|
st.toclear = NULL;
|
||||||
markstacks(&st); /* mark all stacks */
|
markstacks(&st); /* mark all stacks */
|
||||||
propagatemarks(&st); /* mark all reachable objects */
|
propagatemarks(&st); /* mark all reachable objects */
|
||||||
|
cleartables(st.toclear);
|
||||||
separateudata(L); /* separate userdata to be preserved */
|
separateudata(L); /* separate userdata to be preserved */
|
||||||
marktmu(&st); /* mark `preserved' userdata */
|
marktmu(&st); /* mark `preserved' userdata */
|
||||||
propagatemarks(&st); /* remark */
|
propagatemarks(&st); /* remark */
|
||||||
cleartables(st.toclear);
|
|
||||||
luaC_collect(L, 0);
|
luaC_collect(L, 0);
|
||||||
checkMbuffer(L);
|
checkMbuffer(L);
|
||||||
G(L)->GCthreshold = 2*G(L)->nblocks; /* new threshold */
|
G(L)->GCthreshold = 2*G(L)->nblocks; /* new threshold */
|
||||||
|
|
Loading…
Reference in New Issue