diff options
author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2008-06-26 16:40:12 -0300 |
---|---|---|
committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2008-06-26 16:40:12 -0300 |
commit | 1527d8f00d4a99997cf73f50fe159ddba8681f8f (patch) | |
tree | 88606a3615006a1d740943dc1836a834c85f1e55 /lua.c | |
parent | 8efaf8af81ec1daf7a9881373d08a01fc2dc72e4 (diff) | |
download | lua-1527d8f00d4a99997cf73f50fe159ddba8681f8f.tar.gz lua-1527d8f00d4a99997cf73f50fe159ddba8681f8f.tar.bz2 lua-1527d8f00d4a99997cf73f50fe159ddba8681f8f.zip |
GC called after errors now are called after showing error message (to
avoid problems when there are other errors during GC itself)
Diffstat (limited to 'lua.c')
-rw-r--r-- | lua.c | 6 |
1 files changed, 3 insertions, 3 deletions
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lua.c,v 1.167 2007/08/07 16:53:40 roberto Exp roberto $ | 2 | ** $Id: lua.c,v 1.168 2007/09/05 17:17:39 roberto Exp roberto $ |
3 | ** Lua stand-alone interpreter | 3 | ** Lua stand-alone interpreter |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -68,6 +68,8 @@ static int report (lua_State *L, int status) { | |||
68 | if (msg == NULL) msg = "(error object is not a string)"; | 68 | if (msg == NULL) msg = "(error object is not a string)"; |
69 | l_message(progname, msg); | 69 | l_message(progname, msg); |
70 | lua_pop(L, 1); | 70 | lua_pop(L, 1); |
71 | /* force a complete garbage collection in case of errors */ | ||
72 | lua_gc(L, LUA_GCCOLLECT, 0); | ||
71 | } | 73 | } |
72 | return status; | 74 | return status; |
73 | } | 75 | } |
@@ -95,8 +97,6 @@ static int docall (lua_State *L, int narg, int clear) { | |||
95 | status = lua_pcall(L, narg, (clear ? 0 : LUA_MULTRET), base); | 97 | status = lua_pcall(L, narg, (clear ? 0 : LUA_MULTRET), base); |
96 | signal(SIGINT, SIG_DFL); | 98 | signal(SIGINT, SIG_DFL); |
97 | lua_remove(L, base); /* remove traceback function */ | 99 | lua_remove(L, base); /* remove traceback function */ |
98 | /* force a complete garbage collection in case of errors */ | ||
99 | if (status != LUA_OK) lua_gc(L, LUA_GCCOLLECT, 0); | ||
100 | return status; | 100 | return status; |
101 | } | 101 | } |
102 | 102 | ||