1997-09-16 12:25:59 -07:00
|
|
|
/*
|
2005-02-18 04:40:02 -08:00
|
|
|
** $Id: lfunc.h,v 2.2 2005/01/18 17:18:09 roberto Exp roberto $
|
1999-12-27 09:33:22 -08:00
|
|
|
** Auxiliary functions to manipulate prototypes and closures
|
1997-09-16 12:25:59 -07:00
|
|
|
** See Copyright Notice in lua.h
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef lfunc_h
|
|
|
|
#define lfunc_h
|
|
|
|
|
|
|
|
|
|
|
|
#include "lobject.h"
|
|
|
|
|
|
|
|
|
2003-11-24 10:50:36 -08:00
|
|
|
#define sizeCclosure(n) (cast(int, sizeof(CClosure)) + \
|
2003-12-10 04:13:36 -08:00
|
|
|
cast(int, sizeof(TValue)*((n)-1)))
|
2003-11-24 10:50:36 -08:00
|
|
|
|
|
|
|
#define sizeLclosure(n) (cast(int, sizeof(LClosure)) + \
|
2003-12-10 04:13:36 -08:00
|
|
|
cast(int, sizeof(TValue *)*((n)-1)))
|
2003-11-24 10:50:36 -08:00
|
|
|
|
|
|
|
|
2000-03-10 10:37:44 -08:00
|
|
|
Proto *luaF_newproto (lua_State *L);
|
2005-02-18 04:40:02 -08:00
|
|
|
Closure *luaF_newCclosure (lua_State *L, int nelems, Table *e);
|
|
|
|
Closure *luaF_newLclosure (lua_State *L, int nelems, Table *e);
|
2003-10-20 10:42:41 -07:00
|
|
|
UpVal *luaF_newupval (lua_State *L);
|
2001-11-29 12:22:22 -08:00
|
|
|
UpVal *luaF_findupval (lua_State *L, StkId level);
|
2001-09-07 10:39:10 -07:00
|
|
|
void luaF_close (lua_State *L, StkId level);
|
2000-03-10 10:37:44 -08:00
|
|
|
void luaF_freeproto (lua_State *L, Proto *f);
|
1999-11-22 05:12:07 -08:00
|
|
|
void luaF_freeclosure (lua_State *L, Closure *c);
|
2005-01-18 09:18:09 -08:00
|
|
|
void luaF_freeupval (lua_State *L, UpVal *uv);
|
1997-09-16 12:25:59 -07:00
|
|
|
|
2001-11-28 12:13:13 -08:00
|
|
|
const char *luaF_getlocalname (const Proto *func, int local_number, int pc);
|
1997-09-16 12:25:59 -07:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|