mirror of
https://github.com/lua/lua.git
synced 2024-12-12 03:23:28 +08:00
a69356e9e0
memory use a little higher, code much simpler).
34 lines
875 B
C
34 lines
875 B
C
/*
|
|
** $Id: ldo.h,v 1.18 2000/03/24 17:26:08 roberto Exp roberto $
|
|
** Stack and Call structure of Lua
|
|
** See Copyright Notice in lua.h
|
|
*/
|
|
|
|
#ifndef ldo_h
|
|
#define ldo_h
|
|
|
|
|
|
#include "lobject.h"
|
|
#include "lstate.h"
|
|
|
|
|
|
/*
|
|
** macro to increment stack top.
|
|
** There must be always an empty slot at the L->stack.top
|
|
*/
|
|
#define incr_top {if (L->top == L->stack_last) luaD_checkstack(L, 1); L->top++;}
|
|
|
|
|
|
void luaD_init (lua_State *L, int stacksize);
|
|
void luaD_adjusttop (lua_State *L, StkId base, int extra);
|
|
void luaD_openstack (lua_State *L, StkId pos);
|
|
void luaD_lineHook (lua_State *L, StkId func, int line);
|
|
void luaD_call (lua_State *L, StkId func, int nResults);
|
|
void luaD_callTM (lua_State *L, const TObject *f, int nParams, int nResults);
|
|
int luaD_protectedrun (lua_State *L);
|
|
void luaD_gcIM (lua_State *L, const TObject *o);
|
|
void luaD_checkstack (lua_State *L, int n);
|
|
|
|
|
|
#endif
|