it doesn't pay to optimize absence when it is an error

This commit is contained in:
Roberto Ierusalimschy
2001-12-10 20:10:30 -02:00
parent 9cd36059ad
commit a4c35a3269
3 changed files with 33 additions and 19 deletions

11
ltm.c
View File

@@ -39,6 +39,10 @@ void luaT_init (lua_State *L) {
}
/*
** function to be used with macro "fasttm": optimized for absence of
** tag methods
*/
const TObject *luaT_gettm (Table *events, TMS event, TString *ename) {
const TObject *tm = luaH_getstr(events, ename);
if (ttype(tm) == LUA_TNIL) { /* no tag method? */
@@ -50,13 +54,14 @@ const TObject *luaT_gettm (Table *events, TMS event, TString *ename) {
const TObject *luaT_gettmbyobj (lua_State *L, const TObject *o, TMS event) {
TString *ename = G(L)->tmname[event];
switch (ttype(o)) {
case LUA_TTABLE:
return fasttm(L, hvalue(o)->eventtable, event);
return luaH_getstr(hvalue(o)->eventtable, ename);
case LUA_TUSERDATA:
return fasttm(L, uvalue(o)->uv.eventtable, event);
return luaH_getstr(uvalue(o)->uv.eventtable, ename);
default:
return NULL;
return &luaO_nilobject;
}
}