diff options
| author | chai <chaifix@163.com> | 2020-09-27 20:31:53 +0800 |
|---|---|---|
| committer | chai <chaifix@163.com> | 2020-09-27 20:31:53 +0800 |
| commit | 63cb4fbbb961da133c68865845eaf22d9b876700 (patch) | |
| tree | 42be163db598df2cf1c11d329c3e5843db4faa0c /src/lua51/lfunc.c | |
| parent | 2dfa15a926f06137f2ba6afcce2e3c1d23300100 (diff) | |
*misc
Diffstat (limited to 'src/lua51/lfunc.c')
| -rw-r--r-- | src/lua51/lfunc.c | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/src/lua51/lfunc.c b/src/lua51/lfunc.c index df2c8e3..5835295 100644 --- a/src/lua51/lfunc.c +++ b/src/lua51/lfunc.c @@ -32,6 +32,7 @@ Closure *luaF_newCclosure (lua_State *L, int nelems, Table *e) { //c 新建lua closure //c nelems upvalue的个数 +//c 这个方法有两个地方调用,一个是f_parser,在代码编译后生成一个闭包;一个是闭包内嵌方法执行到OP_CLOSURE指令时新建闭包 Closure *luaF_newLclosure (lua_State *L, int nelems, Table *e) { Closure *c = cast(Closure *, luaM_malloc(L, sizeLclosure(nelems))); luaC_link(L, obj2gco(c), LUA_TFUNCTION); //c 加入GC链表 @@ -43,7 +44,7 @@ Closure *luaF_newLclosure (lua_State *L, int nelems, Table *e) { } -//c 新建一个closed upvalue +//c 新建一个upvalue,默认是closed UpVal *luaF_newupval (lua_State *L) { UpVal *uv = luaM_new(L, UpVal); luaC_link(L, obj2gco(uv), LUA_TUPVAL); //c 加入GC链表 @@ -53,6 +54,7 @@ UpVal *luaF_newupval (lua_State *L) { } +//c 设置upvalue的数据指针指向stack中某个值level UpVal *luaF_findupval (lua_State *L, StkId level) { global_State *g = G(L); GCObject **pp = &L->openupval; @@ -82,6 +84,7 @@ UpVal *luaF_findupval (lua_State *L, StkId level) { } +// 把uv从global_state->uvhead或者lua_state->openupval中删除 static void unlinkupval (UpVal *uv) { lua_assert(uv->u.l.next->u.l.prev == uv && uv->u.l.prev->u.l.next == uv); uv->u.l.next->u.l.prev = uv->u.l.prev; /* remove from `uvhead' list */ @@ -89,6 +92,7 @@ static void unlinkupval (UpVal *uv) { } +//c 从global_state->uvhead中删除并释放内存 void luaF_freeupval (lua_State *L, UpVal *uv) { if (uv->v != &uv->u.value) /* is it open? */ unlinkupval(uv); /* remove from open list */ @@ -96,19 +100,23 @@ void luaF_freeupval (lua_State *L, UpVal *uv) { } +//c 设置闭包的upvalue void luaF_close (lua_State *L, StkId level) { + log("luaF_close()"); UpVal *uv; global_State *g = G(L); while (L->openupval != NULL && (uv = ngcotouv(L->openupval))->v >= level) { GCObject *o = obj2gco(uv); - lua_assert(!isblack(o) && uv->v != &uv->u.value); + lua_assert(!isblack(o) && uv->v != &uv->u.value); //必须是 open upvalue L->openupval = uv->next; /* remove from `open' list */ - if (isdead(g, o)) + if (isdead(g, o)) luaF_freeupval(L, uv); /* free upvalue */ - else { - unlinkupval(uv); - setobj(L, &uv->u.value, uv->v); + else { + unlinkupval(uv); // 从L->openupval中删除 + + setobj(L, &uv->u.value, uv->v); // 拷贝到upvalue的value字段,upvalue储存值 uv->v = &uv->u.value; /* now current value lives here */ + luaC_linkupval(L, uv); /* link upvalue into `gcroot' list */ } } |
