diff options
author | Alexander Lantsev <aunsane@gmail.com> | 2016-01-02 13:52:38 +0000 |
---|---|---|
committer | Alexander Lantsev <aunsane@gmail.com> | 2016-01-02 13:52:38 +0000 |
commit | 0a79763db57ac830746fbb70f227ca2a0b758e49 (patch) | |
tree | e7285dd46041e3cfd9016758ec83e026669f254c /libs/liblua/src/lfunc.h | |
parent | 170bc1e725d52b2b5398527b32cca68579f8d891 (diff) |
added liblua project
git-svn-id: http://svn.miranda-ng.org/main/trunk@15988 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'libs/liblua/src/lfunc.h')
-rw-r--r-- | libs/liblua/src/lfunc.h | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/libs/liblua/src/lfunc.h b/libs/liblua/src/lfunc.h new file mode 100644 index 0000000000..256d3cf90b --- /dev/null +++ b/libs/liblua/src/lfunc.h @@ -0,0 +1,54 @@ +/* +** $Id: lfunc.h,v 2.14 2014/06/19 18:27:20 roberto Exp $ +** Auxiliary functions to manipulate prototypes and closures +** See Copyright Notice in lua.h +*/ + +#ifndef lfunc_h +#define lfunc_h + + +#include "lobject.h" + + +#define sizeCclosure(n) (cast(int, sizeof(CClosure)) + \ + cast(int, sizeof(TValue)*((n)-1))) + +#define sizeLclosure(n) (cast(int, sizeof(LClosure)) + \ + cast(int, sizeof(TValue *)*((n)-1))) + + +/* test whether thread is in 'twups' list */ +#define isintwups(L) (L->twups != L) + + +/* +** Upvalues for Lua closures +*/ +struct UpVal { + TValue *v; /* points to stack or to its own value */ + lu_mem refcount; /* reference counter */ + union { + struct { /* (when open) */ + UpVal *next; /* linked list */ + int touched; /* mark to avoid cycles with dead threads */ + } open; + TValue value; /* the value (when closed) */ + } u; +}; + +#define upisopen(up) ((up)->v != &(up)->u.value) + + +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); +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_freeproto (lua_State *L, Proto *f); +LUAI_FUNC const char *luaF_getlocalname (const Proto *func, int local_number, + int pc); + + +#endif |