Browse Source

details in ERRORMESSAGE

v5-2
Roberto Ierusalimschy 25 years ago
parent
commit
5d033f33eb
  1. 22
      liolib.c

22
liolib.c

@ -1,5 +1,5 @@
/* /*
** $Id: liolib.c,v 1.80 2000/09/12 13:48:34 roberto Exp roberto $ ** $Id: liolib.c,v 1.81 2000/09/12 13:58:37 roberto Exp roberto $
** Standard I/O (and system) library ** Standard I/O (and system) library
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -597,10 +597,12 @@ static int errorfb (lua_State *L) {
luaL_buffinit(L, &b); luaL_buffinit(L, &b);
luaL_addstring(&b, "error: "); luaL_addstring(&b, "error: ");
luaL_addstring(&b, luaL_check_string(L, 1)); luaL_addstring(&b, luaL_check_string(L, 1));
luaL_addstring(&b, "\nstack traceback:\n"); luaL_addstring(&b, "\n");
while (lua_getstack(L, level++, &ar)) { while (lua_getstack(L, level++, &ar)) {
char buff[120]; /* enough to fit following `sprintf's */ char buff[120]; /* enough to fit following `sprintf's */
if (level > LEVELS1 && firstpart) { if (level == 2)
luaL_addstring(&b, "stack traceback:\n");
else if (level > LEVELS1 && firstpart) {
/* no more than `LEVELS2' more levels? */ /* no more than `LEVELS2' more levels? */
if (!lua_getstack(L, level+LEVELS2, &ar)) if (!lua_getstack(L, level+LEVELS2, &ar))
level--; /* keep going */ level--; /* keep going */
@ -627,11 +629,11 @@ static int errorfb (lua_State *L) {
break; break;
default: { default: {
if (*ar.what == 'm') /* main? */ if (*ar.what == 'm') /* main? */
sprintf(buff, "main of %.70s", ar.source_id); sprintf(buff, "main of %.70s", ar.short_src);
else if (*ar.what == 'C') /* C function? */ else if (*ar.what == 'C') /* C function? */
sprintf(buff, "%.70s", ar.source_id); sprintf(buff, "%.70s", ar.short_src);
else else
sprintf(buff, "function <%d:%.70s>", ar.linedefined, ar.source_id); sprintf(buff, "function <%d:%.70s>", ar.linedefined, ar.short_src);
ar.source = NULL; /* do not print source again */ ar.source = NULL; /* do not print source again */
} }
} }
@ -641,17 +643,15 @@ static int errorfb (lua_State *L) {
luaL_addstring(&b, buff); luaL_addstring(&b, buff);
} }
if (ar.source) { if (ar.source) {
sprintf(buff, " [%.70s]", ar.source_id); sprintf(buff, " [%.70s]", ar.short_src);
luaL_addstring(&b, buff); luaL_addstring(&b, buff);
} }
luaL_addstring(&b, "\n"); luaL_addstring(&b, "\n");
} }
luaL_pushresult(&b); luaL_pushresult(&b);
lua_getglobals(L); lua_getglobal(L, LUA_ALERT);
lua_pushstring(L, LUA_ALERT);
lua_rawget(L, -2);
if (lua_isfunction(L, -1)) { /* avoid loop if _ALERT is not defined */ if (lua_isfunction(L, -1)) { /* avoid loop if _ALERT is not defined */
lua_pushvalue(L, -3); /* error message */ lua_pushvalue(L, -2); /* error message */
lua_call(L, 1, 0); lua_call(L, 1, 0);
} }
return 0; return 0;

Loading…
Cancel
Save