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

39 lines
1.0 KiB
C
Raw Normal View History

1997-09-16 16:25:59 -03:00
/*
2002-01-25 20:14:54 -02:00
** $Id: ldo.h,v 1.1 2001/11/29 22:14:34 rieru Exp rieru $
1997-09-16 16:25:59 -03:00
** Stack and Call structure of Lua
** See Copyright Notice in lua.h
*/
#ifndef ldo_h
#define ldo_h
#include "lobject.h"
#include "lstate.h"
1997-09-16 16:25:59 -03:00
/*
** macro to increment stack top.
** There must be always an empty slot at the L->stack.top
1997-09-16 16:25:59 -03:00
*/
2002-01-25 20:14:54 -02:00
#define incr_top(L) \
{if (L->top >= L->stack_last) luaD_growstack(L, 1); L->top++;}
1997-09-16 16:25:59 -03:00
2002-01-25 20:14:54 -02:00
#define luaD_checkstack(L,n) if (L->stack_last-(n)<=L->top) luaD_growstack(L, n)
2001-06-05 16:41:24 -03:00
void luaD_lineHook (lua_State *L, int line, lua_Hook linehook);
2001-12-18 18:52:30 -02:00
StkId luaD_precall (lua_State *L, StkId func);
void luaD_call (lua_State *L, StkId func, int nResults);
void luaD_poscall (lua_State *L, int wanted, StkId firstResult);
2002-01-25 20:14:54 -02:00
void luaD_reallocCI (lua_State *L, int newsize);
void luaD_reallocstack (lua_State *L, int newsize);
void luaD_growstack (lua_State *L, int n);
1997-09-16 16:25:59 -03:00
void luaD_error (lua_State *L, const char *s);
2000-09-25 13:22:42 -03:00
void luaD_breakrun (lua_State *L, int errcode);
int luaD_runprotected (lua_State *L, void (*f)(lua_State *, void *), void *ud);
1997-09-16 16:25:59 -03:00
#endif