summaryrefslogtreecommitdiff
path: root/libs/liblua/src/lfunc.h
diff options
context:
space:
mode:
authorAlexander Lantsev <aunsane@gmail.com>2016-01-02 13:52:38 +0000
committerAlexander Lantsev <aunsane@gmail.com>2016-01-02 13:52:38 +0000
commit0a79763db57ac830746fbb70f227ca2a0b758e49 (patch)
treee7285dd46041e3cfd9016758ec83e026669f254c /libs/liblua/src/lfunc.h
parent170bc1e725d52b2b5398527b32cca68579f8d891 (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.h54
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