2020-11-16 14:47:43 +08:00
|
|
|
/*
|
2021-10-08 16:15:33 +08:00
|
|
|
** $Id: ltm.h $
|
2020-11-16 14:47:43 +08:00
|
|
|
** Tag methods
|
|
|
|
** See Copyright Notice in lua.h
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ltm_h
|
|
|
|
#define ltm_h
|
|
|
|
|
|
|
|
|
|
|
|
#include "lobject.h"
|
2023-05-16 15:47:55 +08:00
|
|
|
#include "lstate.h"
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* WARNING: if you change the order of this enumeration,
|
|
|
|
* grep "ORDER TM" and "ORDER OP"
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
TM_INDEX,
|
|
|
|
TM_NEWINDEX,
|
|
|
|
TM_GC,
|
|
|
|
TM_MODE,
|
|
|
|
TM_LEN,
|
|
|
|
TM_EQ, /* last tag method with fast access */
|
|
|
|
TM_ADD,
|
|
|
|
TM_SUB,
|
|
|
|
TM_MUL,
|
|
|
|
TM_MOD,
|
|
|
|
TM_POW,
|
|
|
|
TM_DIV,
|
|
|
|
TM_IDIV,
|
|
|
|
TM_BAND,
|
|
|
|
TM_BOR,
|
|
|
|
TM_BXOR,
|
|
|
|
TM_SHL,
|
|
|
|
TM_SHR,
|
|
|
|
TM_UNM,
|
|
|
|
TM_BNOT,
|
|
|
|
TM_LT,
|
|
|
|
TM_LE,
|
|
|
|
TM_CONCAT,
|
|
|
|
TM_CALL,
|
2021-10-08 16:15:33 +08:00
|
|
|
TM_CLOSE,
|
2020-11-16 14:47:43 +08:00
|
|
|
TM_N /* number of elements in the enum */
|
|
|
|
} TMS;
|
|
|
|
|
|
|
|
|
2021-10-08 16:15:33 +08:00
|
|
|
/*
|
|
|
|
** Mask with 1 in all fast-access methods. A 1 in any of these bits
|
|
|
|
** in the flag of a (meta)table means the metatable does not have the
|
|
|
|
** corresponding metamethod field. (Bit 7 of the flag is used for
|
|
|
|
** 'isrealasize'.)
|
|
|
|
*/
|
|
|
|
#define maskflags (~(~0u << (TM_EQ + 1)))
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Test whether there is no tagmethod.
|
|
|
|
** (Because tagmethods use raw accesses, the result may be an "empty" nil.)
|
|
|
|
*/
|
|
|
|
#define notm(tm) ttisnil(tm)
|
|
|
|
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
#define gfasttm(g,et,e) ((et) == NULL ? NULL : \
|
|
|
|
((et)->flags & (1u<<(e))) ? NULL : luaT_gettm(et, e, (g)->tmname[e]))
|
|
|
|
|
|
|
|
#define fasttm(l,et,e) gfasttm(G(l), et, e)
|
|
|
|
|
|
|
|
#define ttypename(x) luaT_typenames_[(x) + 1]
|
|
|
|
|
2021-10-08 16:15:33 +08:00
|
|
|
LUAI_DDEC(const char *const luaT_typenames_[LUA_TOTALTYPES];)
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
|
|
|
|
LUAI_FUNC const char *luaT_objtypename (lua_State *L, const TValue *o);
|
|
|
|
|
|
|
|
LUAI_FUNC const TValue *luaT_gettm (Table *events, TMS event, TString *ename);
|
|
|
|
LUAI_FUNC const TValue *luaT_gettmbyobj (lua_State *L, const TValue *o,
|
|
|
|
TMS event);
|
|
|
|
LUAI_FUNC void luaT_init (lua_State *L);
|
|
|
|
|
|
|
|
LUAI_FUNC void luaT_callTM (lua_State *L, const TValue *f, const TValue *p1,
|
2021-10-08 16:15:33 +08:00
|
|
|
const TValue *p2, const TValue *p3);
|
|
|
|
LUAI_FUNC void luaT_callTMres (lua_State *L, const TValue *f,
|
|
|
|
const TValue *p1, const TValue *p2, StkId p3);
|
2020-11-16 14:47:43 +08:00
|
|
|
LUAI_FUNC void luaT_trybinTM (lua_State *L, const TValue *p1, const TValue *p2,
|
|
|
|
StkId res, TMS event);
|
2021-10-08 16:15:33 +08:00
|
|
|
LUAI_FUNC void luaT_tryconcatTM (lua_State *L);
|
|
|
|
LUAI_FUNC void luaT_trybinassocTM (lua_State *L, const TValue *p1,
|
|
|
|
const TValue *p2, int inv, StkId res, TMS event);
|
|
|
|
LUAI_FUNC void luaT_trybiniTM (lua_State *L, const TValue *p1, lua_Integer i2,
|
|
|
|
int inv, StkId res, TMS event);
|
2020-11-16 14:47:43 +08:00
|
|
|
LUAI_FUNC int luaT_callorderTM (lua_State *L, const TValue *p1,
|
|
|
|
const TValue *p2, TMS event);
|
2021-10-08 16:15:33 +08:00
|
|
|
LUAI_FUNC int luaT_callorderiTM (lua_State *L, const TValue *p1, int v2,
|
|
|
|
int inv, int isfloat, TMS event);
|
2020-11-16 14:47:43 +08:00
|
|
|
|
2021-10-08 16:15:33 +08:00
|
|
|
LUAI_FUNC void luaT_adjustvarargs (lua_State *L, int nfixparams,
|
2023-05-16 15:47:55 +08:00
|
|
|
CallInfo *ci, const Proto *p);
|
|
|
|
LUAI_FUNC void luaT_getvarargs (lua_State *L, CallInfo *ci,
|
2021-10-08 16:15:33 +08:00
|
|
|
StkId where, int wanted);
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|