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;