mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
Lunatic: call G_ShowView() using the Lua C API and not through the FFI.
G_ShowView() may call events. Ouch! git-svn-id: https://svn.eduke32.com/eduke32@3948 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
e76348cc4b
commit
75204d782a
4 changed files with 16 additions and 12 deletions
|
@ -904,7 +904,7 @@ function _showview(x, y, z, a, horiz, sect, x1, y1, x2, y2, unbiasedp)
|
||||||
error("invalid coordinates "..str, 2)
|
error("invalid coordinates "..str, 2)
|
||||||
end
|
end
|
||||||
|
|
||||||
ffiC.G_ShowView(x, y, z, a, horiz, sect, x1, y1, x2, y2, unbiasedp);
|
CF.G_ShowView(x, y, z, a, horiz, sect, x1, y1, x2, y2, unbiasedp);
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -691,8 +691,6 @@ vec2_t G_ScreenTextSize(const int32_t font,
|
||||||
int32_t xspace, int32_t yline, int32_t xbetween, int32_t ybetween,
|
int32_t xspace, int32_t yline, int32_t xbetween, int32_t ybetween,
|
||||||
const int32_t f,
|
const int32_t f,
|
||||||
int32_t x1, int32_t y1, int32_t x2, int32_t y2);
|
int32_t x1, int32_t y1, int32_t x2, int32_t y2);
|
||||||
void G_ShowView(int32_t x, int32_t y, int32_t z, int32_t a, int32_t horiz, int32_t sect,
|
|
||||||
int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t unbiasedp);
|
|
||||||
|
|
||||||
void G_SaveMapState(void);
|
void G_SaveMapState(void);
|
||||||
void G_RestoreMapState(void);
|
void G_RestoreMapState(void);
|
||||||
|
|
|
@ -214,7 +214,6 @@ G_DrawTXDigiNumZ;
|
||||||
G_PrintGameText;
|
G_PrintGameText;
|
||||||
G_ScreenText;
|
G_ScreenText;
|
||||||
G_ScreenTextSize;
|
G_ScreenTextSize;
|
||||||
G_ShowView;
|
|
||||||
|
|
||||||
G_SaveMapState;
|
G_SaveMapState;
|
||||||
G_RestoreMapState;
|
G_RestoreMapState;
|
||||||
|
|
|
@ -339,6 +339,8 @@ extern int32_t A_InsertSprite(int32_t whatsect,int32_t s_x,int32_t s_y,int32_t s
|
||||||
extern void A_AddToDeleteQueue(int32_t i);
|
extern void A_AddToDeleteQueue(int32_t i);
|
||||||
extern int32_t A_PlaySound(uint32_t num, int32_t i);
|
extern int32_t A_PlaySound(uint32_t num, int32_t i);
|
||||||
extern void A_DeleteSprite(int32_t s);
|
extern void A_DeleteSprite(int32_t s);
|
||||||
|
extern void G_ShowView(int32_t x, int32_t y, int32_t z, int32_t a, int32_t horiz, int32_t sect,
|
||||||
|
int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t unbiasedp);
|
||||||
|
|
||||||
#define LARG(index) lua_tointeger(L, index)
|
#define LARG(index) lua_tointeger(L, index)
|
||||||
|
|
||||||
|
@ -384,6 +386,8 @@ DEFINE_RET_CFUNC(A_InsertSprite, LARG(1), LARG(2), LARG(3), LARG(4), LARG(5), LA
|
||||||
DEFINE_VOID_CFUNC(A_AddToDeleteQueue, ONE_ARG)
|
DEFINE_VOID_CFUNC(A_AddToDeleteQueue, ONE_ARG)
|
||||||
DEFINE_RET_CFUNC(A_PlaySound, TWO_ARGS)
|
DEFINE_RET_CFUNC(A_PlaySound, TWO_ARGS)
|
||||||
DEFINE_VOID_CFUNC(A_DeleteSprite, ONE_ARG)
|
DEFINE_VOID_CFUNC(A_DeleteSprite, ONE_ARG)
|
||||||
|
DEFINE_VOID_CFUNC(G_ShowView, LARG(1), LARG(2), LARG(3), LARG(4), LARG(5), LARG(6),
|
||||||
|
LARG(7), LARG(8), LARG(9), LARG(10), LARG(11))
|
||||||
|
|
||||||
#define CFUNC_REG(Name) { #Name, Name##_CF }
|
#define CFUNC_REG(Name) { #Name, Name##_CF }
|
||||||
|
|
||||||
|
@ -403,6 +407,7 @@ struct { const char *name; lua_CFunction func; } cfuncs[] =
|
||||||
CFUNC_REG(A_AddToDeleteQueue),
|
CFUNC_REG(A_AddToDeleteQueue),
|
||||||
CFUNC_REG(A_PlaySound),
|
CFUNC_REG(A_PlaySound),
|
||||||
CFUNC_REG(A_DeleteSprite),
|
CFUNC_REG(A_DeleteSprite),
|
||||||
|
CFUNC_REG(G_ShowView),
|
||||||
};
|
};
|
||||||
|
|
||||||
// Creates a global table "CF" containing the functions from cfuncs[].
|
// Creates a global table "CF" containing the functions from cfuncs[].
|
||||||
|
@ -528,9 +533,8 @@ static int32_t SetActor_CF(lua_State *L)
|
||||||
static int32_t call_regd_function3(lua_State *L, void *keyaddr,
|
static int32_t call_regd_function3(lua_State *L, void *keyaddr,
|
||||||
int32_t iActor, int32_t iPlayer, int32_t lDist)
|
int32_t iActor, int32_t iPlayer, int32_t lDist)
|
||||||
{
|
{
|
||||||
int32_t i, haveerr;
|
|
||||||
#if !defined NDEBUG
|
#if !defined NDEBUG
|
||||||
int32_t top = lua_gettop(L);
|
const int32_t top = lua_gettop(L);
|
||||||
#endif
|
#endif
|
||||||
lua_pushcfunction(L, &our_traceback_CF);
|
lua_pushcfunction(L, &our_traceback_CF);
|
||||||
|
|
||||||
|
@ -543,14 +547,17 @@ static int32_t call_regd_function3(lua_State *L, void *keyaddr,
|
||||||
lua_pushinteger(L, lDist);
|
lua_pushinteger(L, lDist);
|
||||||
|
|
||||||
// -- call it! --
|
// -- call it! --
|
||||||
i = lua_pcall(L, 3, 0, -5);
|
{
|
||||||
haveerr = (i != 0);
|
const int32_t i = lua_pcall(L, 3, 0, -5);
|
||||||
Bassert(lua_iscfunction(L, -1-haveerr));
|
const int32_t haveerr = (i != 0);
|
||||||
lua_remove(L, -1-haveerr);
|
|
||||||
|
|
||||||
Bassert(lua_gettop(L) == top+(i!=0));
|
Bassert(lua_iscfunction(L, -1-haveerr));
|
||||||
|
lua_remove(L, -1-haveerr);
|
||||||
|
|
||||||
return i;
|
Bassert(lua_gettop(L) == top+haveerr);
|
||||||
|
|
||||||
|
return i;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t g_eventIdx = 0;
|
static int32_t g_eventIdx = 0;
|
||||||
|
|
Loading…
Reference in a new issue