- transitioned the 5 primary action keys: Open, Jump, Crouch and Fire/AltFire.

This commit is contained in:
Christoph Oelckers 2020-08-28 22:51:05 +02:00
parent d62d2eaec7
commit b9e0f493b2
27 changed files with 352 additions and 436 deletions

View file

@ -4749,7 +4749,7 @@ void MoveDude(spritetype *pSprite)
if (pPlayer) { if (pPlayer) {
pPlayer->posture = 0; pPlayer->posture = 0;
pPlayer->bubbleTime = 0; pPlayer->bubbleTime = 0;
if (!pPlayer->cantJump && pPlayer->input.syncFlags.jump) { if (!pPlayer->cantJump && (pPlayer->input.actions & SB_JUMP)) {
zvel[nSprite] = -0x6aaaa; zvel[nSprite] = -0x6aaaa;
pPlayer->cantJump = 1; pPlayer->cantJump = 1;
} }

View file

@ -73,6 +73,7 @@ char gUserMapFilename[BMAX_PATH];
short BloodVersion = 0x115; short BloodVersion = 0x115;
bool gameRestart;
int gNetPlayers; int gNetPlayers;
int gQuitRequest; int gQuitRequest;
@ -529,7 +530,7 @@ void ProcessFrame(void)
auto oldflags = inp.syncFlags.value; auto oldflags = inp.syncFlags.value;
inp = gFifoInput[gNetFifoTail & 255][i]; inp = gFifoInput[gNetFifoTail & 255][i];
inp.actions |= oldactions & SB_INTERFACE_MASK; // should be everything non-button and non-weapon inp.actions |= oldactions & ~(SB_BUTTON_MASK|SB_RUN|SB_WEAPONMASK_BITS); // should be everything non-button and non-weapon
inp.syncFlags.value |= oldflags & ~flag_buttonmask; inp.syncFlags.value |= oldflags & ~flag_buttonmask;
int newweap = inp.getNewWeapon(); int newweap = inp.getNewWeapon();
@ -562,6 +563,13 @@ void ProcessFrame(void)
} }
} }
#endif #endif
// This is single player only.
if (gameRestart)
{
gameRestart = false;
levelRestart();
return;
}
viewClearInterpolations(); viewClearInterpolations();
{ {
if (paused || gEndGameMgr.at0 || (gGameOptions.nGameType == 0 && M_Active())) if (paused || gEndGameMgr.at0 || (gGameOptions.nGameType == 0 && M_Active()))

View file

@ -169,24 +169,6 @@ void ctrlGetInput(void)
cl_showweapon = (cl_showweapon + 1) & 3; cl_showweapon = (cl_showweapon + 1) & 3;
} }
if (buttonMap.ButtonDown(gamefunc_Jump))
gInput.syncFlags.jump = 1;
if (buttonMap.ButtonDown(gamefunc_Crouch))
gInput.syncFlags.crouch = 1;
if (buttonMap.ButtonDown(gamefunc_Fire))
gInput.syncFlags.shoot = 1;
if (buttonMap.ButtonDown(gamefunc_Alt_Fire))
gInput.syncFlags.shoot2 = 1;
if (buttonMap.ButtonDown(gamefunc_Open))
{
buttonMap.ClearButton(gamefunc_Open);
gInput.syncFlags.action = 1;
}
gInput.syncFlags.lookUp |= buttonMap.ButtonDown(gamefunc_Look_Up); gInput.syncFlags.lookUp |= buttonMap.ButtonDown(gamefunc_Look_Up);
gInput.syncFlags.lookDown |= buttonMap.ButtonDown(gamefunc_Look_Down); gInput.syncFlags.lookDown |= buttonMap.ButtonDown(gamefunc_Look_Down);

View file

@ -1990,7 +1990,7 @@ void usePropertiesChanger(XSPRITE* pXSource, short objType, int objIndex) {
xsprite[pSpr->extra].medium = kMediumNormal; xsprite[pSpr->extra].medium = kMediumNormal;
if (pPlayer) { if (pPlayer) {
pPlayer->posture = (!pPlayer->input.syncFlags.crouch) ? kPostureStand : kPostureCrouch; pPlayer->posture = (!(pPlayer->input.actions & SB_CROUCH)) ? kPostureStand : kPostureCrouch;
pPlayer->nWaterPal = 0; pPlayer->nWaterPal = 0;
} }
@ -2087,7 +2087,7 @@ void useTeleportTarget(XSPRITE* pXSource, spritetype* pSprite) {
xsprite[pSprite->extra].medium = kMediumNormal; xsprite[pSprite->extra].medium = kMediumNormal;
if (pPlayer) { if (pPlayer) {
pPlayer->posture = (!pPlayer->input.syncFlags.crouch) ? kPostureStand : kPostureCrouch; pPlayer->posture = (!(pPlayer->input.actions & SB_CROUCH)) ? kPostureStand : kPostureCrouch;
pPlayer->nWaterPal = 0; pPlayer->nWaterPal = 0;
} }
@ -2889,10 +2889,10 @@ bool condCheckPlayer(XSPRITE* pXCond, int cmpOp, bool PUSH) {
case 2: return (pPlayer->input.fvel < 0); // backward case 2: return (pPlayer->input.fvel < 0); // backward
case 3: return (pPlayer->input.svel > 0); // left case 3: return (pPlayer->input.svel > 0); // left
case 4: return (pPlayer->input.svel < 0); // right case 4: return (pPlayer->input.svel < 0); // right
case 5: return (pPlayer->input.syncFlags.jump); // jump case 5: return !!(pPlayer->input.actions & SB_JUMP); // jump
case 6: return (pPlayer->input.syncFlags.crouch); // crouch case 6: return !!(pPlayer->input.actions & SB_CROUCH); // crouch
case 7: return (pPlayer->input.syncFlags.shoot); // normal fire weapon case 7: return !!(pPlayer->input.actions & SB_FIRE); // normal fire weapon
case 8: return (pPlayer->input.syncFlags.shoot2); // alt fire weapon case 8: return !!(pPlayer->input.actions & SB_ALTFIRE); // alt fire weapon
default: default:
condError(pXCond, "Player conditions:\nSpecify a correct key!"); condError(pXCond, "Player conditions:\nSpecify a correct key!");
break; break;

View file

@ -51,6 +51,8 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_BLD_NS BEGIN_BLD_NS
extern bool gameRestart;
PROFILE gProfile[kMaxPlayers]; PROFILE gProfile[kMaxPlayers];
PLAYER gPlayer[kMaxPlayers]; PLAYER gPlayer[kMaxPlayers];
@ -762,6 +764,7 @@ void playerStart(int nPlayer, int bNewLevel)
pPlayer->nextWeapon = 0; pPlayer->nextWeapon = 0;
xvel[pSprite->index] = yvel[pSprite->index] = zvel[pSprite->index] = 0; xvel[pSprite->index] = yvel[pSprite->index] = zvel[pSprite->index] = 0;
pInput->q16avel = 0; pInput->q16avel = 0;
pInput->actions = 0;
pInput->syncFlags.value = 0; pInput->syncFlags.value = 0;
pInput->fvel = 0; pInput->fvel = 0;
pInput->svel = 0; pInput->svel = 0;
@ -1330,7 +1333,7 @@ void ProcessInput(PLAYER *pPlayer)
} }
pPlayer->isRunning = pInput->syncFlags.run; pPlayer->isRunning = pInput->syncFlags.run;
if ((pInput->syncFlags.value & flag_buttonmask_norun) || pInput->fvel || pInput->svel || pInput->q16avel) if ((pInput->syncFlags.value & flag_buttonmask_norun) || (pInput->actions & SB_BUTTON_MASK) || pInput->fvel || pInput->svel || pInput->q16avel)
pPlayer->restTime = 0; pPlayer->restTime = 0;
else if (pPlayer->restTime >= 0) else if (pPlayer->restTime >= 0)
pPlayer->restTime += 4; pPlayer->restTime += 4;
@ -1353,7 +1356,7 @@ void ProcessInput(PLAYER *pPlayer)
} }
if (pPlayer->curWeapon) if (pPlayer->curWeapon)
pInput->setNewWeapon(pPlayer->curWeapon); pInput->setNewWeapon(pPlayer->curWeapon);
if (pInput->syncFlags.action) if (pInput->actions & SB_OPEN)
{ {
if (bSeqStat) if (bSeqStat)
{ {
@ -1369,12 +1372,12 @@ void ProcessInput(PLAYER *pPlayer)
playerReset(pPlayer); playerReset(pPlayer);
if (gGameOptions.nGameType == 0 && numplayers == 1) if (gGameOptions.nGameType == 0 && numplayers == 1)
{ {
pInput->syncFlags.restart = 1; gameRestart = 1;
} }
else else
playerStart(pPlayer->nPlayer); playerStart(pPlayer->nPlayer);
} }
pInput->syncFlags.action = 0; pInput->actions &= ~SB_OPEN;
} }
return; return;
} }
@ -1431,11 +1434,11 @@ void ProcessInput(PLAYER *pPlayer)
} }
if (pInput->q16avel) if (pInput->q16avel)
pPlayer->q16ang = (pPlayer->q16ang+pInput->q16avel)&0x7ffffff; pPlayer->q16ang = (pPlayer->q16ang+pInput->q16avel)&0x7ffffff;
if (pInput->syncFlags.spin180) if (pInput->actions & SB_TURNAROUND)
{ {
if (!pPlayer->spin) if (!pPlayer->spin)
pPlayer->spin = -1024; pPlayer->spin = -1024;
pInput->syncFlags.spin180 = 0; pInput->actions &= ~SB_TURNAROUND;
} }
if (pPlayer->spin < 0) if (pPlayer->spin < 0)
{ {
@ -1453,22 +1456,22 @@ void ProcessInput(PLAYER *pPlayer)
gViewAngleAdjust += float(pSprite->ang - pPlayer->angold); gViewAngleAdjust += float(pSprite->ang - pPlayer->angold);
pPlayer->q16ang = (pPlayer->q16ang+fix16_from_int(pSprite->ang-pPlayer->angold))&0x7ffffff; pPlayer->q16ang = (pPlayer->q16ang+fix16_from_int(pSprite->ang-pPlayer->angold))&0x7ffffff;
pPlayer->angold = pSprite->ang = fix16_to_int(pPlayer->q16ang); pPlayer->angold = pSprite->ang = fix16_to_int(pPlayer->q16ang);
if (!pInput->syncFlags.jump) if (!(pInput->actions & SB_JUMP))
pPlayer->cantJump = 0; pPlayer->cantJump = 0;
switch (pPlayer->posture) { switch (pPlayer->posture) {
case 1: case 1:
if (pInput->syncFlags.jump) if (pInput->actions & SB_JUMP)
zvel[nSprite] -= pPosture->normalJumpZ;//0x5b05; zvel[nSprite] -= pPosture->normalJumpZ;//0x5b05;
if (pInput->syncFlags.crouch) if (pInput->actions & SB_CROUCH)
zvel[nSprite] += pPosture->normalJumpZ;//0x5b05; zvel[nSprite] += pPosture->normalJumpZ;//0x5b05;
break; break;
case 2: case 2:
if (!pInput->syncFlags.crouch) if (!(pInput->actions & SB_CROUCH))
pPlayer->posture = 0; pPlayer->posture = 0;
break; break;
default: default:
if (!pPlayer->cantJump && pInput->syncFlags.jump && pXSprite->height == 0) { if (!pPlayer->cantJump && (pInput->actions & SB_JUMP) && pXSprite->height == 0) {
#ifdef NOONE_EXTENSIONS #ifdef NOONE_EXTENSIONS
if ((packItemActive(pPlayer, 4) && pPosture->pwupJumpZ != 0) || pPosture->normalJumpZ != 0) if ((packItemActive(pPlayer, 4) && pPosture->pwupJumpZ != 0) || pPosture->normalJumpZ != 0)
#endif #endif
@ -1479,11 +1482,11 @@ void ProcessInput(PLAYER *pPlayer)
pPlayer->cantJump = 1; pPlayer->cantJump = 1;
} }
if (pInput->syncFlags.crouch) if (pInput->actions & SB_CROUCH)
pPlayer->posture = 2; pPlayer->posture = 2;
break; break;
} }
if (pInput->syncFlags.action) if (pInput->actions & SB_OPEN)
{ {
int a2, a3; int a2, a3;
int hit = ActionScan(pPlayer, &a2, &a3); int hit = ActionScan(pPlayer, &a2, &a3);
@ -1556,18 +1559,18 @@ void ProcessInput(PLAYER *pPlayer)
zvel[pSprite2->index] = zvel[nSprite]; zvel[pSprite2->index] = zvel[nSprite];
pPlayer->hand = 0; pPlayer->hand = 0;
} }
pInput->syncFlags.action = 0; pInput->actions &= ~SB_OPEN;
} }
if (bVanilla) if (bVanilla)
{ {
if (pInput->syncFlags.lookCenter && !pInput->syncFlags.lookUp && !pInput->syncFlags.lookDown) if ((pInput->actions & SB_CENTERVIEW) && !pInput->syncFlags.lookUp && !pInput->syncFlags.lookDown)
{ {
if (pPlayer->q16look < 0) if (pPlayer->q16look < 0)
pPlayer->q16look = fix16_min(pPlayer->q16look+fix16_from_int(4), fix16_from_int(0)); pPlayer->q16look = fix16_min(pPlayer->q16look+fix16_from_int(4), fix16_from_int(0));
if (pPlayer->q16look > 0) if (pPlayer->q16look > 0)
pPlayer->q16look = fix16_max(pPlayer->q16look-fix16_from_int(4), fix16_from_int(0)); pPlayer->q16look = fix16_max(pPlayer->q16look-fix16_from_int(4), fix16_from_int(0));
if (!pPlayer->q16look) if (!pPlayer->q16look)
pInput->syncFlags.lookCenter = 0; pInput->actions &= ~SB_CENTERVIEW;
} }
else else
{ {
@ -1590,14 +1593,14 @@ void ProcessInput(PLAYER *pPlayer)
int downAngle = -347; int downAngle = -347;
double lookStepUp = 4.0*upAngle/60.0; double lookStepUp = 4.0*upAngle/60.0;
double lookStepDown = -4.0*downAngle/60.0; double lookStepDown = -4.0*downAngle/60.0;
if (pInput->syncFlags.lookCenter && !pInput->syncFlags.lookUp && !pInput->syncFlags.lookDown) if ((pInput->actions & SB_CENTERVIEW) && !pInput->syncFlags.lookUp && !pInput->syncFlags.lookDown)
{ {
if (pPlayer->q16look < 0) if (pPlayer->q16look < 0)
pPlayer->q16look = fix16_min(pPlayer->q16look+fix16_from_dbl(lookStepDown), fix16_from_int(0)); pPlayer->q16look = fix16_min(pPlayer->q16look+fix16_from_dbl(lookStepDown), fix16_from_int(0));
if (pPlayer->q16look > 0) if (pPlayer->q16look > 0)
pPlayer->q16look = fix16_max(pPlayer->q16look-fix16_from_dbl(lookStepUp), fix16_from_int(0)); pPlayer->q16look = fix16_max(pPlayer->q16look-fix16_from_dbl(lookStepUp), fix16_from_int(0));
if (!pPlayer->q16look) if (!pPlayer->q16look)
pInput->syncFlags.lookCenter = 0; pInput->actions &= ~SB_CENTERVIEW;
} }
else else
{ {
@ -1616,7 +1619,7 @@ void ProcessInput(PLAYER *pPlayer)
{ {
gViewLookAdjust -= float(lookStepDown); gViewLookAdjust -= float(lookStepDown);
} }
gViewLookRecenter = pInput->syncFlags.lookCenter && !pInput->syncFlags.lookUp && !pInput->syncFlags.lookDown; gViewLookRecenter = (pInput->actions & SB_CENTERVIEW) && !pInput->syncFlags.lookUp && !pInput->syncFlags.lookDown;
} }
pPlayer->q16look = fix16_clamp(pPlayer->q16look+(pInput->q16horz<<3), fix16_from_int(downAngle), fix16_from_int(upAngle)); pPlayer->q16look = fix16_clamp(pPlayer->q16look+(pInput->q16horz<<3), fix16_from_int(downAngle), fix16_from_int(upAngle));
pPlayer->q16horiz = fix16_from_float(100.f*tanf(fix16_to_float(pPlayer->q16look)*fPI/1024.f)); pPlayer->q16horiz = fix16_from_float(100.f*tanf(fix16_to_float(pPlayer->q16look)*fPI/1024.f));
@ -1688,9 +1691,9 @@ void ProcessInput(PLAYER *pPlayer)
if (pPlayer->packSlots[0].curAmount > 0) if (pPlayer->packSlots[0].curAmount > 0)
packUseItem(pPlayer, 0); packUseItem(pPlayer, 0);
} }
if (pInput->syncFlags.holsterWeapon) if (pInput->actions & SB_HOLSTER)
{ {
pInput->syncFlags.holsterWeapon = 0; pInput->actions &= ~SB_HOLSTER;
if (pPlayer->curWeapon) if (pPlayer->curWeapon)
{ {
WeaponLower(pPlayer); WeaponLower(pPlayer);

View file

@ -1767,17 +1767,17 @@ char sub_4F0E0(PLAYER *pPlayer)
switch (pPlayer->weaponState) switch (pPlayer->weaponState)
{ {
case 5: case 5:
if (!pPlayer->input.syncFlags.shoot2) if (!(pPlayer->input.actions & SB_ALTFIRE))
pPlayer->weaponState = 6; pPlayer->weaponState = 6;
return 1; return 1;
case 6: case 6:
if (pPlayer->input.syncFlags.shoot2) if (pPlayer->input.actions & SB_ALTFIRE)
{ {
pPlayer->weaponState = 3; pPlayer->weaponState = 3;
pPlayer->fuseTime = pPlayer->weaponTimer; pPlayer->fuseTime = pPlayer->weaponTimer;
StartQAV(pPlayer, 13, nClientDropCan, 0); StartQAV(pPlayer, 13, nClientDropCan, 0);
} }
else if (pPlayer->input.syncFlags.shoot) else if (pPlayer->input.actions & SB_FIRE)
{ {
pPlayer->weaponState = 7; pPlayer->weaponState = 7;
pPlayer->fuseTime = 0; pPlayer->fuseTime = 0;
@ -1787,7 +1787,7 @@ char sub_4F0E0(PLAYER *pPlayer)
case 7: case 7:
{ {
pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536); pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536);
if (!pPlayer->input.syncFlags.shoot) if (!(pPlayer->input.actions & SB_FIRE))
{ {
if (!pPlayer->fuseTime) if (!pPlayer->fuseTime)
pPlayer->fuseTime = pPlayer->weaponTimer; pPlayer->fuseTime = pPlayer->weaponTimer;
@ -1805,17 +1805,17 @@ char sub_4F200(PLAYER *pPlayer)
switch (pPlayer->weaponState) switch (pPlayer->weaponState)
{ {
case 4: case 4:
if (!pPlayer->input.syncFlags.shoot2) if (!(pPlayer->input.actions & SB_ALTFIRE))
pPlayer->weaponState = 5; pPlayer->weaponState = 5;
return 1; return 1;
case 5: case 5:
if (pPlayer->input.syncFlags.shoot2) if (pPlayer->input.actions & SB_ALTFIRE)
{ {
pPlayer->weaponState = 1; pPlayer->weaponState = 1;
pPlayer->fuseTime = pPlayer->weaponTimer; pPlayer->fuseTime = pPlayer->weaponTimer;
StartQAV(pPlayer, 22, nClientDropBundle, 0); StartQAV(pPlayer, 22, nClientDropBundle, 0);
} }
else if (pPlayer->input.syncFlags.shoot) else if (pPlayer->input.actions & SB_FIRE)
{ {
pPlayer->weaponState = 6; pPlayer->weaponState = 6;
pPlayer->fuseTime = 0; pPlayer->fuseTime = 0;
@ -1825,7 +1825,7 @@ char sub_4F200(PLAYER *pPlayer)
case 6: case 6:
{ {
pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536); pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536);
if (!pPlayer->input.syncFlags.shoot) if (!(pPlayer->input.actions & SB_FIRE))
{ {
if (!pPlayer->fuseTime) if (!pPlayer->fuseTime)
pPlayer->fuseTime = pPlayer->weaponTimer; pPlayer->fuseTime = pPlayer->weaponTimer;
@ -1845,7 +1845,7 @@ char sub_4F320(PLAYER *pPlayer)
case 9: case 9:
pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536); pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536);
pPlayer->weaponTimer = 0; pPlayer->weaponTimer = 0;
if (!pPlayer->input.syncFlags.shoot) if (!(pPlayer->input.actions & SB_FIRE))
{ {
pPlayer->weaponState = 8; pPlayer->weaponState = 8;
StartQAV(pPlayer, 29, nClientThrowProx, 0); StartQAV(pPlayer, 29, nClientThrowProx, 0);
@ -1861,7 +1861,7 @@ char sub_4F3A0(PLAYER *pPlayer)
{ {
case 13: case 13:
pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536); pPlayer->throwPower = ClipHigh(divscale16(gFrameClock-pPlayer->throwTime,240), 65536);
if (!pPlayer->input.syncFlags.shoot) if (!(pPlayer->input.actions & SB_FIRE))
{ {
pPlayer->weaponState = 11; pPlayer->weaponState = 11;
StartQAV(pPlayer, 39, nClientThrowRemote, 0); StartQAV(pPlayer, 39, nClientThrowRemote, 0);
@ -1880,7 +1880,7 @@ char sub_4F414(PLAYER *pPlayer)
StartQAV(pPlayer, 114, nClientFireLifeLeech, 1); StartQAV(pPlayer, 114, nClientFireLifeLeech, 1);
return 1; return 1;
case 6: case 6:
if (!pPlayer->input.syncFlags.shoot2) if (!(pPlayer->input.actions & SB_ALTFIRE))
{ {
pPlayer->weaponState = 2; pPlayer->weaponState = 2;
StartQAV(pPlayer, 118, -1, 0); StartQAV(pPlayer, 118, -1, 0);
@ -1907,7 +1907,7 @@ char sub_4F484(PLAYER *pPlayer)
StartQAV(pPlayer, 77, nClientFireTesla, 1); StartQAV(pPlayer, 77, nClientFireTesla, 1);
return 1; return 1;
case 5: case 5:
if (!pPlayer->input.syncFlags.shoot) if (!(pPlayer->input.actions & SB_FIRE))
{ {
pPlayer->weaponState = 2; pPlayer->weaponState = 2;
if (sub_4B2C8(pPlayer, 7, 10) && powerupCheck(pPlayer, kPwUpTwoGuns)) if (sub_4B2C8(pPlayer, 7, 10) && powerupCheck(pPlayer, kPwUpTwoGuns))
@ -1968,8 +1968,8 @@ void WeaponProcess(PLAYER *pPlayer) {
WeaponPlay(pPlayer); WeaponPlay(pPlayer);
UpdateAimVector(pPlayer); UpdateAimVector(pPlayer);
pPlayer->weaponTimer -= 4; pPlayer->weaponTimer -= 4;
char bShoot = pPlayer->input.syncFlags.shoot; bool bShoot = pPlayer->input.actions & SB_FIRE;
char bShoot2 = pPlayer->input.syncFlags.shoot2; bool bShoot2 = pPlayer->input.actions & SB_ALTFIRE;
if (pPlayer->qavLoop && pPlayer->pXSprite->health > 0) if (pPlayer->qavLoop && pPlayer->pXSprite->health > 0)
{ {
if (bShoot && CheckAmmo(pPlayer, pPlayer->weaponAmmo, 1)) if (bShoot && CheckAmmo(pPlayer, pPlayer->weaponAmmo, 1))

View file

@ -343,25 +343,28 @@ void ApplyGlobalInput(InputPacket& input, ControlInfo *info)
input.actions |= ActionsToSend; input.actions |= ActionsToSend;
ActionsToSend = 0; ActionsToSend = 0;
if (buttonMap.ButtonDown(gamefunc_Jump))
input.actions |= SB_JUMP;
if (buttonMap.ButtonDown(gamefunc_Crouch))
input.actions |= SB_CROUCH;
if (buttonMap.ButtonDown(gamefunc_Fire))
input.actions |= SB_FIRE;
if (buttonMap.ButtonDown(gamefunc_Alt_Fire))
input.actions |= SB_ALTFIRE;
if (buttonMap.ButtonDown(gamefunc_Open))
{
if (g_gameType & GAMEFLAG_BLOOD) buttonMap.ClearButton(gamefunc_Open);
input.actions |= SB_OPEN;
}
} }
#if 0 #if 0
void registerinputcommands()
{
C_RegisterFunction("centerview", nullptr, [](CCmdFuncPtr)->int { BitsToSend.lookCenter = 1; return CCMD_OK; });
C_RegisterFunction("holsterweapon", nullptr, [](CCmdFuncPtr)->int { BitsToSend.holsterWeapon = 1; return CCMD_OK; });
C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend.spin180 = 1; return CCMD_OK; });
}
//---------------------------------------------------------------------------
//
// CCMD based input. The basics are from Randi's ZDuke but this uses dynamic
// registration to only have the commands active when this game module runs.
//
//---------------------------------------------------------------------------
C_RegisterFunction("backoff", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_ESCAPE; return CCMD_OK; }); C_RegisterFunction("backoff", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_ESCAPE; return CCMD_OK; });
}
#endif #endif

View file

@ -21,12 +21,19 @@ enum ESyncBits_ : uint32_t
SB_CENTERVIEW = 1 << 14, SB_CENTERVIEW = 1 << 14,
SB_TURNAROUND = 1 << 15, SB_TURNAROUND = 1 << 15,
SB_HOLSTER = 1 << 16, SB_HOLSTER = 1 << 16,
SB_OPEN = 1 << 17,
SB_RUN = 1 << 27,
SB_JUMP = 1 << 28,
SB_CROUCH = 1 << 29,
SB_FIRE = 1 << 30,
SB_ALTFIRE = 1u << 31,
SB_WEAPONMASK_BITS = (15u * SB_FIRST_WEAPON_BIT), // Weapons take up 4 bits SB_WEAPONMASK_BITS = (15u * SB_FIRST_WEAPON_BIT), // Weapons take up 4 bits
SB_ITEMUSE_BITS = (127u * SB_ITEM_BIT_1), SB_ITEMUSE_BITS = (127u * SB_ITEM_BIT_1),
SB_BUTTON_MASK = 0, // all input from buttons (i.e. active while held) SB_BUTTON_MASK = SB_ALTFIRE|SB_FIRE|SB_CROUCH|SB_JUMP, // all input from buttons (i.e. active while held)
SB_INTERFACE_MASK = (SB_INVPREV|SB_INVNEXT|SB_INVUSE|SB_CENTERVIEW|SB_TURNAROUND|SB_HOLSTER), // all input from CCMDs SB_INTERFACE_MASK = (SB_INVPREV|SB_INVNEXT|SB_INVUSE|SB_CENTERVIEW|SB_TURNAROUND|SB_HOLSTER|SB_OPEN), // all input from CCMDs
SB_INTERFACE_BITS = (SB_WEAPONMASK_BITS | SB_ITEMUSE_BITS | SB_INTERFACE_MASK), SB_INTERFACE_BITS = (SB_WEAPONMASK_BITS | SB_ITEMUSE_BITS | SB_INTERFACE_MASK),
SB_ALL = ~0u SB_ALL = ~0u
}; };
@ -60,9 +67,6 @@ enum
enum EDukeSyncBits_ : uint32_t enum EDukeSyncBits_ : uint32_t
{ {
SKB_JUMP = 1 << 0,
SKB_CROUCH = 1 << 1,
SKB_FIRE = 1 << 2,
SKB_AIM_UP = 1 << 3, SKB_AIM_UP = 1 << 3,
SKB_AIM_DOWN = 1 << 4, SKB_AIM_DOWN = 1 << 4,
SKB_RUN = 1 << 5, SKB_RUN = 1 << 5,
@ -72,11 +76,10 @@ enum EDukeSyncBits_ : uint32_t
SKB_LOOK_DOWN = 1 << 14, SKB_LOOK_DOWN = 1 << 14,
SKB_QUICK_KICK = 1 << 22, SKB_QUICK_KICK = 1 << 22,
SKB_AIMMODE = 1 << 23, SKB_AIMMODE = 1 << 23,
SKB_OPEN = 1 << 29,
SKB_ESCAPE = 1u << 31, SKB_ESCAPE = 1u << 31,
SKB_INTERFACE_BITS = (SKB_QUICK_KICK | \ SKB_INTERFACE_BITS = (SKB_QUICK_KICK | \
SKB_OPEN | SKB_ESCAPE), SKB_ESCAPE),
SKB_NONE = 0, SKB_NONE = 0,
SKB_ALL = ~0u SKB_ALL = ~0u
@ -93,15 +96,14 @@ union SYNCFLAGS
struct struct
{ {
unsigned int run : 1; unsigned int run : 1;
unsigned int jump : 1; unsigned int _jump : 1;
unsigned int crouch : 1; unsigned int _crouch : 1;
unsigned int shoot : 1; unsigned int _shoot : 1;
unsigned int shoot2 : 1; unsigned int _shoot2 : 1;
unsigned int lookUp : 1; unsigned int lookUp : 1;
unsigned int lookDown : 1; unsigned int lookDown : 1;
unsigned int action : 1;
unsigned int jab : 1; unsigned int jab : 1;
unsigned int lookLeft : 1; unsigned int lookLeft : 1;
unsigned int lookRight : 1; unsigned int lookRight : 1;
@ -123,12 +125,8 @@ union SYNCFLAGS
#define SK_FLY 15 #define SK_FLY 15
#define SK_RUN 16 #define SK_RUN 16
#define SK_SHOOT 17 #define SK_AIM_UP 21
#define SK_OPERATE 18 #define SK_AIM_DOWN 22
#define SK_JUMP 19
#define SK_CRAWL 20
#define SK_SNAP_UP 21
#define SK_SNAP_DOWN 22
#define SK_SPACE_BAR 31 #define SK_SPACE_BAR 31
@ -136,10 +134,6 @@ union SYNCFLAGS
// Exhumed // Exhumed
enum { enum {
kButtonJump = 0x1,
kButtonOpen = 0x4,
kButtonFire = 0x8,
kButtonCrouch = 0x10,
kButtonCheatGuns = 0x20, kButtonCheatGuns = 0x20,
kButtonCheatGodMode = 0x40, kButtonCheatGodMode = 0x40,
kButtonCheatKeys = 0x80, kButtonCheatKeys = 0x80,

View file

@ -501,7 +501,6 @@ void GameTicker()
{ {
lastTic = currentTic; lastTic = currentTic;
int lLocalButtons = GetLocalInput(); // shouldn't this be placed in localInput?
PlayerInterruptKeys(false); PlayerInterruptKeys(false);
nPlayerDAng = fix16_sadd(nPlayerDAng, localInput.q16avel); nPlayerDAng = fix16_sadd(nPlayerDAng, localInput.q16avel);
@ -601,7 +600,7 @@ void GameTicker()
sPlayerInput[nLocalPlayer].xVel = lPlayerXVel; sPlayerInput[nLocalPlayer].xVel = lPlayerXVel;
sPlayerInput[nLocalPlayer].yVel = lPlayerYVel; sPlayerInput[nLocalPlayer].yVel = lPlayerYVel;
// make weapon selection persist until it gets used up. // make weapon selection persist until it gets used up.
sPlayerInput[nLocalPlayer].buttons = lLocalButtons | lLocalCodes; sPlayerInput[nLocalPlayer].buttons = lLocalCodes;
int weap = sPlayerInput[nLocalPlayer].getNewWeapon(); int weap = sPlayerInput[nLocalPlayer].getNewWeapon();
sPlayerInput[nLocalPlayer].actions = localInput.actions; sPlayerInput[nLocalPlayer].actions = localInput.actions;
if (weap2 <= 0 || weap2 > 7) sPlayerInput[nLocalPlayer].SetNewWeapon(weap); if (weap2 <= 0 || weap2 > 7) sPlayerInput[nLocalPlayer].SetNewWeapon(weap);
@ -635,52 +634,12 @@ void InitTimer()
htimer = 1; htimer = 1;
} }
static const char* actions[] =
{
"Move_Forward",
"Move_Backward",
"Turn_Left",
"Turn_Right",
"Strafe",
"Fire",
"Open",
"Run",
"Alt_Fire", // Duke3D", Blood
"Jump",
"Crouch",
"Look_Up",
"Look_Down",
"Look_Left",
"Look_Right",
"Strafe_Left",
"Strafe_Right",
"Aim_Up",
"Aim_Down",
"SendMessage",
"Shrink_Screen",
"Enlarge_Screen",
"Show_Opponents_Weapon",
"See_Coop_View",
"Mouse_Aiming",
"Dpad_Select",
"Dpad_Aiming",
"Last_Weapon",
"Alt_Weapon",
"Third_Person_View",
"Toggle_Crouch", // This is the last one used by EDuke32.
};
void GameInterface::app_init() void GameInterface::app_init()
{ {
int i; int i;
//int esi = 1; //int esi = 1;
//int edi = esi; //int edi = esi;
buttonMap.SetButtons(actions, NUM_ACTIONS);
help_disabled = true; help_disabled = true;
// Create the global level table. Parts of the engine need it, even though the game itself does not. // Create the global level table. Parts of the engine need it, even though the game itself does not.
for (int i = 0; i <= 32; i++) for (int i = 0; i <= 32; i++)

View file

@ -74,26 +74,10 @@ void InitInput()
void ClearSpaceBar(short nPlayer) void ClearSpaceBar(short nPlayer)
{ {
sPlayerInput[nPlayer].buttons &= 0x0FB; sPlayerInput[nPlayer].actions &= SB_OPEN;
buttonMap.ClearButton(gamefunc_Open); buttonMap.ClearButton(gamefunc_Open);
} }
int GetLocalInput()
{
int lLocalButtons;
if (PlayerList[nLocalPlayer].nHealth)
{
lLocalButtons = (buttonMap.ButtonDown(gamefunc_Crouch) << 4) | (buttonMap.ButtonDown(gamefunc_Fire) << 3)
| (buttonMap.ButtonDown(gamefunc_Jump) << 0);
}
else
{
lLocalButtons = 0;
}
lLocalButtons |= buttonMap.ButtonDown(gamefunc_Open) << 2;
return lLocalButtons;
}
void BackupInput() void BackupInput()
{ {
@ -189,6 +173,7 @@ void PlayerInterruptKeys(bool after)
if (!after) if (!after)
{ {
ApplyGlobalInput(localInput, &info); ApplyGlobalInput(localInput, &info);
if (PlayerList[nLocalPlayer].nHealth == 0) localInput.actions &= ~(SB_FIRE | SB_JUMP | SB_CROUCH);
} }

View file

@ -1279,6 +1279,7 @@ loc_1AB8E:
int var_5C = SectFlag[nViewSect] & kSectUnderwater; int var_5C = SectFlag[nViewSect] & kSectUnderwater;
uint16_t buttons = sPlayerInput[nPlayer].buttons; uint16_t buttons = sPlayerInput[nPlayer].buttons;
auto actions = sPlayerInput[nPlayer].actions;
if (buttons & kButtonCheatGodMode) // LOBODEITY cheat if (buttons & kButtonCheatGodMode) // LOBODEITY cheat
{ {
@ -2535,7 +2536,7 @@ do_default_b:
if (!PlayerList[nPlayer].bIsMummified) if (!PlayerList[nPlayer].bIsMummified)
{ {
if (buttons & kButtonOpen) if (actions & SB_OPEN)
{ {
ClearSpaceBar(nPlayer); ClearSpaceBar(nPlayer);
@ -2551,7 +2552,7 @@ do_default_b:
} }
// was int var_38 = buttons & 0x8 // was int var_38 = buttons & 0x8
if (buttons & kButtonFire) if (actions & SB_FIRE)
{ {
FireWeapon(nPlayer); FireWeapon(nPlayer);
} }
@ -2568,7 +2569,7 @@ do_default_b:
} }
// Jumping // Jumping
if (buttons & kButtonJump) if (actions & SB_JUMP)
{ {
if (bUnderwater) if (bUnderwater)
{ {
@ -2586,7 +2587,7 @@ do_default_b:
// goto loc_1BE70: // goto loc_1BE70:
} }
else if (buttons & kButtonCrouch) else if (actions & SB_CROUCH)
{ {
if (bUnderwater) if (bUnderwater)
{ {
@ -2647,7 +2648,7 @@ loc_1BD2E:
} }
} }
// loc_1BE30 // loc_1BE30
if (buttons & kButtonFire) // was var_38 if (actions & SB_FIRE) // was var_38
{ {
if (bUnderwater) if (bUnderwater)
{ {
@ -2679,7 +2680,7 @@ loc_1BD2E:
} }
else // player is mummified else // player is mummified
{ {
if (buttons & kButtonFire) if (actions & SB_FIRE)
{ {
FireWeapon(nPlayer); FireWeapon(nPlayer);
} }
@ -2708,7 +2709,7 @@ loc_1BD2E:
else // else, player's health is less than 0 else // else, player's health is less than 0
{ {
// loc_1C0E9 // loc_1C0E9
if (buttons & kButtonOpen) if (actions & SB_OPEN)
{ {
ClearSpaceBar(nPlayer); ClearSpaceBar(nPlayer);

View file

@ -1522,7 +1522,7 @@ bool queball(int i, int pocket, int queball, int stripeball)
// if(s->pal == 12) // if(s->pal == 12)
{ {
j = getincangle(ps[p].getang(), getangle(s->x - ps[p].posx, s->y - ps[p].posy)); j = getincangle(ps[p].getang(), getangle(s->x - ps[p].posx, s->y - ps[p].posy));
if (j > -64 && j < 64 && PlayerInput(p, SKB_OPEN)) if (j > -64 && j < 64 && PlayerInput(p, SB_OPEN))
if (ps[p].toggle_key_flag == 1) if (ps[p].toggle_key_flag == 1)
{ {
int a = headspritestat[STAT_ACTOR]; int a = headspritestat[STAT_ACTOR];

View file

@ -2126,13 +2126,13 @@ void movetransports_d(void)
else if (!(sectlotag == 1 && ps[p].on_ground == 1)) break; else if (!(sectlotag == 1 && ps[p].on_ground == 1)) break;
if (onfloorz == 0 && abs(sprite[i].z - ps[p].posz) < 6144) if (onfloorz == 0 && abs(sprite[i].z - ps[p].posz) < 6144)
if ((ps[p].jetpack_on == 0) || (ps[p].jetpack_on && (PlayerInput(p, SKB_JUMP))) || if ((ps[p].jetpack_on == 0) || (ps[p].jetpack_on && (PlayerInput(p, SB_JUMP))) ||
(ps[p].jetpack_on && (PlayerInput(p, SKB_CROUCH) ^ !!ps[p].crouch_toggle))) (ps[p].jetpack_on && (PlayerInput(p, SB_CROUCH) ^ !!ps[p].crouch_toggle)))
{ {
ps[p].oposx = ps[p].posx += sprite[sprite[i].owner].x - sprite[i].x; ps[p].oposx = ps[p].posx += sprite[sprite[i].owner].x - sprite[i].x;
ps[p].oposy = ps[p].posy += sprite[sprite[i].owner].y - sprite[i].y; ps[p].oposy = ps[p].posy += sprite[sprite[i].owner].y - sprite[i].y;
if (ps[p].jetpack_on && (PlayerInput(p, SKB_JUMP) || ps[p].jetpack_on < 11)) if (ps[p].jetpack_on && (PlayerInput(p, SB_JUMP) || ps[p].jetpack_on < 11))
ps[p].posz = sprite[sprite[i].owner].z - 6144; ps[p].posz = sprite[sprite[i].owner].z - 6144;
else ps[p].posz = sprite[sprite[i].owner].z + 6144; else ps[p].posz = sprite[sprite[i].owner].z + 6144;
ps[p].oposz = ps[p].posz; ps[p].oposz = ps[p].posz;
@ -2149,7 +2149,7 @@ void movetransports_d(void)
k = 0; k = 0;
if (onfloorz && sectlotag == ST_1_ABOVE_WATER && ps[p].on_ground && ps[p].posz > (sector[sect].floorz - (16 << 8)) && (PlayerInput(p, SKB_CROUCH) || ps[p].poszv > 2048)) if (onfloorz && sectlotag == ST_1_ABOVE_WATER && ps[p].on_ground && ps[p].posz > (sector[sect].floorz - (16 << 8)) && (PlayerInput(p, SB_CROUCH) || ps[p].poszv > 2048))
// if( onfloorz && sectlotag == 1 && ps[p].posz > (sector[sect].floorz-(6<<8)) ) // if( onfloorz && sectlotag == 1 && ps[p].posz > (sector[sect].floorz-(6<<8)) )
{ {
k = 1; k = 1;
@ -2478,7 +2478,7 @@ static void greenslime(int i)
s->ang = ps[p].getang(); s->ang = ps[p].getang();
if ((PlayerInput(p, SKB_FIRE) || (ps[p].quick_kick > 0)) && sprite[ps[p].i].extra > 0) if ((PlayerInput(p, SB_FIRE) || (ps[p].quick_kick > 0)) && sprite[ps[p].i].extra > 0)
if (ps[p].quick_kick > 0 || (ps[p].curr_weapon != HANDREMOTE_WEAPON && ps[p].curr_weapon != HANDBOMB_WEAPON && ps[p].curr_weapon != TRIPBOMB_WEAPON && ps[p].ammo_amount[ps[p].curr_weapon] >= 0)) if (ps[p].quick_kick > 0 || (ps[p].curr_weapon != HANDREMOTE_WEAPON && ps[p].curr_weapon != HANDBOMB_WEAPON && ps[p].curr_weapon != TRIPBOMB_WEAPON && ps[p].ammo_amount[ps[p].curr_weapon] >= 0))
{ {
for (x = 0; x < 8; x++) for (x = 0; x < 8; x++)

View file

@ -1755,13 +1755,13 @@ void movetransports_r(void)
else break; else break;
if (onfloorz == 0 && abs(sprite[i].z - ps[p].posz) < 6144) if (onfloorz == 0 && abs(sprite[i].z - ps[p].posz) < 6144)
if ((ps[p].jetpack_on == 0) || (ps[p].jetpack_on && PlayerInput(p, SKB_JUMP)) || if ((ps[p].jetpack_on == 0) || (ps[p].jetpack_on && PlayerInput(p, SB_JUMP)) ||
(ps[p].jetpack_on && PlayerInput(p, SKB_CROUCH))) (ps[p].jetpack_on && PlayerInput(p, SB_CROUCH)))
{ {
ps[p].oposx = ps[p].posx += sprite[OW].x - sprite[i].x; ps[p].oposx = ps[p].posx += sprite[OW].x - sprite[i].x;
ps[p].oposy = ps[p].posy += sprite[OW].y - sprite[i].y; ps[p].oposy = ps[p].posy += sprite[OW].y - sprite[i].y;
if (ps[p].jetpack_on && (PlayerInput(p, SKB_JUMP) || ps[p].jetpack_on < 11)) if (ps[p].jetpack_on && (PlayerInput(p, SB_JUMP) || ps[p].jetpack_on < 11))
ps[p].posz = sprite[OW].z - 6144; ps[p].posz = sprite[OW].z - 6144;
else ps[p].posz = sprite[OW].z + 6144; else ps[p].posz = sprite[OW].z + 6144;
ps[p].oposz = ps[p].posz; ps[p].oposz = ps[p].posz;

View file

@ -1163,7 +1163,7 @@ int ParseState::parse(void)
s = g_sp->xvel; s = g_sp->xvel;
// sigh... this was yet another place where number literals were used as bit masks for every single value, making the code totally unreadable. // sigh... this was yet another place where number literals were used as bit masks for every single value, making the code totally unreadable.
if( (l& pducking) && ps[g_p].on_ground && (PlayerInput(g_p, SKB_CROUCH) ^ !!(ps[g_p].crouch_toggle) )) if( (l& pducking) && ps[g_p].on_ground && (PlayerInput(g_p, SB_CROUCH) ^ !!(ps[g_p].crouch_toggle) ))
j = 1; j = 1;
else if( (l& pfalling) && ps[g_p].jumping_counter == 0 && !ps[g_p].on_ground && ps[g_p].poszv > 2048 ) else if( (l& pfalling) && ps[g_p].jumping_counter == 0 && !ps[g_p].on_ground && ps[g_p].poszv > 2048 )
j = 1; j = 1;
@ -1244,7 +1244,7 @@ int ParseState::parse(void)
parseifelse( (( hittype[g_i].floorz - hittype[g_i].ceilingz ) >> 8 ) < *insptr); parseifelse( (( hittype[g_i].floorz - hittype[g_i].ceilingz ) >> 8 ) < *insptr);
break; break;
case concmd_ifhitspace: case concmd_ifhitspace:
parseifelse(PlayerInput(g_p, SKB_OPEN)); parseifelse(PlayerInput(g_p, SB_OPEN));
break; break;
case concmd_ifoutside: case concmd_ifoutside:
parseifelse(sector[g_sp->sectnum].ceilingstat & 1); parseifelse(sector[g_sp->sectnum].ceilingstat & 1);

View file

@ -178,7 +178,7 @@ void mploadsave()
int domovethings() int domovethings()
{ {
int i, j; int i;
// mplpadsave(); // mplpadsave();

View file

@ -607,33 +607,34 @@ enum
static void processInputBits(player_struct *p, ControlInfo &info) static void processInputBits(player_struct *p, ControlInfo &info)
{ {
bool onVehicle = p->OnMotorcycle || p->OnBoat; bool onVehicle = p->OnMotorcycle || p->OnBoat;
if (buttonMap.ButtonDown(gamefunc_Fire)) loc.sbits |= SKB_FIRE;
if (buttonMap.ButtonDown(gamefunc_Open)) loc.sbits |= SKB_OPEN;
if (!onVehicle) if (!onVehicle)
{ {
if (buttonMap.ButtonDown(gamefunc_Jump)) loc.sbits |= SKB_JUMP; if (buttonMap.ButtonDown(gamefunc_Toggle_Crouch) || p->crouch_toggle)
if (buttonMap.ButtonDown(gamefunc_Crouch) || buttonMap.ButtonDown(gamefunc_Toggle_Crouch) || p->crouch_toggle)
{ {
loc.sbits |= SKB_CROUCH; loc.actions |= SB_CROUCH;
if (isRR()) loc.sbits &= ~SKB_JUMP;
} }
if (buttonMap.ButtonDown(gamefunc_Aim_Up) || (buttonMap.ButtonDown(gamefunc_Dpad_Aiming) && info.dz > 0)) loc.sbits |= SKB_AIM_UP; if (buttonMap.ButtonDown(gamefunc_Aim_Up) || (buttonMap.ButtonDown(gamefunc_Dpad_Aiming) && info.dz > 0)) loc.sbits |= SKB_AIM_UP;
if ((buttonMap.ButtonDown(gamefunc_Aim_Down) || (buttonMap.ButtonDown(gamefunc_Dpad_Aiming) && info.dz < 0))) loc.sbits |= SKB_AIM_DOWN; if ((buttonMap.ButtonDown(gamefunc_Aim_Down) || (buttonMap.ButtonDown(gamefunc_Dpad_Aiming) && info.dz < 0))) loc.sbits |= SKB_AIM_DOWN;
if (G_CheckAutorun(buttonMap.ButtonDown(gamefunc_Run))) loc.sbits |= SKB_RUN; if (G_CheckAutorun(buttonMap.ButtonDown(gamefunc_Run))) loc.sbits |= SKB_RUN;
if (buttonMap.ButtonDown(gamefunc_Look_Left) || (isRR() && p->drink_amt > 88)) loc.sbits |= SKB_LOOK_LEFT; if (buttonMap.ButtonDown(gamefunc_Look_Left)) loc.sbits |= SKB_LOOK_LEFT;
if (buttonMap.ButtonDown(gamefunc_Look_Right)) loc.sbits |= SKB_LOOK_RIGHT; if (buttonMap.ButtonDown(gamefunc_Look_Right)) loc.sbits |= SKB_LOOK_RIGHT;
if (buttonMap.ButtonDown(gamefunc_Look_Up)) loc.sbits |= SKB_LOOK_UP; if (buttonMap.ButtonDown(gamefunc_Look_Up)) loc.sbits |= SKB_LOOK_UP;
if (buttonMap.ButtonDown(gamefunc_Look_Down) || (isRR() && p->drink_amt > 99)) loc.sbits |= SKB_LOOK_DOWN; if (buttonMap.ButtonDown(gamefunc_Look_Down)) loc.sbits |= SKB_LOOK_DOWN;
if (buttonMap.ButtonDown(gamefunc_Quick_Kick)) loc.sbits |= SKB_QUICK_KICK; if (buttonMap.ButtonDown(gamefunc_Quick_Kick)) loc.sbits |= SKB_QUICK_KICK;
if (in_mousemode || buttonMap.ButtonDown(gamefunc_Mouse_Aiming)) loc.sbits |= SKB_AIMMODE; if (in_mousemode || buttonMap.ButtonDown(gamefunc_Mouse_Aiming)) loc.sbits |= SKB_AIMMODE;
if ((isRR() && p->drink_amt > 88)) loc.sbits |= SKB_LOOK_LEFT;
if ((isRR() && p->drink_amt > 99)) loc.sbits |= SKB_LOOK_DOWN;
} }
ApplyGlobalInput(loc, &info); ApplyGlobalInput(loc, &info);
if (isRR() && (loc.actions & SB_CROUCH)) loc.actions &= ~SB_JUMP;
if (onVehicle) if (onVehicle)
{ {
// mask out all actions not compatible with vehicles. // mask out all actions not compatible with vehicles.
loc.actions &= ~(SB_WEAPONMASK_BITS | SB_TURNAROUND | SB_CENTERVIEW | SB_HOLSTER); loc.actions &= ~(SB_WEAPONMASK_BITS | SB_TURNAROUND | SB_CENTERVIEW | SB_HOLSTER | SB_JUMP | SB_CROUCH);
} }
if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming)) if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
@ -978,11 +979,11 @@ static void processVehicleInput(player_struct *p, ControlInfo& info, InputPacket
if (p->OnBoat || !p->moto_underwater) if (p->OnBoat || !p->moto_underwater)
{ {
if (buttonMap.ButtonDown(gamefunc_Move_Forward) || buttonMap.ButtonDown(gamefunc_Strafe)) if (buttonMap.ButtonDown(gamefunc_Move_Forward) || buttonMap.ButtonDown(gamefunc_Strafe))
loc.sbits |= SKB_JUMP; loc.actions |= SB_JUMP;
if (buttonMap.ButtonDown(gamefunc_Move_Backward)) if (buttonMap.ButtonDown(gamefunc_Move_Backward))
loc.sbits |= SKB_AIM_UP; loc.sbits |= SKB_AIM_UP;
if (buttonMap.ButtonDown(gamefunc_Run)) if (buttonMap.ButtonDown(gamefunc_Run))
loc.sbits |= SKB_CROUCH; loc.actions |= SB_CROUCH;
} }
if (turnl) if (turnl)

View file

@ -41,7 +41,7 @@ source as it is released.
BEGIN_DUKE_NS BEGIN_DUKE_NS
void fireweapon_ww(int snum); void fireweapon_ww(int snum);
void operateweapon_ww(int snum, EDukeSyncBits sb_snum, int psect); void operateweapon_ww(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect);
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
// //
@ -1498,7 +1498,7 @@ int doincrements_d(struct player_struct* p)
} }
S_PlayActorSound(DUKE_CRACK_FIRST, p->i); S_PlayActorSound(DUKE_CRACK_FIRST, p->i);
} }
else if (p->knuckle_incs == 22 || PlayerInput(snum, SKB_FIRE)) else if (p->knuckle_incs == 22 || PlayerInput(snum, SB_FIRE))
p->knuckle_incs = 0; p->knuckle_incs = 0;
return 1; return 1;
@ -1552,7 +1552,7 @@ void checkweapons_d(struct player_struct* p)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void operateJetpack(int snum, EDukeSyncBits sb_snum, int psectlotag, int fz, int cz, int shrunk) static void operateJetpack(int snum, ESyncBits actions, int psectlotag, int fz, int cz, int shrunk)
{ {
int j; int j;
auto p = &ps[snum]; auto p = &ps[snum];
@ -1582,7 +1582,7 @@ static void operateJetpack(int snum, EDukeSyncBits sb_snum, int psectlotag, int
if (shrunk) j = 512; if (shrunk) j = 512;
else j = 2048; else j = 2048;
if (sb_snum & SKB_JUMP) //A (soar high) if (actions & SB_JUMP) //A (soar high)
{ {
// jump // jump
SetGameVarID(g_iReturnVarID, 0, pi, snum); SetGameVarID(g_iReturnVarID, 0, pi, snum);
@ -1594,7 +1594,7 @@ static void operateJetpack(int snum, EDukeSyncBits sb_snum, int psectlotag, int
} }
} }
if (sb_snum & SKB_CROUCH) //Z (soar low) if (actions & SB_CROUCH) //Z (soar low)
{ {
// crouch // crouch
SetGameVarID(g_iReturnVarID, 0, pi, snum); SetGameVarID(g_iReturnVarID, 0, pi, snum);
@ -1626,7 +1626,7 @@ static void operateJetpack(int snum, EDukeSyncBits sb_snum, int psectlotag, int
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz, int shrunk, int truefdist, int psectlotag) static void movement(int snum, ESyncBits actions, int psect, int fz, int cz, int shrunk, int truefdist, int psectlotag)
{ {
int j; int j;
auto p = &ps[snum]; auto p = &ps[snum];
@ -1675,7 +1675,7 @@ static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz,
{ {
// not jumping or crouching // not jumping or crouching
if ((sb_snum & (SKB_JUMP|SKB_CROUCH)) == 0 && p->on_ground && (sector[psect].floorstat & 2) && p->posz >= (fz - (i << 8) - (16 << 8))) if ((actions & (SB_JUMP|SB_CROUCH)) == 0 && p->on_ground && (sector[psect].floorstat & 2) && p->posz >= (fz - (i << 8) - (16 << 8)))
p->posz = fz - (i << 8); p->posz = fz - (i << 8);
else else
{ {
@ -1751,27 +1751,27 @@ static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz,
p->on_warping_sector = 0; p->on_warping_sector = 0;
if (sb_snum & SKB_CROUCH) if (actions & SB_CROUCH)
{ {
playerCrouch(snum); playerCrouch(snum);
} }
// jumping // jumping
if ((sb_snum & SKB_JUMP) == 0 && p->jumping_toggle == 1) if ((actions & SB_JUMP) == 0 && p->jumping_toggle == 1)
p->jumping_toggle = 0; p->jumping_toggle = 0;
else if ((sb_snum & SKB_JUMP)) else if ((actions & SB_JUMP))
{ {
playerJump(snum, fz, cz); playerJump(snum, fz, cz);
} }
if (p->jumping_counter && (sb_snum & SKB_JUMP) == 0) if (p->jumping_counter && (actions & SB_JUMP) == 0)
p->jumping_toggle = 0; p->jumping_toggle = 0;
} }
if (p->jumping_counter) if (p->jumping_counter)
{ {
if ((sb_snum & SKB_JUMP) == 0 && p->jumping_toggle == 1) if ((actions & SB_JUMP) == 0 && p->jumping_toggle == 1)
p->jumping_toggle = 0; p->jumping_toggle = 0;
if (p->jumping_counter < (1024 + 256)) if (p->jumping_counter < (1024 + 256))
@ -1813,7 +1813,7 @@ static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz,
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void underwater(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz) static void underwater(int snum, ESyncBits actions, int psect, int fz, int cz)
{ {
int j; int j;
auto p = &ps[snum]; auto p = &ps[snum];
@ -1830,14 +1830,14 @@ static void underwater(int snum, EDukeSyncBits sb_snum, int psect, int fz, int c
if (!S_CheckActorSoundPlaying(pi, DUKE_UNDERWATER)) if (!S_CheckActorSoundPlaying(pi, DUKE_UNDERWATER))
S_PlayActorSound(DUKE_UNDERWATER, pi); S_PlayActorSound(DUKE_UNDERWATER, pi);
if (sb_snum & SKB_JUMP) if (actions & SB_JUMP)
{ {
// jump // jump
if (p->poszv > 0) p->poszv = 0; if (p->poszv > 0) p->poszv = 0;
p->poszv -= 348; p->poszv -= 348;
if (p->poszv < -(256 * 6)) p->poszv = -(256 * 6); if (p->poszv < -(256 * 6)) p->poszv = -(256 * 6);
} }
else if (sb_snum & SKB_CROUCH) else if (actions & SB_CROUCH)
{ {
// crouch // crouch
if (p->poszv < 0) p->poszv = 0; if (p->poszv < 0) p->poszv = 0;
@ -2062,7 +2062,7 @@ static void fireweapon(int snum)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect) static void operateweapon(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect)
{ {
auto p = &ps[snum]; auto p = &ps[snum];
int pi = p->i; int pi = p->i;
@ -2073,7 +2073,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
switch (p->curr_weapon) switch (p->curr_weapon)
{ {
case HANDBOMB_WEAPON: // grenade in NAM case HANDBOMB_WEAPON: // grenade in NAM
if (p->kickback_pic == 6 && (sb_snum & SKB_FIRE)) if (p->kickback_pic == 6 && (actions & SB_FIRE))
{ {
p->rapid_fire_hold = 1; p->rapid_fire_hold = 1;
break; break;
@ -2083,7 +2083,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
{ {
p->ammo_amount[HANDBOMB_WEAPON]--; p->ammo_amount[HANDBOMB_WEAPON]--;
if (p->on_ground && (sb_snum & SKB_CROUCH)) if (p->on_ground && (actions & SB_CROUCH))
{ {
k = 15; k = 15;
i = ((p->gethorizsum() - 100) * 20); i = ((p->gethorizsum() - 100) * 20);
@ -2122,7 +2122,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
p->hbomb_on = 1; p->hbomb_on = 1;
} }
else if (p->kickback_pic < 12 && (sb_snum & SKB_FIRE)) else if (p->kickback_pic < 12 && (actions & SB_FIRE))
p->hbomb_hold_delay++; p->hbomb_hold_delay++;
else if (p->kickback_pic > 19) else if (p->kickback_pic > 19)
{ {
@ -2282,7 +2282,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
p->visibility = 0; p->visibility = 0;
checkavailweapon(p); checkavailweapon(p);
if ((sb_snum & SKB_FIRE) == 0) if ((actions & SB_FIRE) == 0)
{ {
p->okickback_pic = p->kickback_pic = 0; p->okickback_pic = p->kickback_pic = 0;
break; break;
@ -2291,7 +2291,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
} }
else if (p->kickback_pic > 10) else if (p->kickback_pic > 10)
{ {
if (sb_snum & SKB_FIRE) p->okickback_pic = p->kickback_pic = 1; if (actions & SB_FIRE) p->okickback_pic = p->kickback_pic = 1;
else p->okickback_pic = p->kickback_pic = 0; else p->okickback_pic = p->kickback_pic = 0;
} }
@ -2429,7 +2429,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
} }
else else
{ {
if (sb_snum & SKB_FIRE) if (actions & SB_FIRE)
{ {
p->okickback_pic = p->kickback_pic = 1; p->okickback_pic = p->kickback_pic = 1;
S_PlayActorSound(CAT_FIRE, pi); S_PlayActorSound(CAT_FIRE, pi);
@ -2455,7 +2455,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
} }
else if (p->kickback_pic == 16) else if (p->kickback_pic == 16)
{ {
if ((sb_snum & SKB_FIRE) != 0) if ((actions & SB_FIRE) != 0)
{ {
p->okickback_pic = p->kickback_pic = 1; p->okickback_pic = p->kickback_pic = 1;
S_PlayActorSound(FLAMETHROWER_INTRO, pi); S_PlayActorSound(FLAMETHROWER_INTRO, pi);
@ -2487,7 +2487,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
if (p->kickback_pic == 7) fi.shoot(pi, KNEE); if (p->kickback_pic == 7) fi.shoot(pi, KNEE);
else if (p->kickback_pic == 14) else if (p->kickback_pic == 14)
{ {
if (sb_snum & SKB_FIRE) if (actions & SB_FIRE)
p->okickback_pic = p->kickback_pic = 1 + (krand() & 3); p->okickback_pic = p->kickback_pic = 1 + (krand() & 3);
else p->okickback_pic = p->kickback_pic = 0; else p->okickback_pic = p->kickback_pic = 0;
} }
@ -2547,7 +2547,7 @@ static void processweapon(int snum, ESyncBits actions, EDukeSyncBits sb_snum, in
p->ammo_amount[p->curr_weapon] % aplWeaponClip[p->curr_weapon][snum]; p->ammo_amount[p->curr_weapon] % aplWeaponClip[p->curr_weapon][snum];
// p->kickback_pic = aplWeaponFireDelay[p->curr_weapon][snum]+1; // animate, but don't shoot... // p->kickback_pic = aplWeaponFireDelay[p->curr_weapon][snum]+1; // animate, but don't shoot...
p->kickback_pic = aplWeaponTotalTime[p->curr_weapon][snum] + 1; // animate, but don't shoot... p->kickback_pic = aplWeaponTotalTime[p->curr_weapon][snum] + 1; // animate, but don't shoot...
sb_snum &= ~SKB_FIRE; // not firing... actions &= ~SB_FIRE; // not firing...
} }
return; return;
} }
@ -2560,7 +2560,7 @@ static void processweapon(int snum, ESyncBits actions, EDukeSyncBits sb_snum, in
// throw away the remaining clip // throw away the remaining clip
p->ammo_amount[PISTOL_WEAPON] -= p->ammo_amount[PISTOL_WEAPON] % 20; p->ammo_amount[PISTOL_WEAPON] -= p->ammo_amount[PISTOL_WEAPON] % 20;
p->kickback_pic = 3; // animate, but don't shoot... p->kickback_pic = 3; // animate, but don't shoot...
sb_snum &= ~SKB_FIRE; // not firing... actions &= ~SB_FIRE; // not firing...
} }
return; return;
} }
@ -2575,13 +2575,13 @@ static void processweapon(int snum, ESyncBits actions, EDukeSyncBits sb_snum, in
if (p->rapid_fire_hold == 1) if (p->rapid_fire_hold == 1)
{ {
if (sb_snum & SKB_FIRE) return; if (actions & SB_FIRE) return;
p->rapid_fire_hold = 0; p->rapid_fire_hold = 0;
} }
if (shrunk || p->tipincs || p->access_incs) if (shrunk || p->tipincs || p->access_incs)
sb_snum &= ~SKB_FIRE; actions &= ~SB_FIRE;
else if (shrunk == 0 && (sb_snum & SKB_FIRE) && p->kickback_pic == 0 && p->fist_incs == 0 && else if (shrunk == 0 && (actions & SB_FIRE) && p->kickback_pic == 0 && p->fist_incs == 0 &&
p->last_weapon == -1 && (p->weapon_pos == 0 || p->holster_weapon == 1)) p->last_weapon == -1 && (p->weapon_pos == 0 || p->holster_weapon == 1))
{ {
if (!isWW2GI()) fireweapon(snum); if (!isWW2GI()) fireweapon(snum);
@ -2589,8 +2589,8 @@ static void processweapon(int snum, ESyncBits actions, EDukeSyncBits sb_snum, in
} }
else if (p->kickback_pic) else if (p->kickback_pic)
{ {
if (!isWW2GI()) operateweapon(snum, sb_snum, psect); if (!isWW2GI()) operateweapon(snum, actions, sb_snum, psect);
else operateweapon_ww(snum, sb_snum, psect); else operateweapon_ww(snum, actions, sb_snum, psect);
} }
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
@ -2764,16 +2764,16 @@ void processinput_d(int snum)
if (psectlotag == ST_2_UNDERWATER) if (psectlotag == ST_2_UNDERWATER)
{ {
underwater(snum, sb_snum, psect, fz, cz); underwater(snum, actions, psect, fz, cz);
} }
else if (p->jetpack_on) else if (p->jetpack_on)
{ {
operateJetpack(snum, sb_snum, psectlotag, fz, cz, shrunk); operateJetpack(snum, actions, psectlotag, fz, cz, shrunk);
} }
else if (psectlotag != ST_2_UNDERWATER) else if (psectlotag != ST_2_UNDERWATER)
{ {
movement(snum, sb_snum, psect, fz, cz, shrunk, truefdist, psectlotag); movement(snum, actions, psect, fz, cz, shrunk, truefdist, psectlotag);
} }
p->psectlotag = psectlotag; p->psectlotag = psectlotag;
@ -2882,8 +2882,8 @@ void processinput_d(int snum)
bool check; bool check;
if (!isWW2GI()) check = ((p->curr_weapon == KNEE_WEAPON && p->kickback_pic > 10 && p->on_ground) || (p->on_ground && (sb_snum & SKB_CROUCH))); if (!isWW2GI()) check = ((p->curr_weapon == KNEE_WEAPON && p->kickback_pic > 10 && p->on_ground) || (p->on_ground && (actions & SB_CROUCH)));
else check = ((aplWeaponWorksLike[p->curr_weapon][snum] == KNEE_WEAPON && p->kickback_pic > 10 && p->on_ground) || (p->on_ground && (sb_snum & SKB_CROUCH))); else check = ((aplWeaponWorksLike[p->curr_weapon][snum] == KNEE_WEAPON && p->kickback_pic > 10 && p->on_ground) || (p->on_ground && (actions & SB_CROUCH)));
if (check) if (check)
{ {
p->posxv = mulscale(p->posxv, dukefriction - 0x2000, 16); p->posxv = mulscale(p->posxv, dukefriction - 0x2000, 16);
@ -3071,22 +3071,22 @@ HORIZONLY:
processweapon(snum, actions, sb_snum, psect); processweapon(snum, actions, sb_snum, psect);
} }
void processmove_d(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz, int shrunk, int truefdist) void processmove_d(int snum, ESyncBits actions, int psect, int fz, int cz, int shrunk, int truefdist)
{ {
int psectlotag = sector[psect].lotag; int psectlotag = sector[psect].lotag;
auto p = &ps[snum]; auto p = &ps[snum];
if (psectlotag == 2) if (psectlotag == 2)
{ {
underwater(snum, sb_snum, psect, fz, cz); underwater(snum, actions, psect, fz, cz);
} }
else if (p->jetpack_on) else if (p->jetpack_on)
{ {
operateJetpack(snum, sb_snum, psectlotag, fz, cz, shrunk); operateJetpack(snum, actions, psectlotag, fz, cz, shrunk);
} }
else if (psectlotag != 2) else if (psectlotag != 2)
{ {
movement(snum, sb_snum, psect, fz, cz, shrunk, truefdist, psectlotag); movement(snum, actions, psect, fz, cz, shrunk, truefdist, psectlotag);
} }
} }
END_DUKE_NS END_DUKE_NS

View file

@ -1411,7 +1411,7 @@ int doincrements_r(struct player_struct* p)
else S_PlayActorSound(DUKE_CRACK2, p->i); else S_PlayActorSound(DUKE_CRACK2, p->i);
} }
} }
else if (p->knuckle_incs == 22 || PlayerInput(snum, SKB_FIRE)) else if (p->knuckle_incs == 22 || PlayerInput(snum, SB_FIRE))
p->knuckle_incs = 0; p->knuckle_incs = 0;
return 1; return 1;
@ -1513,7 +1513,7 @@ void checkweapons_r(struct player_struct* p)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void onMotorcycle(int snum, EDukeSyncBits &sb_snum) static void onMotorcycle(int snum, ESyncBits &actions, EDukeSyncBits &sb_snum)
{ {
auto p = &ps[snum]; auto p = &ps[snum];
auto pi = p->i; auto pi = p->i;
@ -1523,18 +1523,18 @@ static void onMotorcycle(int snum, EDukeSyncBits &sb_snum)
short var84; short var84;
if (p->MotoSpeed < 0) if (p->MotoSpeed < 0)
p->MotoSpeed = 0; p->MotoSpeed = 0;
if (sb_snum & SKB_CROUCH) if (actions & SB_CROUCH)
{ {
var64 = 1; var64 = 1;
sb_snum &= ~SKB_CROUCH; actions &= ~SB_CROUCH;
} }
else else
var64 = 0; var64 = 0;
if (sb_snum & SKB_JUMP) if (actions & SB_JUMP)
{ {
var68 = 1; var68 = 1;
sb_snum &= ~SKB_JUMP; actions &= ~SB_JUMP;
if (p->on_ground) if (p->on_ground)
{ {
if (p->MotoSpeed == 0 && var64) if (p->MotoSpeed == 0 && var64)
@ -1806,7 +1806,7 @@ static void onMotorcycle(int snum, EDukeSyncBits &sb_snum)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void onBoat(int snum, EDukeSyncBits& sb_snum) static void onBoat(int snum, ESyncBits &actions, EDukeSyncBits& sb_snum)
{ {
auto p = &ps[snum]; auto p = &ps[snum];
auto pi = p->i; auto pi = p->i;
@ -1829,19 +1829,19 @@ static void onBoat(int snum, EDukeSyncBits& sb_snum)
} }
if (p->MotoSpeed < 0) if (p->MotoSpeed < 0)
p->MotoSpeed = 0; p->MotoSpeed = 0;
if ((sb_snum & SKB_CROUCH) && (sb_snum & SKB_JUMP)) if ((actions & SB_CROUCH) && (actions & SB_JUMP))
{ {
vara8 = 1; vara8 = 1;
varac = 0; varac = 0;
varb0 = 0; varb0 = 0;
sb_snum &= ~(SKB_JUMP|SKB_CROUCH); actions &= ~(SB_JUMP|SB_CROUCH);
} }
else else
vara8 = 0; vara8 = 0;
if (sb_snum & SKB_JUMP) if (actions & SB_JUMP)
{ {
varac = 1; varac = 1;
sb_snum &= ~SKB_JUMP; actions &= ~SB_JUMP;
if (p->MotoSpeed == 0 && !S_CheckActorSoundPlaying(pi, 89)) if (p->MotoSpeed == 0 && !S_CheckActorSoundPlaying(pi, 89))
{ {
if (S_CheckActorSoundPlaying(pi, 87)) if (S_CheckActorSoundPlaying(pi, 87))
@ -1872,10 +1872,10 @@ static void onBoat(int snum, EDukeSyncBits& sb_snum)
S_PlayActorSound(87, pi); S_PlayActorSound(87, pi);
} }
if (sb_snum & SKB_CROUCH) if (actions & SB_CROUCH)
{ {
varb0 = 1; varb0 = 1;
sb_snum &= ~SKB_CROUCH; actions &= ~SB_CROUCH;
} }
else else
varb0 = 0; varb0 = 0;
@ -2090,7 +2090,7 @@ static void onBoat(int snum, EDukeSyncBits& sb_snum)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz, int shrunk, int truefdist, int psectlotag) static void movement(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect, int fz, int cz, int shrunk, int truefdist, int psectlotag)
{ {
auto p = &ps[snum]; auto p = &ps[snum];
auto pi = p->i; auto pi = p->i;
@ -2148,7 +2148,7 @@ static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz,
if (p->posz < (fz - (i << 8))) //falling if (p->posz < (fz - (i << 8))) //falling
{ {
if ((sb_snum & (SKB_JUMP|SKB_CROUCH)) == 0 && p->on_ground && (sector[psect].floorstat & 2) && p->posz >= (fz - (i << 8) - (16 << 8))) if ((actions & (SB_JUMP|SB_CROUCH)) == 0 && p->on_ground && (sector[psect].floorstat & 2) && p->posz >= (fz - (i << 8) - (16 << 8)))
p->posz = fz - (i << 8); p->posz = fz - (i << 8);
else else
{ {
@ -2262,15 +2262,15 @@ static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz,
p->on_warping_sector = 0; p->on_warping_sector = 0;
if ((sb_snum & SKB_CROUCH) && !p->OnMotorcycle) if ((actions & SB_CROUCH) && !p->OnMotorcycle)
{ {
playerCrouch(snum); playerCrouch(snum);
} }
if ((sb_snum & SKB_JUMP) == 0 && !p->OnMotorcycle && p->jumping_toggle == 1) if ((actions & SB_JUMP) == 0 && !p->OnMotorcycle && p->jumping_toggle == 1)
p->jumping_toggle = 0; p->jumping_toggle = 0;
else if ((sb_snum & SKB_JUMP) && !p->OnMotorcycle && p->jumping_toggle == 0) else if ((actions & SB_JUMP) && !p->OnMotorcycle && p->jumping_toggle == 0)
{ {
playerJump(snum, fz, cz); playerJump(snum, fz, cz);
} }
@ -2278,7 +2278,7 @@ static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz,
if (p->jumping_counter) if (p->jumping_counter)
{ {
if ((sb_snum & SKB_JUMP) == 0 && !p->OnMotorcycle && p->jumping_toggle == 1) if ((actions & SB_JUMP) == 0 && !p->OnMotorcycle && p->jumping_toggle == 1)
p->jumping_toggle = 0; p->jumping_toggle = 0;
if (p->jumping_counter < 768) if (p->jumping_counter < 768)
@ -2320,7 +2320,7 @@ static void movement(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz,
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void underwater(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz) static void underwater(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect, int fz, int cz)
{ {
int j; int j;
auto p = &ps[snum]; auto p = &ps[snum];
@ -2336,13 +2336,13 @@ static void underwater(int snum, EDukeSyncBits sb_snum, int psect, int fz, int c
if (!S_CheckActorSoundPlaying(pi, DUKE_UNDERWATER)) if (!S_CheckActorSoundPlaying(pi, DUKE_UNDERWATER))
S_PlayActorSound(DUKE_UNDERWATER, pi); S_PlayActorSound(DUKE_UNDERWATER, pi);
if ((sb_snum & SKB_JUMP) && !p->OnMotorcycle) if ((actions & SB_JUMP) && !p->OnMotorcycle)
{ {
if (p->poszv > 0) p->poszv = 0; if (p->poszv > 0) p->poszv = 0;
p->poszv -= 348; p->poszv -= 348;
if (p->poszv < -(256 * 6)) p->poszv = -(256 * 6); if (p->poszv < -(256 * 6)) p->poszv = -(256 * 6);
} }
else if ((sb_snum & SKB_CROUCH) || p->OnMotorcycle) else if ((actions & SB_CROUCH) || p->OnMotorcycle)
{ {
if (p->poszv < 0) p->poszv = 0; if (p->poszv < 0) p->poszv = 0;
p->poszv += 348; p->poszv += 348;
@ -2744,7 +2744,7 @@ static void fireweapon(int snum)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect) static void operateweapon(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect)
{ {
auto p = &ps[snum]; auto p = &ps[snum];
int pi = p->i; int pi = p->i;
@ -2758,7 +2758,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
if (p->kickback_pic == 1) if (p->kickback_pic == 1)
S_PlaySound(401); S_PlaySound(401);
if (p->kickback_pic == 6 && (sb_snum & SKB_FIRE)) if (p->kickback_pic == 6 && (actions & SB_FIRE))
p->rapid_fire_hold = 1; p->rapid_fire_hold = 1;
p->kickback_pic++; p->kickback_pic++;
if (p->kickback_pic > 19) if (p->kickback_pic > 19)
@ -2795,7 +2795,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
p->ammo_amount[DYNAMITE_WEAPON]--; p->ammo_amount[DYNAMITE_WEAPON]--;
if (p->ammo_amount[CROSSBOW_WEAPON]) if (p->ammo_amount[CROSSBOW_WEAPON])
p->ammo_amount[CROSSBOW_WEAPON]--; p->ammo_amount[CROSSBOW_WEAPON]--;
if (p->on_ground && (sb_snum & SKB_CROUCH) && !p->OnMotorcycle) if (p->on_ground && (actions & SB_CROUCH) && !p->OnMotorcycle)
{ {
k = 15; k = 15;
i = ((p->gethorizsum() - 100) * 20); i = ((p->gethorizsum() - 100) * 20);
@ -2828,7 +2828,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
p->hbomb_on = 1; p->hbomb_on = 1;
} }
else if (p->kickback_pic < 12 && (sb_snum & SKB_FIRE)) else if (p->kickback_pic < 12 && (actions & SB_FIRE))
p->hbomb_hold_delay++; p->hbomb_hold_delay++;
if (p->kickback_pic == 40) if (p->kickback_pic == 40)
@ -2911,7 +2911,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
if (p->kickback_pic == 6) if (p->kickback_pic == 6)
if (p->shotgun_state[0] == 0) if (p->shotgun_state[0] == 0)
if (p->ammo_amount[SHOTGUN_WEAPON] > 1) if (p->ammo_amount[SHOTGUN_WEAPON] > 1)
if (sb_snum & SKB_FIRE) if (actions & SB_FIRE)
p->shotgun_state[1] = 1; p->shotgun_state[1] = 1;
if (p->kickback_pic == 4) if (p->kickback_pic == 4)
@ -3055,7 +3055,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
} }
checkavailweapon(p); checkavailweapon(p);
if ((sb_snum & SKB_FIRE) == 0) if ((actions & SB_FIRE) == 0)
{ {
p->kickback_pic = 0; p->kickback_pic = 0;
break; break;
@ -3064,7 +3064,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
} }
else if (p->kickback_pic > 10) else if (p->kickback_pic > 10)
{ {
if (sb_snum & SKB_FIRE) p->kickback_pic = 1; if (actions & SB_FIRE) p->kickback_pic = 1;
else p->kickback_pic = 0; else p->kickback_pic = 0;
} }
@ -3119,7 +3119,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
} }
if (p->kickback_pic > 4) if (p->kickback_pic > 4)
p->kickback_pic = 1; p->kickback_pic = 1;
if (!(sb_snum & SKB_FIRE)) if (!(actions & SB_FIRE))
p->kickback_pic = 0; p->kickback_pic = 0;
break; break;
@ -3149,7 +3149,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
} }
if (p->kickback_pic > 4) if (p->kickback_pic > 4)
p->kickback_pic = 1; p->kickback_pic = 1;
if (!(sb_snum & SKB_FIRE)) if (!(actions & SB_FIRE))
p->kickback_pic = 0; p->kickback_pic = 0;
break; break;
case BOAT_WEAPON: case BOAT_WEAPON:
@ -3205,7 +3205,7 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
{ {
p->ammo_amount[POWDERKEG_WEAPON]--; p->ammo_amount[POWDERKEG_WEAPON]--;
p->gotweapon.Clear(POWDERKEG_WEAPON); p->gotweapon.Clear(POWDERKEG_WEAPON);
if (p->on_ground && (sb_snum & SKB_CROUCH) && !p->OnMotorcycle) if (p->on_ground && (actions & SB_CROUCH) && !p->OnMotorcycle)
{ {
k = 15; k = 15;
i = ((p->gethorizsum() - 100) * 20); i = ((p->gethorizsum() - 100) * 20);
@ -3336,14 +3336,14 @@ static void operateweapon(int snum, EDukeSyncBits sb_snum, int psect)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
static void processweapon(int snum, EDukeSyncBits sb_snum, int psect) static void processweapon(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect)
{ {
auto p = &ps[snum]; auto p = &ps[snum];
int pi = p->i; int pi = p->i;
auto s = &sprite[pi]; auto s = &sprite[pi];
int shrunk = (s->yrepeat < 8); int shrunk = (s->yrepeat < 8);
if (sb_snum & SKB_FIRE) if (actions & SB_FIRE)
{ {
int a = 0; int a = 0;
} }
@ -3374,20 +3374,20 @@ static void processweapon(int snum, EDukeSyncBits sb_snum, int psect)
if (p->rapid_fire_hold == 1) if (p->rapid_fire_hold == 1)
{ {
if (sb_snum & SKB_FIRE) return; if (actions & SB_FIRE) return;
p->rapid_fire_hold = 0; p->rapid_fire_hold = 0;
} }
if (shrunk || p->tipincs || p->access_incs) if (shrunk || p->tipincs || p->access_incs)
sb_snum &= ~SKB_FIRE; actions &= ~SB_FIRE;
else if (shrunk == 0 && (sb_snum & SKB_FIRE) && p->kickback_pic == 0 && p->fist_incs == 0 && else if (shrunk == 0 && (actions & SB_FIRE) && p->kickback_pic == 0 && p->fist_incs == 0 &&
p->last_weapon == -1 && (p->weapon_pos == 0 || p->holster_weapon == 1)) p->last_weapon == -1 && (p->weapon_pos == 0 || p->holster_weapon == 1))
{ {
fireweapon(snum); fireweapon(snum);
} }
else if (p->kickback_pic) else if (p->kickback_pic)
{ {
operateweapon(snum, sb_snum, psect); operateweapon(snum, actions, sb_snum, psect);
} }
} }
@ -3423,11 +3423,11 @@ void processinput_r(int snum)
psect = p->cursectnum; psect = p->cursectnum;
if (p->OnMotorcycle && s->extra > 0) if (p->OnMotorcycle && s->extra > 0)
{ {
onMotorcycle(snum, sb_snum); onMotorcycle(snum, actions, sb_snum);
} }
else if (p->OnBoat && s->extra > 0) else if (p->OnBoat && s->extra > 0)
{ {
onBoat(snum, sb_snum); onBoat(snum, actions, sb_snum);
} }
if (psect == -1) if (psect == -1)
{ {
@ -3510,7 +3510,7 @@ void processinput_r(int snum)
if (!p->stairs) if (!p->stairs)
{ {
p->stairs = 10; p->stairs = 10;
if ((sb_snum & SKB_JUMP) && !p->OnMotorcycle) if ((actions & SB_JUMP) && !p->OnMotorcycle)
{ {
hz = 0; hz = 0;
cz = p->truecz; cz = p->truecz;
@ -3560,7 +3560,7 @@ void processinput_r(int snum)
if (!p->stairs) if (!p->stairs)
{ {
p->stairs = 10; p->stairs = 10;
if ((sb_snum & SKB_CROUCH) && !p->OnMotorcycle) if ((actions & SB_CROUCH) && !p->OnMotorcycle)
{ {
cz = sprite[j].z; cz = sprite[j].z;
hz = 0; hz = 0;
@ -3572,7 +3572,7 @@ void processinput_r(int snum)
} }
else if (sprite[j].picnum == TOILET || sprite[j].picnum == RRTILE2121) else if (sprite[j].picnum == TOILET || sprite[j].picnum == RRTILE2121)
{ {
if ((sb_snum & SKB_CROUCH) && !p->OnMotorcycle) if ((actions & SB_CROUCH) && !p->OnMotorcycle)
//if (Sound[436].num == 0) //if (Sound[436].num == 0)
{ {
S_PlayActorSound(436, p->i); S_PlayActorSound(436, p->i);
@ -3634,7 +3634,7 @@ void processinput_r(int snum)
fi.doincrements(p); fi.doincrements(p);
if (p->curr_weapon == THROWINGDYNAMITE_WEAPON) processweapon(snum, sb_snum, psect); if (p->curr_weapon == THROWINGDYNAMITE_WEAPON) processweapon(snum, actions, sb_snum, psect);
return; return;
} }
@ -3680,11 +3680,11 @@ void processinput_r(int snum)
if (psectlotag == ST_2_UNDERWATER) if (psectlotag == ST_2_UNDERWATER)
{ {
underwater(snum, sb_snum, psect, fz, cz); underwater(snum, actions, sb_snum, psect, fz, cz);
} }
else else
{ {
movement(snum, sb_snum, psect, fz, cz, shrunk, truefdist, psectlotag); movement(snum, actions, sb_snum, psect, fz, cz, shrunk, truefdist, psectlotag);
} }
p->psectlotag = psectlotag; p->psectlotag = psectlotag;
@ -3780,7 +3780,7 @@ void processinput_r(int snum)
p->posxv += ((sb_fvel * doubvel) << 6); p->posxv += ((sb_fvel * doubvel) << 6);
p->posyv += ((sb_svel * doubvel) << 6); p->posyv += ((sb_svel * doubvel) << 6);
if (!isRRRA() && ((p->curr_weapon == KNEE_WEAPON && p->kickback_pic > 10 && p->on_ground) || (p->on_ground && (sb_snum & SKB_CROUCH)))) if (!isRRRA() && ((p->curr_weapon == KNEE_WEAPON && p->kickback_pic > 10 && p->on_ground) || (p->on_ground && (actions & SB_CROUCH))))
{ {
p->posxv = mulscale(p->posxv, dukefriction - 0x2000, 16); p->posxv = mulscale(p->posxv, dukefriction - 0x2000, 16);
p->posyv = mulscale(p->posyv, dukefriction - 0x2000, 16); p->posyv = mulscale(p->posyv, dukefriction - 0x2000, 16);
@ -4096,7 +4096,7 @@ HORIZONLY:
else p->weapon_pos--; else p->weapon_pos--;
} }
processweapon(snum, sb_snum, psect); processweapon(snum, actions, sb_snum, psect);
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
@ -4105,17 +4105,17 @@ HORIZONLY:
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void processmove_r(int snum, EDukeSyncBits sb_snum, int psect, int fz, int cz, int shrunk, int truefdist) void processmove_r(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect, int fz, int cz, int shrunk, int truefdist)
{ {
int psectlotag = sector[psect].lotag; int psectlotag = sector[psect].lotag;
auto p = &ps[snum]; auto p = &ps[snum];
if (psectlotag == ST_2_UNDERWATER) if (psectlotag == ST_2_UNDERWATER)
{ {
underwater(snum, sb_snum, psect, fz, cz); underwater(snum, actions, sb_snum, psect, fz, cz);
} }
else else
{ {
movement(snum, sb_snum, psect, fz, cz, shrunk, truefdist, psectlotag); movement(snum, actions, sb_snum, psect, fz, cz, shrunk, truefdist, psectlotag);
} }
} }

View file

@ -306,7 +306,7 @@ void fireweapon_ww(int snum)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void operateweapon_ww(int snum, EDukeSyncBits sb_snum, int psect) void operateweapon_ww(int snum, ESyncBits actions, EDukeSyncBits sb_snum, int psect)
{ {
auto p = &ps[snum]; auto p = &ps[snum];
int pi = p->i; int pi = p->i;
@ -318,7 +318,7 @@ void operateweapon_ww(int snum, EDukeSyncBits sb_snum, int psect)
{ {
if (aplWeaponHoldDelay[p->curr_weapon][snum] // there is a hold delay if (aplWeaponHoldDelay[p->curr_weapon][snum] // there is a hold delay
&& (p->kickback_pic == aplWeaponFireDelay[p->curr_weapon][snum]) // and we are 'at' hold && (p->kickback_pic == aplWeaponFireDelay[p->curr_weapon][snum]) // and we are 'at' hold
&& (sb_snum & SKB_FIRE) // and 'fire' button is still down && (actions & SB_FIRE) // and 'fire' button is still down
) )
// just hold here... // just hold here...
{ {
@ -330,7 +330,7 @@ void operateweapon_ww(int snum, EDukeSyncBits sb_snum, int psect)
{ {
p->ammo_amount[p->curr_weapon]--; p->ammo_amount[p->curr_weapon]--;
if (p->on_ground && (sb_snum & SKB_CROUCH)) if (p->on_ground && (actions & SB_CROUCH))
{ {
k = 15; k = 15;
i = ((p->gethorizsum() - 100) * 20); i = ((p->gethorizsum() - 100) * 20);
@ -374,7 +374,7 @@ void operateweapon_ww(int snum, EDukeSyncBits sb_snum, int psect)
} }
else if (p->kickback_pic < aplWeaponHoldDelay[p->curr_weapon][snum] && else if (p->kickback_pic < aplWeaponHoldDelay[p->curr_weapon][snum] &&
(sb_snum & SKB_CROUCH)) (actions & SB_CROUCH))
{ {
p->hbomb_hold_delay++; p->hbomb_hold_delay++;
} }
@ -461,7 +461,7 @@ void operateweapon_ww(int snum, EDukeSyncBits sb_snum, int psect)
if (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_AUTOMATIC) if (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_AUTOMATIC)
{ // an 'automatic' { // an 'automatic'
if ((sb_snum & SKB_FIRE) == 0) if ((actions & SB_FIRE) == 0)
{ {
p->kickback_pic = aplWeaponTotalTime[p->curr_weapon][snum]; p->kickback_pic = aplWeaponTotalTime[p->curr_weapon][snum];
} }
@ -518,7 +518,7 @@ void operateweapon_ww(int snum, EDukeSyncBits sb_snum, int psect)
{ {
if (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_AUTOMATIC) if (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_AUTOMATIC)
{ // an 'automatic' { // an 'automatic'
if (sb_snum & SKB_FIRE) if (actions & SB_FIRE)
{ {
// we are an AUTOMATIC. Fire again... // we are an AUTOMATIC. Fire again...
if (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_RANDOMRESTART) if (aplWeaponFlags[p->curr_weapon][snum] & WEAPON_FLAG_RANDOMRESTART)

View file

@ -1520,7 +1520,7 @@ void checksectors_d(int snum)
if (chatmodeon || sprite[p->i].extra <= 0) return; if (chatmodeon || sprite[p->i].extra <= 0) return;
if (ud.cashman && PlayerInput(snum, SKB_OPEN)) if (ud.cashman && PlayerInput(snum, SB_OPEN))
fi.lotsofmoney(&sprite[p->i], 2); fi.lotsofmoney(&sprite[p->i], 2);
if (p->newowner >= 0) if (p->newowner >= 0)
@ -1532,7 +1532,7 @@ void checksectors_d(int snum)
} }
} }
if (!(PlayerInput(snum, SKB_OPEN)) && !PlayerInput(snum, SKB_ESCAPE)) if (!(PlayerInput(snum, SB_OPEN)) && !PlayerInput(snum, SKB_ESCAPE))
p->toggle_key_flag = 0; p->toggle_key_flag = 0;
else if (!p->toggle_key_flag) else if (!p->toggle_key_flag)
@ -1740,7 +1740,7 @@ void checksectors_d(int snum)
} }
} }
if (!PlayerInput(snum, SKB_OPEN)) return; if (!PlayerInput(snum, SB_OPEN)) return;
else if (p->newowner >= 0) { i = -1; goto CLEARCAMERAS; } else if (p->newowner >= 0) { i = -1; goto CLEARCAMERAS; }
if (neartagwall == -1 && neartagsector == -1 && neartagsprite == -1) if (neartagwall == -1 && neartagsector == -1 && neartagsprite == -1)

View file

@ -2484,11 +2484,11 @@ void checksectors_r(int snum)
if (chatmodeon || sprite[p->i].extra <= 0) return; if (chatmodeon || sprite[p->i].extra <= 0) return;
if (ud.cashman && PlayerInput(snum, SKB_OPEN)) if (ud.cashman && PlayerInput(snum, SB_OPEN))
fi.lotsofmoney(&sprite[p->i], 2); fi.lotsofmoney(&sprite[p->i], 2);
if (!(PlayerInput(snum, SKB_OPEN)) && !PlayerInput(snum, SKB_ESCAPE)) if (!(PlayerInput(snum, SB_OPEN)) && !PlayerInput(snum, SKB_ESCAPE))
p->toggle_key_flag = 0; p->toggle_key_flag = 0;
else if (!p->toggle_key_flag) else if (!p->toggle_key_flag)
@ -2709,7 +2709,7 @@ void checksectors_r(int snum)
} }
} }
if (!PlayerInput(snum, SKB_OPEN)) return; if (!PlayerInput(snum, SB_OPEN)) return;
if (neartagwall == -1 && neartagsector == -1 && neartagsprite == -1) if (neartagwall == -1 && neartagsector == -1 && neartagsprite == -1)
if (abs(hits(p->i)) < 512) if (abs(hits(p->i)) < 512)

View file

@ -323,12 +323,10 @@ getinput(InputPacket *loc, SWBOOL tied)
#endif #endif
} }
SET_LOC_KEY(loc->bits, SK_RUN, buttonMap.ButtonDown(gamefunc_Run));
SET_LOC_KEY(loc->bits, SK_SHOOT, buttonMap.ButtonDown(gamefunc_Fire));
// actually snap // actually snap
SET_LOC_KEY(loc->bits, SK_SNAP_UP, buttonMap.ButtonDown(gamefunc_Aim_Up)); SET_LOC_KEY(loc->bits, SK_AIM_UP, buttonMap.ButtonDown(gamefunc_Aim_Up));
SET_LOC_KEY(loc->bits, SK_SNAP_DOWN, buttonMap.ButtonDown(gamefunc_Aim_Down)); SET_LOC_KEY(loc->bits, SK_AIM_DOWN, buttonMap.ButtonDown(gamefunc_Aim_Down));
// actually just look // actually just look
SET_LOC_KEY(loc->bits, SK_LOOK_UP, buttonMap.ButtonDown(gamefunc_Look_Up)); SET_LOC_KEY(loc->bits, SK_LOOK_UP, buttonMap.ButtonDown(gamefunc_Look_Up));
@ -410,11 +408,6 @@ getinput(InputPacket *loc, SWBOOL tied)
loc->setNewWeapon(which_weapon); loc->setNewWeapon(which_weapon);
} }
SET_LOC_KEY(loc->bits, SK_OPERATE, buttonMap.ButtonDown(gamefunc_Open));
SET_LOC_KEY(loc->bits, SK_JUMP, buttonMap.ButtonDown(gamefunc_Jump));
SET_LOC_KEY(loc->bits, SK_CRAWL, buttonMap.ButtonDown(gamefunc_Crouch));
// need BUTTON // need BUTTON
SET_LOC_KEY(loc->bits, SK_CRAWL_LOCK, buttonMap.ButtonDown(gamefunc_Toggle_Crouch)); SET_LOC_KEY(loc->bits, SK_CRAWL_LOCK, buttonMap.ButtonDown(gamefunc_Toggle_Crouch));

View file

@ -465,9 +465,9 @@ int WeaponOperate(PLAYERp pp)
if (!TEST(pp->sop->flags, SOBJ_HAS_WEAPON)) if (!TEST(pp->sop->flags, SOBJ_HAS_WEAPON))
break; break;
if (TEST_SYNC_KEY(pp, SK_SHOOT)) if (pp->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(pp, SK_SHOOT)) if (pp->KeyPressBits & SB_FIRE)
{ {
if (!pp->FirePause) if (!pp->FirePause)
{ {
@ -693,7 +693,7 @@ WeaponOK(PLAYERp pp)
return TRUE; return TRUE;
} }
FLAG_KEY_RELEASE(pp, SK_SHOOT); pp->KeyPressBits &= ~SB_FIRE;
FindWeaponNum = WPN_SHOTGUN; // Start at the top FindWeaponNum = WPN_SHOTGUN; // Start at the top
@ -984,8 +984,7 @@ InitWeaponSword(PLAYERp pp)
PlayerSound(DIGI_ILIKESWORD, v3df_follow|v3df_dontpan,pp); PlayerSound(DIGI_ILIKESWORD, v3df_follow|v3df_dontpan,pp);
} }
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
@ -1065,9 +1064,9 @@ pSwordSlideDown(PANEL_SPRITEp psp)
if (psp->x < -40) if (psp->x < -40)
{ {
// if still holding down the fire key - continue swinging // if still holding down the fire key - continue swinging
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->KeyPressBits & SB_FIRE)
{ {
DoPlayerChooseYell(psp->PlayerP); DoPlayerChooseYell(psp->PlayerP);
// continue to next state to swing right // continue to next state to swing right
@ -1150,9 +1149,9 @@ pSwordSlideDownR(PANEL_SPRITEp psp)
if (psp->x > 350) if (psp->x > 350)
{ {
// if still holding down the fire key - continue swinging // if still holding down the fire key - continue swinging
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->KeyPressBits & SB_FIRE)
{ {
DoPlayerChooseYell(psp->PlayerP); DoPlayerChooseYell(psp->PlayerP);
// back to action state // back to action state
@ -1227,9 +1226,9 @@ pSwordRest(PANEL_SPRITEp psp)
force = !!TEST(psp->flags, PANF_UNHIDE_SHOOT); force = !!TEST(psp->flags, PANF_UNHIDE_SHOOT);
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -1361,9 +1360,9 @@ PANEL_STATE ps_RetractStar[] =
void void
pStarRestTest(PANEL_SPRITEp psp) pStarRestTest(PANEL_SPRITEp psp)
{ {
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->KeyPressBits & SB_FIRE)
{ {
if (!WeaponOK(psp->PlayerP)) if (!WeaponOK(psp->PlayerP))
return; return;
@ -1439,8 +1438,7 @@ InitWeaponStar(PLAYERp pp)
PlayerSound(DIGI_ILIKESHURIKEN, v3df_follow|v3df_dontpan,pp); PlayerSound(DIGI_ILIKESHURIKEN, v3df_follow|v3df_dontpan,pp);
} }
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
void void
@ -1518,9 +1516,9 @@ pStarRest(PANEL_SPRITEp psp)
pStarBobSetup(psp); pStarBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -2156,8 +2154,7 @@ InitWeaponUzi(PLAYERp pp)
PlaySound(DIGI_UZI_UP, pp, v3df_follow); PlaySound(DIGI_UZI_UP, pp, v3df_follow);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
PANEL_SPRITEp PANEL_SPRITEp
@ -2358,7 +2355,7 @@ pUziRest(PANEL_SPRITEp psp)
SetVisNorm(); SetVisNorm();
shooting = TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) && FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT); shooting = (psp->PlayerP->input.actions & SB_FIRE) && (psp->PlayerP->KeyPressBits & SB_FIRE);
shooting |= force; shooting |= force;
pUziBobSetup(psp); pUziBobSetup(psp);
@ -2383,7 +2380,7 @@ pUziAction(PANEL_SPRITEp psp)
char shooting; char shooting;
static SWBOOL alternate = FALSE; static SWBOOL alternate = FALSE;
shooting = TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) && FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT); shooting = (psp->PlayerP->input.actions & SB_FIRE) && (psp->PlayerP->KeyPressBits & SB_FIRE);
if (shooting) if (shooting)
{ {
@ -2803,8 +2800,7 @@ InitWeaponShotgun(PLAYERp pp)
PlaySound(DIGI_SHOTGUN_UP, pp, v3df_follow); PlaySound(DIGI_SHOTGUN_UP, pp, v3df_follow);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
void void
@ -3056,9 +3052,9 @@ pShotgunRest(PANEL_SPRITEp psp)
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -3100,9 +3096,9 @@ pShotgunRestTest(PANEL_SPRITEp psp)
pShotgunBobSetup(psp); pShotgunBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -3315,8 +3311,7 @@ InitWeaponRail(PLAYERp pp)
PlaySound(DIGI_RAILREADY, pp, v3df_follow | v3df_dontpan, CHAN_ITEM); // this one needs to be on a dedicated channel to allow switching it off without too many checks. PlaySound(DIGI_RAILREADY, pp, v3df_follow | v3df_dontpan, CHAN_ITEM); // this one needs to be on a dedicated channel to allow switching it off without too many checks.
Set3DSoundOwner(psp->PlayerP->PlayerSprite); Set3DSoundOwner(psp->PlayerP->PlayerSprite);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
void void
@ -3460,9 +3455,9 @@ pRailRest(PANEL_SPRITEp psp)
pRailBobSetup(psp); pRailBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -3493,9 +3488,9 @@ pRailRestTest(PANEL_SPRITEp psp)
pRailBobSetup(psp); pRailBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -3773,8 +3768,7 @@ InitWeaponHothead(PLAYERp pp)
psp->ang = 768; psp->ang = 768;
psp->vel = 512; psp->vel = 512;
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
pHotHeadOverlays(psp, pp->WpnFlameType); pHotHeadOverlays(psp, pp->WpnFlameType);
psp->over[0].xoff = HOTHEAD_FINGER_XOFF; psp->over[0].xoff = HOTHEAD_FINGER_XOFF;
psp->over[0].yoff = HOTHEAD_FINGER_YOFF; psp->over[0].yoff = HOTHEAD_FINGER_YOFF;
@ -3785,9 +3779,9 @@ InitWeaponHothead(PLAYERp pp)
void void
pHotheadRestTest(PANEL_SPRITEp psp) pHotheadRestTest(PANEL_SPRITEp psp)
{ {
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->KeyPressBits & SB_FIRE)
{ {
//if (!TEST(psp->PlayerP->Flags,PF_DIVING)) //if (!TEST(psp->PlayerP->Flags,PF_DIVING))
{ {
@ -3883,9 +3877,9 @@ pHotheadRest(PANEL_SPRITEp psp)
pHotheadBobSetup(psp); pHotheadBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -3917,7 +3911,7 @@ pHotheadAction(PANEL_SPRITEp psp)
{ {
char shooting; char shooting;
shooting = TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) && FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT); shooting = (psp->PlayerP->input.actions & SB_FIRE) && (psp->PlayerP->KeyPressBits & SB_FIRE);
if (shooting) if (shooting)
{ {
@ -4216,8 +4210,7 @@ InitWeaponMicro(PLAYERp pp)
PlaySound(DIGI_ROCKET_UP, pp, v3df_follow); PlaySound(DIGI_ROCKET_UP, pp, v3df_follow);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
@ -4467,9 +4460,9 @@ pMicroRest(PANEL_SPRITEp psp)
} }
} }
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -4729,8 +4722,7 @@ InitWeaponHeart(PLAYERp pp)
psp->RestState = ps_HeartRest; psp->RestState = ps_HeartRest;
pSetState(psp, psp->PresentState); pSetState(psp, psp->PresentState);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
void void
@ -4798,11 +4790,11 @@ pHeartRest(PANEL_SPRITEp psp)
pHeartBobSetup(psp); pHeartBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits &= ~SB_FIRE;
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
if (!WeaponOK(psp->PlayerP)) if (!WeaponOK(psp->PlayerP))
@ -4814,7 +4806,7 @@ pHeartRest(PANEL_SPRITEp psp)
} }
else else
{ {
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
WeaponOK(psp->PlayerP); WeaponOK(psp->PlayerP);
} }
} }
@ -5232,8 +5224,7 @@ InitWeaponGrenade(PLAYERp pp)
PlaySound(DIGI_GRENADE_UP, pp, v3df_follow); PlaySound(DIGI_GRENADE_UP, pp, v3df_follow);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
void void
@ -5380,9 +5371,9 @@ pGrenadeRest(PANEL_SPRITEp psp)
pGrenadeBobSetup(psp); pGrenadeBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -5530,8 +5521,7 @@ InitWeaponMine(PLAYERp pp)
PlaySound(DIGI_PULL, pp, v3df_follow|v3df_dontpan); PlaySound(DIGI_PULL, pp, v3df_follow|v3df_dontpan);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
void void
@ -5630,9 +5620,9 @@ pMineRest(PANEL_SPRITEp psp)
pMineBobSetup(psp); pMineBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -6197,8 +6187,7 @@ InitWeaponFist(PLAYERp pp)
else if (rnd_num > 700) else if (rnd_num > 700)
PlaySound(DIGI_PLAYERYELL2, pp, v3df_follow|v3df_dontpan); PlaySound(DIGI_PLAYERYELL2, pp, v3df_follow|v3df_dontpan);
FLAG_KEY_RELEASE(psp->PlayerP, SK_SHOOT); psp->PlayerP->KeyPressBits |= SB_FIRE;
FLAG_KEY_RESET(psp->PlayerP, SK_SHOOT);
} }
@ -6298,9 +6287,9 @@ pFistSlideDown(PANEL_SPRITEp psp)
if (psp->y > 440) if (psp->y > 440)
{ {
// if still holding down the fire key - continue swinging // if still holding down the fire key - continue swinging
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->KeyPressBits & SB_FIRE)
{ {
DoPlayerChooseYell(psp->PlayerP); DoPlayerChooseYell(psp->PlayerP);
@ -6417,9 +6406,9 @@ pFistSlideDownR(PANEL_SPRITEp psp)
if (psp->y > 440) if (psp->y > 440)
{ {
// if still holding down the fire key - continue swinging // if still holding down the fire key - continue swinging
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->KeyPressBits & SB_FIRE)
{ {
DoPlayerChooseYell(psp->PlayerP); DoPlayerChooseYell(psp->PlayerP);
@ -6520,11 +6509,11 @@ pFistRest(PANEL_SPRITEp psp)
// Reset move to default // Reset move to default
psp->PlayerP->WpnKungFuMove = 0; psp->PlayerP->WpnKungFuMove = 0;
//if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force || TEST_SYNC_KEY(psp->PlayerP, SK_OPERATE)) //if ((psp->PlayerP->input.actions & SB_FIRE) || force || TEST_SYNC_KEY(psp->PlayerP, SK_OPERATE))
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->input.actions & SB_FIRE) || force)
{ {
//if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force || FLAG_KEY_PRESSED(psp->PlayerP, SK_OPERATE)) //if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force || FLAG_KEY_PRESSED(psp->PlayerP, SK_OPERATE))
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT) || force) if ((psp->PlayerP->KeyPressBits & SB_FIRE) || force)
{ {
RESET(psp->flags, PANF_UNHIDE_SHOOT); RESET(psp->flags, PANF_UNHIDE_SHOOT);
@ -6585,7 +6574,7 @@ pFistBlock(PANEL_SPRITEp psp)
pFistBobSetup(psp); pFistBobSetup(psp);
pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP)); pWeaponBob(psp, PLAYER_MOVING(psp->PlayerP));
if (!TEST_SYNC_KEY(psp->PlayerP, SK_OPERATE)) if (!(psp->PlayerP->input.actions & SB_OPEN))
{ {
pStatePlusOne(psp); pStatePlusOne(psp);
} }
@ -6641,9 +6630,9 @@ pWeaponUnHideKeys(PANEL_SPRITEp psp, PANEL_STATEp state)
psp->PlayerP->KeyPressBits |= SB_HOLSTER; psp->PlayerP->KeyPressBits |= SB_HOLSTER;
} }
if (TEST_SYNC_KEY(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(psp->PlayerP, SK_SHOOT)) if (psp->PlayerP->KeyPressBits & SB_FIRE)
{ {
SET(psp->flags, PANF_UNHIDE_SHOOT); SET(psp->flags, PANF_UNHIDE_SHOOT);
pSetState(psp, state); pSetState(psp, state);

View file

@ -1957,13 +1957,13 @@ DoPlayerHorizon(PLAYERp pp, fix16_t *pq16horiz, fix16_t q16aimvel)
} }
// this is the locked type // this is the locked type
if (TEST_SYNC_KEY(pp, SK_SNAP_UP) || TEST_SYNC_KEY(pp, SK_SNAP_DOWN)) if (TEST_SYNC_KEY(pp, SK_AIM_UP) || TEST_SYNC_KEY(pp, SK_AIM_DOWN))
{ {
// set looking because player is manually looking // set looking because player is manually looking
SET(pp->Flags, PF_LOCK_HORIZ | PF_LOOKING); SET(pp->Flags, PF_LOCK_HORIZ | PF_LOOKING);
// adjust *pq16horiz negative // adjust *pq16horiz negative
if (TEST_SYNC_KEY(pp, SK_SNAP_DOWN)) if (TEST_SYNC_KEY(pp, SK_AIM_DOWN))
{ {
if (PedanticMode) if (PedanticMode)
pp->q16horizbase -= fix16_from_int((HORIZ_SPEED/2)); pp->q16horizbase -= fix16_from_int((HORIZ_SPEED/2));
@ -1972,7 +1972,7 @@ DoPlayerHorizon(PLAYERp pp, fix16_t *pq16horiz, fix16_t q16aimvel)
} }
// adjust *pq16horiz positive // adjust *pq16horiz positive
if (TEST_SYNC_KEY(pp, SK_SNAP_UP)) if (TEST_SYNC_KEY(pp, SK_AIM_UP))
{ {
if (PedanticMode) if (PedanticMode)
pp->q16horizbase += fix16_from_int((HORIZ_SPEED/2)); pp->q16horizbase += fix16_from_int((HORIZ_SPEED/2));
@ -3485,16 +3485,16 @@ DoPlayerJump(PLAYERp pp)
short i; short i;
// reset flag key for double jumps // reset flag key for double jumps
if (!TEST_SYNC_KEY(pp, SK_JUMP)) if (!(pp->input.actions & SB_JUMP))
{ {
FLAG_KEY_RESET(pp, SK_JUMP); pp->KeyPressBits |= SB_JUMP;
} }
// instead of multiplying by synctics, use a loop for greater accuracy // instead of multiplying by synctics, use a loop for greater accuracy
for (i = 0; i < synctics; i++) for (i = 0; i < synctics; i++)
{ {
// PlayerGravity += synctics; // See how increase gravity as we go? // PlayerGravity += synctics; // See how increase gravity as we go?
if (TEST_SYNC_KEY(pp, SK_JUMP)) if (pp->input.actions & SB_JUMP)
{ {
if (pp->JumpDuration > 0) if (pp->JumpDuration > 0)
{ {
@ -3650,9 +3650,9 @@ DoPlayerFall(PLAYERp pp)
int depth; int depth;
// reset flag key for double jumps // reset flag key for double jumps
if (!TEST_SYNC_KEY(pp, SK_JUMP)) if (!(pp->input.actions & SB_JUMP))
{ {
FLAG_KEY_RESET(pp, SK_JUMP); pp->KeyPressBits |= SB_JUMP;
} }
if (pp->cursectnum >= 0 && SectorIsUnderwaterArea(pp->cursectnum)) if (pp->cursectnum >= 0 && SectorIsUnderwaterArea(pp->cursectnum))
@ -3727,7 +3727,7 @@ DoPlayerFall(PLAYERp pp)
StopPlayerSound(pp, DIGI_FALLSCREAM); StopPlayerSound(pp, DIGI_FALLSCREAM);
// i any kind of crawl key get rid of recoil // i any kind of crawl key get rid of recoil
if (DoPlayerTestCrawl(pp) || TEST_SYNC_KEY(pp, SK_CRAWL)) if (DoPlayerTestCrawl(pp) || (pp->input.actions & SB_CROUCH))
{ {
pp->posz = pp->loz - PLAYER_CRAWL_HEIGHT; pp->posz = pp->loz - PLAYER_CRAWL_HEIGHT;
} }
@ -3767,7 +3767,7 @@ DoPlayerFall(PLAYERp pp)
return; return;
} }
if (TEST_SYNC_KEY(pp, SK_CRAWL)) if (pp->input.actions & SB_CROUCH)
{ {
StackedWaterSplash(pp); StackedWaterSplash(pp);
DoPlayerBeginCrawl(pp); DoPlayerBeginCrawl(pp);
@ -3856,7 +3856,7 @@ DoPlayerClimb(PLAYERp pp)
// need to rewrite this for FAF stuff // need to rewrite this for FAF stuff
// Jump off of the ladder // Jump off of the ladder
if (TEST_SYNC_KEY(pp, SK_JUMP)) if (pp->input.actions & SB_JUMP)
{ {
RESET(pp->Flags, PF_CLIMBING|PF_WEAPON_DOWN); RESET(pp->Flags, PF_CLIMBING|PF_WEAPON_DOWN);
RESET(sp->cstat, CSTAT_SPRITE_YCENTER); RESET(sp->cstat, CSTAT_SPRITE_YCENTER);
@ -4188,7 +4188,7 @@ DoPlayerCrawl(PLAYERp pp)
} }
// Jump to get up // Jump to get up
if (TEST_SYNC_KEY(pp, SK_JUMP)) if (pp->input.actions & SB_JUMP)
{ {
if (labs(pp->loz - pp->hiz) >= PLAYER_STANDING_ROOM) if (labs(pp->loz - pp->hiz) >= PLAYER_STANDING_ROOM)
{ {
@ -4204,7 +4204,7 @@ DoPlayerCrawl(PLAYERp pp)
else else
{ {
// Let off of crawl to get up // Let off of crawl to get up
if (!TEST_SYNC_KEY(pp, SK_CRAWL)) if (!(pp->input.actions & SB_CROUCH))
{ {
if (labs(pp->loz - pp->hiz) >= PLAYER_STANDING_ROOM) if (labs(pp->loz - pp->hiz) >= PLAYER_STANDING_ROOM)
{ {
@ -4331,7 +4331,7 @@ DoPlayerFly(PLAYERp pp)
return; return;
} }
if (TEST_SYNC_KEY(pp, SK_CRAWL)) if (pp->input.actions & SB_CROUCH)
{ {
pp->z_speed += PLAYER_FLY_INC; pp->z_speed += PLAYER_FLY_INC;
@ -4339,7 +4339,7 @@ DoPlayerFly(PLAYERp pp)
pp->z_speed = PLAYER_FLY_MAX_SPEED; pp->z_speed = PLAYER_FLY_MAX_SPEED;
} }
if (TEST_SYNC_KEY(pp, SK_JUMP)) if (pp->input.actions & SB_JUMP)
{ {
pp->z_speed -= PLAYER_FLY_INC; pp->z_speed -= PLAYER_FLY_INC;
@ -4550,7 +4550,7 @@ PlayerCanDive(PLAYERp pp)
return FALSE; return FALSE;
// Crawl - check for diving // Crawl - check for diving
if (TEST_SYNC_KEY(pp, SK_CRAWL) || pp->jump_speed > 0) if ((pp->input.actions & SB_CROUCH) || pp->jump_speed > 0)
{ {
if (PlayerInDiveArea(pp)) if (PlayerInDiveArea(pp))
{ {
@ -5183,7 +5183,7 @@ DoPlayerDive(PLAYERp pp)
} }
} }
if (TEST_SYNC_KEY(pp, SK_CRAWL)) if (pp->input.actions & SB_CROUCH)
{ {
pp->z_speed += PLAYER_DIVE_INC; pp->z_speed += PLAYER_DIVE_INC;
@ -5191,7 +5191,7 @@ DoPlayerDive(PLAYERp pp)
pp->z_speed = PLAYER_DIVE_MAX_SPEED; pp->z_speed = PLAYER_DIVE_MAX_SPEED;
} }
if (TEST_SYNC_KEY(pp, SK_JUMP)) if (pp->input.actions & SB_JUMP)
{ {
pp->z_speed -= PLAYER_DIVE_INC; pp->z_speed -= PLAYER_DIVE_INC;
@ -5456,13 +5456,13 @@ DoPlayerWade(PLAYERp pp)
if (DebugOperate) if (DebugOperate)
{ {
if (TEST_SYNC_KEY(pp, SK_OPERATE)) if (pp->input.actions & SB_OPEN)
{ {
if (FLAG_KEY_PRESSED(pp, SK_OPERATE)) if (pp->KeyPressBits & SB_OPEN)
{ {
if (TEST(sector[pp->cursectnum].extra, SECTFX_OPERATIONAL)) if (TEST(sector[pp->cursectnum].extra, SECTFX_OPERATIONAL))
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
DoPlayerBeginOperate(pp); DoPlayerBeginOperate(pp);
pp->bob_amt = 0; pp->bob_amt = 0;
pp->bob_ndx = 0; pp->bob_ndx = 0;
@ -5472,7 +5472,7 @@ DoPlayerWade(PLAYERp pp)
} }
else else
{ {
FLAG_KEY_RESET(pp, SK_OPERATE); pp->KeyPressBits |= SB_OPEN;
} }
} }
@ -5484,17 +5484,17 @@ DoPlayerWade(PLAYERp pp)
} }
// Crawl Commanded // Crawl Commanded
if (TEST_SYNC_KEY(pp, SK_CRAWL) && pp->WadeDepth <= PLAYER_CRAWL_WADE_DEPTH) if ((pp->input.actions & SB_CROUCH) && pp->WadeDepth <= PLAYER_CRAWL_WADE_DEPTH)
{ {
DoPlayerBeginCrawl(pp); DoPlayerBeginCrawl(pp);
return; return;
} }
if (TEST_SYNC_KEY(pp, SK_JUMP)) if (pp->input.actions & SB_JUMP)
{ {
if (FLAG_KEY_PRESSED(pp, SK_JUMP)) if (pp->KeyPressBits & SB_JUMP)
{ {
FLAG_KEY_RELEASE(pp, SK_JUMP); pp->KeyPressBits &= ~SB_JUMP;
//DoPlayerHeight(pp); //DoPlayerHeight(pp);
//DoPlayerHeight(pp); //DoPlayerHeight(pp);
//DoPlayerHeight(pp); //DoPlayerHeight(pp);
@ -5507,7 +5507,7 @@ DoPlayerWade(PLAYERp pp)
} }
else else
{ {
FLAG_KEY_RESET(pp, SK_JUMP); pp->KeyPressBits |= SB_JUMP;
} }
if (PlayerFlyKey()) if (PlayerFlyKey())
@ -5980,18 +5980,18 @@ DoPlayerOperateTurret(PLAYERp pp)
{ {
short save_sectnum; short save_sectnum;
if (TEST_SYNC_KEY(pp, SK_OPERATE)) if (pp->input.actions & SB_OPEN)
{ {
if (FLAG_KEY_PRESSED(pp, SK_OPERATE)) if (pp->KeyPressBits & SB_OPEN)
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
DoPlayerStopOperate(pp); DoPlayerStopOperate(pp);
return; return;
} }
} }
else else
{ {
FLAG_KEY_RESET(pp, SK_OPERATE); pp->KeyPressBits |= SB_OPEN;
} }
if (pp->sop->max_damage != -9999 && pp->sop->max_damage <= 0) if (pp->sop->max_damage != -9999 && pp->sop->max_damage <= 0)
@ -6020,18 +6020,18 @@ DoPlayerOperateBoat(PLAYERp pp)
{ {
short save_sectnum; short save_sectnum;
if (TEST_SYNC_KEY(pp, SK_OPERATE)) if (pp->input.actions & SB_OPEN)
{ {
if (FLAG_KEY_PRESSED(pp, SK_OPERATE)) if (pp->KeyPressBits & SB_OPEN)
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
DoPlayerStopOperate(pp); DoPlayerStopOperate(pp);
return; return;
} }
} }
else else
{ {
FLAG_KEY_RESET(pp, SK_OPERATE); pp->KeyPressBits |= SB_OPEN;
} }
if (pp->sop->max_damage != -9999 && pp->sop->max_damage <= 0) if (pp->sop->max_damage != -9999 && pp->sop->max_damage <= 0)
@ -6060,18 +6060,18 @@ DoPlayerOperateTank(PLAYERp pp)
short save_sectnum; short save_sectnum;
//ASSERT(!TEST_SYNC_KEY(pp, SK_OPERATE)); //ASSERT(!TEST_SYNC_KEY(pp, SK_OPERATE));
if (TEST_SYNC_KEY(pp, SK_OPERATE)) if (pp->input.actions & SB_OPEN)
{ {
if (FLAG_KEY_PRESSED(pp, SK_OPERATE)) if (pp->KeyPressBits & SB_OPEN)
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
DoPlayerStopOperate(pp); DoPlayerStopOperate(pp);
return; return;
} }
} }
else else
{ {
FLAG_KEY_RESET(pp, SK_OPERATE); pp->KeyPressBits |= SB_OPEN;
} }
if (pp->sop->max_damage != -9999 && pp->sop->max_damage <= 0) if (pp->sop->max_damage != -9999 && pp->sop->max_damage <= 0)
@ -6574,9 +6574,9 @@ void DoPlayerDeathHurl(PLAYERp pp)
{ {
if (numplayers > 1) if (numplayers > 1)
{ {
if (TEST_SYNC_KEY(pp, SK_SHOOT)) if (pp->input.actions & SB_FIRE)
{ {
if (FLAG_KEY_PRESSED(pp, SK_SHOOT)) if (pp->KeyPressBits & SB_FIRE)
{ {
@ -6637,7 +6637,7 @@ void DoPlayerDeathCheckKeys(PLAYERp pp)
SPRITEp sp = pp->SpriteP; SPRITEp sp = pp->SpriteP;
USERp u = User[pp->PlayerSprite]; USERp u = User[pp->PlayerSprite];
//if (TEST_SYNC_KEY(pp, SK_OPERATE)) //if (pp->input.actions & SB_OPEN)
if (TEST_SYNC_KEY(pp, SK_SPACE_BAR)) if (TEST_SYNC_KEY(pp, SK_SPACE_BAR))
{ {
// Spawn a dead LoWang body for non-head deaths // Spawn a dead LoWang body for non-head deaths
@ -7139,18 +7139,18 @@ DoPlayerRun(PLAYERp pp)
} }
// Crawl Commanded // Crawl Commanded
if (TEST_SYNC_KEY(pp, SK_CRAWL)) if (pp->input.actions & SB_CROUCH)
{ {
DoPlayerBeginCrawl(pp); DoPlayerBeginCrawl(pp);
return; return;
} }
// Jump // Jump
if (TEST_SYNC_KEY(pp, SK_JUMP)) if (pp->input.actions & SB_JUMP)
{ {
if (FLAG_KEY_PRESSED(pp, SK_JUMP)) if (pp->KeyPressBits & SB_JUMP)
{ {
FLAG_KEY_RELEASE(pp, SK_JUMP); pp->KeyPressBits &= ~SB_JUMP;
// make sure you stand at full heights for jumps/double jumps // make sure you stand at full heights for jumps/double jumps
//DoPlayerHeight(pp); //DoPlayerHeight(pp);
//DoPlayerHeight(pp); //DoPlayerHeight(pp);
@ -7164,7 +7164,7 @@ DoPlayerRun(PLAYERp pp)
} }
else else
{ {
FLAG_KEY_RESET(pp, SK_JUMP); pp->KeyPressBits |= SB_JUMP;
} }
// Crawl lock // Crawl lock
@ -7193,13 +7193,13 @@ DoPlayerRun(PLAYERp pp)
{ {
if (!TEST(pp->Flags, PF_DEAD) && !Prediction) if (!TEST(pp->Flags, PF_DEAD) && !Prediction)
{ {
if (TEST_SYNC_KEY(pp, SK_OPERATE)) if (pp->input.actions & SB_OPEN)
{ {
if (FLAG_KEY_PRESSED(pp, SK_OPERATE) && pp->cursectnum >= 0) if ((pp->KeyPressBits & SB_OPEN) && pp->cursectnum >= 0)
{ {
if (TEST(sector[pp->cursectnum].extra, SECTFX_OPERATIONAL)) if (TEST(sector[pp->cursectnum].extra, SECTFX_OPERATIONAL))
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
DoPlayerBeginOperate(pp); DoPlayerBeginOperate(pp);
return; return;
} }
@ -7211,7 +7211,7 @@ DoPlayerRun(PLAYERp pp)
if (sp && SP_TAG5(sp) == TRIGGER_TYPE_REMOTE_SO) if (sp && SP_TAG5(sp) == TRIGGER_TYPE_REMOTE_SO)
{ {
pp->remote_sprite = sp; pp->remote_sprite = sp;
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
ASSERT(pp->remote_sprite); ASSERT(pp->remote_sprite);
DoPlayerBeginRemoteOperate(pp, &SectorObject[SP_TAG7(pp->remote_sprite)]); DoPlayerBeginRemoteOperate(pp, &SectorObject[SP_TAG7(pp->remote_sprite)]);
return; return;
@ -7221,7 +7221,7 @@ DoPlayerRun(PLAYERp pp)
} }
else else
{ {
FLAG_KEY_RESET(pp, SK_OPERATE); pp->KeyPressBits |= SB_OPEN;
} }
} }
} }

View file

@ -83,15 +83,13 @@ DoPrediction(PLAYERp ppp)
// get rid of input bits so it doesn't go into other code branches that would // get rid of input bits so it doesn't go into other code branches that would
// get it out of sync // get it out of sync
ppp->input.actions &= ~(SB_WEAPONMASK_BITS|SB_ITEMUSE_BITS|SB_HOLSTER|SB_CENTERVIEW); ppp->input.actions &= ~(SB_WEAPONMASK_BITS|SB_ITEMUSE_BITS|SB_INVNEXT|SB_INVPREV|SB_INVUSE|SB_HOLSTER|SB_CENTERVIEW|SB_FIRE|SB_OPEN);;
ppp->KeyPressBits |= (SB_WEAPONMASK_BITS|SB_ITEMUSE_BITS|SB_INVNEXT|SB_INVPREV|SB_INVUSE|SB_HOLSTER|SB_CENTERVIEW); ppp->KeyPressBits |= (SB_WEAPONMASK_BITS|SB_ITEMUSE_BITS|SB_INVNEXT|SB_INVPREV|SB_INVUSE|SB_HOLSTER|SB_CENTERVIEW|SB_FIRE|SB_OPEN);
RESET(ppp->input.bits, RESET(ppp->input.bits,
BIT(SK_SHOOT)|BIT(SK_OPERATE)|
BIT(SK_AUTO_AIM) BIT(SK_AUTO_AIM)
); );
SET(ppp->KeyPressFlags, SET(ppp->KeyPressFlags,
BIT(SK_SHOOT)|BIT(SK_OPERATE)|
BIT(SK_AUTO_AIM) BIT(SK_AUTO_AIM)
); );

View file

@ -2585,9 +2585,9 @@ PlayerOperateEnv(PLAYERp pp)
// Switch & door activations // Switch & door activations
// //
if (TEST_SYNC_KEY(pp, SK_OPERATE)) if (pp->input.actions & SB_OPEN)
{ {
if (FLAG_KEY_PRESSED(pp, SK_OPERATE)) if (pp->KeyPressBits & SB_OPEN)
{ {
// if space bar pressed // if space bar pressed
short nt_ndx; short nt_ndx;
@ -2595,7 +2595,7 @@ PlayerOperateEnv(PLAYERp pp)
if (DoPlayerGrabStar(pp)) if (DoPlayerGrabStar(pp))
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
} }
else else
{ {
@ -2613,7 +2613,7 @@ PlayerOperateEnv(PLAYERp pp)
{ {
if (OperateSprite(nti[nt_ndx].spritenum, TRUE)) if (OperateSprite(nti[nt_ndx].spritenum, TRUE))
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
found = TRUE; found = TRUE;
} }
} }
@ -2642,7 +2642,7 @@ PlayerOperateEnv(PLAYERp pp)
{ {
if (OperateSprite(nti[nt_ndx].spritenum, TRUE)) if (OperateSprite(nti[nt_ndx].spritenum, TRUE))
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
break; break;
} }
} }
@ -2663,7 +2663,7 @@ PlayerOperateEnv(PLAYERp pp)
if (OperateSector(neartagsector, TRUE)) if (OperateSector(neartagsector, TRUE))
{ {
// Release the key // Release the key
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
} }
} }
@ -2671,7 +2671,7 @@ PlayerOperateEnv(PLAYERp pp)
{ {
if (OperateWall(neartagwall, TRUE)) if (OperateWall(neartagwall, TRUE))
{ {
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
} }
} }
} }
@ -2690,11 +2690,11 @@ PlayerOperateEnv(PLAYERp pp)
break; break;
case TAG_SPRING_BOARD: case TAG_SPRING_BOARD:
DoSpringBoard(pp/*, pp->cursectnum*/); DoSpringBoard(pp/*, pp->cursectnum*/);
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
break; break;
case TAG_DOOR_ROTATE: case TAG_DOOR_ROTATE:
if (OperateSector(pp->cursectnum, TRUE)) if (OperateSector(pp->cursectnum, TRUE))
FLAG_KEY_RELEASE(pp, SK_OPERATE); pp->KeyPressBits &= ~SB_OPEN;
break; break;
} }
} }
@ -2702,7 +2702,7 @@ PlayerOperateEnv(PLAYERp pp)
else else
{ {
// Reset the key when syncbit key is not in use // Reset the key when syncbit key is not in use
FLAG_KEY_RESET(pp, SK_OPERATE); pp->KeyPressBits |= SB_OPEN;
} }
// //////////////////////////// // ////////////////////////////