diff --git a/src/lua_baselib.c b/src/lua_baselib.c index 3e1f2c2dde1469513b3fb4bacf1f3d16aadb24f5..68455cd65e1035ca5319bbf8cc27be2ece13357a 100644 --- a/src/lua_baselib.c +++ b/src/lua_baselib.c @@ -946,6 +946,18 @@ static int lib_pSceneryXYMovement(lua_State *L) return 0; } +static int lib_pZMovement(lua_State *L) +{ + mobj_t *actor = *((mobj_t **)luaL_checkudata(L, 1, META_MOBJ)); + NOHUD + INLEVEL + if (!actor) + return LUA_ErrInvalid(L, "mobj_t"); + lua_pushboolean(L, P_ZMovement(actor)); + return 1; +} + + // P_USER //////////// @@ -3307,6 +3319,7 @@ static luaL_Reg lib[] = { {"P_XYMovement",lib_pXYMovement}, {"P_RingXYMovement",lib_pRingXYMovement}, {"P_SceneryXYMovement",lib_pSceneryXYMovement}, + {"P_ZMovement",lib_pZMovement}, // p_user {"P_GetPlayerHeight",lib_pGetPlayerHeight}, diff --git a/src/p_mobj.c b/src/p_mobj.c index a6886c1add224f070bd92646fdc9a22197e467c3..02b9885b8b3548e3677448c02a9be5c291a476fb 100644 --- a/src/p_mobj.c +++ b/src/p_mobj.c @@ -2337,7 +2337,7 @@ boolean P_CheckSolidLava(ffloor_t *rover) // P_ZMovement // Returns false if the mobj was killed/exploded/removed, true otherwise. // -static boolean P_ZMovement(mobj_t *mo) +boolean P_ZMovement(mobj_t *mo) { fixed_t dist, delta; boolean onground; diff --git a/src/p_mobj.h b/src/p_mobj.h index 99d09176097027c29626f5bca886c373997cf9c2..63095e2ff8c707b0d81a4e9d799db23f73a33b1a 100644 --- a/src/p_mobj.h +++ b/src/p_mobj.h @@ -473,6 +473,7 @@ void P_SetScale(mobj_t *mobj, fixed_t newscale); void P_XYMovement(mobj_t *mo); void P_RingXYMovement(mobj_t *mo); void P_SceneryXYMovement(mobj_t *mo); +boolean P_ZMovement(mobj_t *mo); void P_EmeraldManager(void); extern INT32 modulothing;