diff options
author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2013-08-30 13:01:37 -0300 |
---|---|---|
committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2013-08-30 13:01:37 -0300 |
commit | 8ef9e8460e775793f760deb28d0c3d10dda31b49 (patch) | |
tree | 803abce8b7caba6e5f66b26e55f0bc8dcfc881a2 /lcode.c | |
parent | 4f292d753c892e705b6d1796d72758cdd4d49765 (diff) | |
download | lua-8ef9e8460e775793f760deb28d0c3d10dda31b49.tar.gz lua-8ef9e8460e775793f760deb28d0c3d10dda31b49.tar.bz2 lua-8ef9e8460e775793f760deb28d0c3d10dda31b49.zip |
bug (GC can collect long identifier during parser) + change (using
a single constant table for all functions in a chunk)
Diffstat (limited to 'lcode.c')
-rw-r--r-- | lcode.c | 20 |
1 files changed, 12 insertions, 8 deletions
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lcode.c,v 2.70 2013/06/20 17:37:31 roberto Exp roberto $ | 2 | ** $Id: lcode.c,v 2.71 2013/06/25 18:57:18 roberto Exp roberto $ |
3 | ** Code generator for Lua | 3 | ** Code generator for Lua |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -307,17 +307,21 @@ static void freeexp (FuncState *fs, expdesc *e) { | |||
307 | } | 307 | } |
308 | 308 | ||
309 | 309 | ||
310 | /* | ||
311 | ** Use scanner's table to cache position of constants in contant list | ||
312 | ** and try to reuse constants | ||
313 | */ | ||
310 | static int addk (FuncState *fs, TValue *key, TValue *v) { | 314 | static int addk (FuncState *fs, TValue *key, TValue *v) { |
311 | lua_State *L = fs->ls->L; | 315 | lua_State *L = fs->ls->L; |
312 | TValue *idx = luaH_set(L, fs->h, key); | ||
313 | Proto *f = fs->f; | 316 | Proto *f = fs->f; |
317 | TValue *idx = luaH_set(L, fs->ls->h, key); /* index scanner table */ | ||
314 | int k, oldsize; | 318 | int k, oldsize; |
315 | if (ttisinteger(idx)) { | 319 | if (ttisinteger(idx)) { /* is there an index there? */ |
316 | k = ivalue(idx); | 320 | k = ivalue(idx); |
317 | if (luaV_rawequalobj(&f->k[k], v)) | 321 | /* correct value? (warning: must distinguish floats from integers!) */ |
318 | return k; | 322 | if (k < fs->nk && ttype(&f->k[k]) == ttype(v) && |
319 | /* else may be a collision (e.g., between 0.0 and "\0\0\0\0\0\0\0\0"); | 323 | luaV_rawequalobj(&f->k[k], v)) |
320 | go through and create a new entry for this value */ | 324 | return k; /* reuse index */ |
321 | } | 325 | } |
322 | /* constant not found; create a new entry */ | 326 | /* constant not found; create a new entry */ |
323 | oldsize = f->sizek; | 327 | oldsize = f->sizek; |
@@ -377,7 +381,7 @@ static int nilK (FuncState *fs) { | |||
377 | TValue k, v; | 381 | TValue k, v; |
378 | setnilvalue(&v); | 382 | setnilvalue(&v); |
379 | /* cannot use nil as key; instead use table itself to represent nil */ | 383 | /* cannot use nil as key; instead use table itself to represent nil */ |
380 | sethvalue(fs->ls->L, &k, fs->h); | 384 | sethvalue(fs->ls->L, &k, fs->ls->h); |
381 | return addk(fs, &k, &v); | 385 | return addk(fs, &k, &v); |
382 | } | 386 | } |
383 | 387 | ||