diff options
| author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2000-09-12 15:41:43 -0300 |
|---|---|---|
| committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2000-09-12 15:41:43 -0300 |
| commit | e143fed484a758a48bac742bf4b60b7510a9bd65 (patch) | |
| tree | 042adbbdd4cb35cdfd8f9d64e022bc58cef77b05 | |
| parent | 01ce1ce48c20bbb97d04460ebe97de3a7751678e (diff) | |
| download | lua-e143fed484a758a48bac742bf4b60b7510a9bd65.tar.gz lua-e143fed484a758a48bac742bf4b60b7510a9bd65.tar.bz2 lua-e143fed484a758a48bac742bf4b60b7510a9bd65.zip | |
better standard error messages
| -rw-r--r-- | lbaselib.c | 21 |
1 files changed, 14 insertions, 7 deletions
| @@ -1,5 +1,5 @@ | |||
| 1 | /* | 1 | /* |
| 2 | ** $Id: lbaselib.c,v 1.1 2000/09/05 19:33:56 roberto Exp roberto $ | 2 | ** $Id: lbaselib.c,v 1.2 2000/09/12 13:49:05 roberto Exp roberto $ |
| 3 | ** Basic library | 3 | ** Basic library |
| 4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
| 5 | */ | 5 | */ |
| @@ -14,6 +14,7 @@ | |||
| 14 | #include "lua.h" | 14 | #include "lua.h" |
| 15 | 15 | ||
| 16 | #include "lauxlib.h" | 16 | #include "lauxlib.h" |
| 17 | #include "luadebug.h" | ||
| 17 | #include "lualib.h" | 18 | #include "lualib.h" |
| 18 | 19 | ||
| 19 | 20 | ||
| @@ -33,15 +34,21 @@ static int luaB__ALERT (lua_State *L) { | |||
| 33 | ** The library `liolib' redefines _ERRORMESSAGE for better error information. | 34 | ** The library `liolib' redefines _ERRORMESSAGE for better error information. |
| 34 | */ | 35 | */ |
| 35 | static int luaB__ERRORMESSAGE (lua_State *L) { | 36 | static int luaB__ERRORMESSAGE (lua_State *L) { |
| 36 | lua_settop(L, 1); | 37 | luaL_checktype(L, 1, "string"); |
| 37 | lua_getglobals(L); | 38 | lua_getglobal(L, LUA_ALERT); |
| 38 | lua_pushstring(L, LUA_ALERT); | ||
| 39 | lua_rawget(L, -2); | ||
| 40 | if (lua_isfunction(L, -1)) { /* avoid error loop if _ALERT is not defined */ | 39 | if (lua_isfunction(L, -1)) { /* avoid error loop if _ALERT is not defined */ |
| 41 | luaL_checktype(L, 1, "string"); | 40 | lua_Debug ar; |
| 42 | lua_pushvalue(L, -1); /* function to be called */ | ||
| 43 | lua_pushstring(L, "error: "); | 41 | lua_pushstring(L, "error: "); |
| 44 | lua_pushvalue(L, 1); | 42 | lua_pushvalue(L, 1); |
| 43 | if (lua_getstack(L, 1, &ar)) { | ||
| 44 | lua_getinfo(L, "Sl", &ar); | ||
| 45 | if (ar.source && ar.currentline > 0) { | ||
| 46 | char buff[100]; | ||
| 47 | sprintf(buff, "\n <%.70s: line %d>", ar.short_src, ar.currentline); | ||
| 48 | lua_pushstring(L, buff); | ||
| 49 | lua_concat(L, 2); | ||
| 50 | } | ||
| 51 | } | ||
| 45 | lua_pushstring(L, "\n"); | 52 | lua_pushstring(L, "\n"); |
| 46 | lua_concat(L, 3); | 53 | lua_concat(L, 3); |
| 47 | lua_call(L, 1, 0); | 54 | lua_call(L, 1, 0); |
