Browse Source

xpcall now is builtin + new macros `ttis*'

v5-2
Roberto Ierusalimschy 23 years ago
parent
commit
390fc99a5c
  1. 43
      ltests.c

43
ltests.c

@ -1,5 +1,5 @@
/* /*
** $Id: ltests.c,v 1.129 2002/07/09 14:58:28 roberto Exp roberto $ ** $Id: ltests.c,v 1.130 2002/07/17 16:25:13 roberto Exp roberto $
** Internal Module for Debugging of the Lua Implementation ** Internal Module for Debugging of the Lua Implementation
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -172,7 +172,7 @@ void luaI_printcode (Proto *pt, int size) {
char buff[100]; char buff[100];
printf("%s\n", buildop(pt, pc, buff)); printf("%s\n", buildop(pt, pc, buff));
} }
printf("-------\n"); printf("-------\n");
} }
#endif #endif
@ -299,9 +299,9 @@ static int table_query (lua_State *L) {
lua_pushnil(L); lua_pushnil(L);
} }
else if ((i -= t->sizearray) < sizenode(t)) { else if ((i -= t->sizearray) < sizenode(t)) {
if (ttype(val(node(t, i))) != LUA_TNIL || if (!ttisnil(val(node(t, i))) ||
ttype(key(node(t, i))) == LUA_TNIL || ttisnil(key(node(t, i))) ||
ttype(key(node(t, i))) == LUA_TNUMBER) { ttisnumber(key(node(t, i)))) {
luaA_pushobject(L, key(node(t, i))); luaA_pushobject(L, key(node(t, i)));
} }
else else
@ -338,34 +338,6 @@ static int string_query (lua_State *L) {
} }
static int xpcall (lua_State *L) {
int status;
luaL_check_type(L, 1, LUA_TFUNCTION);
luaL_check_any(L, 2);
lua_pushliteral(L, LUA_TRACEBACK);
lua_gettable(L, LUA_REGISTRYINDEX);
lua_pushliteral(L, LUA_TRACEBACK);
lua_pushvalue(L, 1);
lua_settable(L, LUA_REGISTRYINDEX);
lua_replace(L, 1);
status = lua_pcall(L, lua_gettop(L) - 2, LUA_MULTRET);
lua_pushliteral(L, LUA_TRACEBACK);
lua_pushvalue(L, 1);
lua_settable(L, LUA_REGISTRYINDEX);
if (status != 0) {
int numres = (status == LUA_ERRRUN) ? 3 : 2;
lua_pushnil(L);
lua_insert(L, -numres);
return numres;
}
else {
lua_pushboolean(L, 1);
lua_insert(L, 2);
return lua_gettop(L) - 1; /* return `true' + all results */
}
}
static int tref (lua_State *L) { static int tref (lua_State *L) {
int level = lua_gettop(L); int level = lua_gettop(L);
int lock = luaL_opt_int(L, 2, 1); int lock = luaL_opt_int(L, 2, 1);
@ -484,8 +456,10 @@ static int doremote (lua_State *L) {
int status; int status;
lua_settop(L1, 0); lua_settop(L1, 0);
status = luaL_loadbuffer(L1, code, lcode, code); status = luaL_loadbuffer(L1, code, lcode, code);
if (status == 0) if (status == 0) {
status = lua_pcall(L1, 0, LUA_MULTRET); status = lua_pcall(L1, 0, LUA_MULTRET);
if (status != 0) lua_pcallreset(L1);
}
if (status != 0) { if (status != 0) {
lua_pushnil(L); lua_pushnil(L);
lua_pushnumber(L, status); lua_pushnumber(L, status);
@ -711,7 +685,6 @@ static const struct luaL_reg tests_funcs[] = {
{"loadlib", loadlib}, {"loadlib", loadlib},
{"stacklevel", stacklevel}, {"stacklevel", stacklevel},
{"querystr", string_query}, {"querystr", string_query},
{"xpcall", xpcall},
{"querytab", table_query}, {"querytab", table_query},
{"testC", testC}, {"testC", testC},
{"ref", tref}, {"ref", tref},

Loading…
Cancel
Save