Skip to content

Commit

Permalink
'clearapihash' -> 'luaS_clearcache' and moved to 'lstring.c' (which
Browse files Browse the repository at this point in the history
keeps all code related to this cache)
  • Loading branch information
roberto-ieru committed Mar 25, 2015
1 parent 2b37f21 commit b436ed5
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 17 deletions.
17 changes: 2 additions & 15 deletions lgc.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
** $Id: lgc.c,v 2.203 2015/03/04 13:31:21 roberto Exp roberto $
** $Id: lgc.c,v 2.204 2015/03/04 13:51:55 roberto Exp roberto $
** Garbage Collector
** See Copyright Notice in lua.h
*/
Expand Down Expand Up @@ -977,19 +977,6 @@ void luaC_freeallobjects (lua_State *L) {
}


/*
** Clear API string cache. (Entries cannot be empty, so fill them with
** a non-collectable string.)
*/
static void clearapihash (global_State *g) {
int i;
for (i = 0; i < STRCACHE_SIZE; i++) {
if (iswhite(g->strcache[i])) /* will entry be collected? */
g->strcache[i] = g->memerrmsg; /* replace it with something fixed */
}
}


static l_mem atomic (lua_State *L) {
global_State *g = G(L);
l_mem work;
Expand Down Expand Up @@ -1030,7 +1017,7 @@ static l_mem atomic (lua_State *L) {
/* clear values from resurrected weak tables */
clearvalues(g, g->weak, origweak);
clearvalues(g, g->allweak, origall);
clearapihash(g);
luaS_clearcache(g);
g->currentwhite = cast_byte(otherwhite(g)); /* flip current white */
work += g->GCmemtrav; /* complete counting */
return work; /* estimate of memory marked by 'atomic' */
Expand Down
15 changes: 14 additions & 1 deletion lstring.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
** $Id: lstring.c,v 2.46 2015/01/16 16:54:37 roberto Exp roberto $
** $Id: lstring.c,v 2.47 2015/03/04 13:31:21 roberto Exp roberto $
** String table (keeps all strings handled by Lua)
** See Copyright Notice in lua.h
*/
Expand Down Expand Up @@ -87,6 +87,19 @@ void luaS_resize (lua_State *L, int newsize) {
}


/*
** Clear API string cache. (Entries cannot be empty, so fill them with
** a non-collectable string.)
*/
void luaS_clearcache (global_State *g) {
int i;
for (i = 0; i < STRCACHE_SIZE; i++) {
if (iswhite(g->strcache[i])) /* will entry be collected? */
g->strcache[i] = g->memerrmsg; /* replace it with something fixed */
}
}


/*
** Initialize the string table and the string cache
*/
Expand Down
3 changes: 2 additions & 1 deletion lstring.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
** $Id: lstring.h,v 1.57 2015/01/16 16:54:37 roberto Exp roberto $
** $Id: lstring.h,v 1.58 2015/03/04 13:31:21 roberto Exp roberto $
** String table (keep all strings handled by Lua)
** See Copyright Notice in lua.h
*/
Expand Down Expand Up @@ -36,6 +36,7 @@
LUAI_FUNC unsigned int luaS_hash (const char *str, size_t l, unsigned int seed);
LUAI_FUNC int luaS_eqlngstr (TString *a, TString *b);
LUAI_FUNC void luaS_resize (lua_State *L, int newsize);
LUAI_FUNC void luaS_clearcache (global_State *g);
LUAI_FUNC void luaS_init (lua_State *L);
LUAI_FUNC void luaS_remove (lua_State *L, TString *ts);
LUAI_FUNC Udata *luaS_newudata (lua_State *L, size_t s);
Expand Down

0 comments on commit b436ed5

Please sign in to comment.