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:
helixhorned 2013-07-13 21:04:49 +00:00
parent e76348cc4b
commit 75204d782a
4 changed files with 16 additions and 12 deletions

View file

@ -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

View file

@ -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);

View file

@ -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;

View file

@ -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);
const int32_t haveerr = (i != 0);
Bassert(lua_iscfunction(L, -1-haveerr)); Bassert(lua_iscfunction(L, -1-haveerr));
lua_remove(L, -1-haveerr); lua_remove(L, -1-haveerr);
Bassert(lua_gettop(L) == top+(i!=0)); Bassert(lua_gettop(L) == top+haveerr);
return i; return i;
}
} }
static int32_t g_eventIdx = 0; static int32_t g_eventIdx = 0;