mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 15:11:51 +00:00
Fix the "fix for flying/jumping monsters getting stuck in water".
In C and Lunatic, split 'jumptoplayer' of enum amoveflags_t / action.MOVFLAGS into 'jumptoplayer_bits' and 'jumptoplayer_only' (see updated Lunatic doc). git-svn-id: https://svn.eduke32.com/eduke32@4378 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
40fd4968bb
commit
10a0e82736
4 changed files with 12 additions and 6 deletions
|
@ -61,7 +61,8 @@ enum amoveflags_t {
|
|||
spin = 32,
|
||||
face_player_smart = 64,
|
||||
fleeenemy = 128,
|
||||
jumptoplayer = 257,
|
||||
jumptoplayer_only = 256,
|
||||
jumptoplayer_bits = 257, // NOTE: two bits set!
|
||||
seekplayer = 512,
|
||||
furthestdir = 1024,
|
||||
dodgebullet = 4096
|
||||
|
|
|
@ -629,7 +629,7 @@ GAMEEXEC_STATIC void VM_Move(void)
|
|||
if (movflags&face_player_slow)
|
||||
VM_FacePlayer(4);
|
||||
|
||||
if ((movflags&jumptoplayer) == jumptoplayer)
|
||||
if ((movflags&jumptoplayer_bits) == jumptoplayer_bits)
|
||||
{
|
||||
if (AC_COUNT(vm.g_t) < 16)
|
||||
vm.g_sp->zvel -= (sintable[(512+(AC_COUNT(vm.g_t)<<4))&2047]>>5);
|
||||
|
@ -958,7 +958,7 @@ static void VM_Fall(int32_t g_i, spritetype *g_sp)
|
|||
int32_t moveScriptOfs = AC_MOVE_ID(vm.g_t);
|
||||
#endif
|
||||
// fix for flying/jumping monsters getting stuck in water
|
||||
if ((AC_MOVFLAGS(g_sp, &actor[vm.g_i]) & jumptoplayer) ||
|
||||
if ((AC_MOVFLAGS(g_sp, &actor[vm.g_i]) & jumptoplayer_bits) == jumptoplayer_only ||
|
||||
(G_HaveActor(g_sp->picnum) &&
|
||||
#if !defined LUNATIC
|
||||
(unsigned)moveScriptOfs < (unsigned)g_scriptSize-1 && script[moveScriptOfs + 1]
|
||||
|
|
|
@ -904,6 +904,8 @@ do
|
|||
spin = 32,
|
||||
faceplayersmart = 64,
|
||||
fleeenemy = 128,
|
||||
jumptoplayer_only = 256,
|
||||
jumptoplayer_bits = 257, -- NOTE: two bits set!
|
||||
jumptoplayer = 257,
|
||||
seekplayer = 512,
|
||||
furthestdir = 1024,
|
||||
|
|
|
@ -1122,9 +1122,12 @@ Contains symbolic names of values applicable to <<gameactor,`gameactor`>>'s
|
|||
[[actor_MOVFLAGS]] `actor.MOVFLAGS`::
|
||||
Contains symbolic names of values applicable <<gameactor,`gameactor`>>'s
|
||||
`movflags` input argument, `actor[]:set_move()`, and the like. +
|
||||
`faceplayer`, `geth`, `getv`, `randomangle`, `faceplayerslow`, `spin`,
|
||||
`faceplayersmart`, `fleeenemy`, `jumptoplayer`, `seekplayer`, `furthestdir`,
|
||||
`dodgebullet`.
|
||||
* `faceplayer`, `geth`, `getv`, `randomangle`, `faceplayerslow`, `spin`,
|
||||
`faceplayersmart`, `fleeenemy`, `seekplayer`, `furthestdir`,
|
||||
`dodgebullet`, all naming single bits
|
||||
* `jumptoplayer_bits`: the bitwise-OR of *two* bits, one of which is `faceplayer`
|
||||
* `jumptoplayer_only`: the same as `jumptoplayer_bits`, but without the `faceplayer` bit set
|
||||
* `jumptoplayer`: [red]*deprecated*
|
||||
|
||||
'''
|
||||
[[player]]
|
||||
|
|
Loading…
Reference in a new issue