1
0
mirror of https://github.com/lua/lua.git synced 2025-01-14 05:43:00 +08:00
lua/lfunc.h

58 lines
1.5 KiB
C
Raw Normal View History

1997-09-16 16:25:59 -03:00
/*
2018-01-28 13:13:26 -02:00
** $Id: lfunc.h,v 2.18 2017/06/29 15:06:44 roberto Exp roberto $
1999-12-27 15:33:22 -02:00
** Auxiliary functions to manipulate prototypes and closures
1997-09-16 16:25:59 -03:00
** See Copyright Notice in lua.h
*/
#ifndef lfunc_h
#define lfunc_h
#include "lobject.h"
2018-01-28 13:13:26 -02:00
#define sizeCclosure(n) (cast_int(sizeof(CClosure)) + \
cast_int(sizeof(TValue)*((n)-1)))
2003-11-24 16:50:36 -02:00
2018-01-28 13:13:26 -02:00
#define sizeLclosure(n) (cast_int(sizeof(LClosure)) + \
cast_int(sizeof(TValue *)*((n)-1)))
2003-11-24 16:50:36 -02:00
/* test whether thread is in 'twups' list */
#define isintwups(L) (L->twups != L)
/*
** maximum number of upvalues in a closure (both C and Lua). (Value
** must fit in a VM register.)
*/
#define MAXUPVAL 255
2013-08-27 15:53:35 -03:00
#define upisopen(up) ((up)->v != &(up)->u.value)
#define uplevel(up) check_exp(upisopen(up), cast(StkId, (up)->v))
/*
** maximum number of misses before giving up the cache of closures
** in prototypes
*/
#define MAXMISS 10
LUAI_FUNC Proto *luaF_newproto (lua_State *L);
LUAI_FUNC CClosure *luaF_newCclosure (lua_State *L, int nelems);
LUAI_FUNC LClosure *luaF_newLclosure (lua_State *L, int nelems);
2013-08-27 15:53:35 -03:00
LUAI_FUNC void luaF_initupvals (lua_State *L, LClosure *cl);
LUAI_FUNC UpVal *luaF_findupval (lua_State *L, StkId level);
LUAI_FUNC void luaF_close (lua_State *L, StkId level);
LUAI_FUNC void luaF_unlinkupval (UpVal *uv);
LUAI_FUNC void luaF_freeproto (lua_State *L, Proto *f);
LUAI_FUNC const char *luaF_getlocalname (const Proto *func, int local_number,
int pc);
1997-09-16 16:25:59 -03:00
#endif