- consolidation of inventory item activation through hotkeys.

This also adds hotkeys for Exhumed which never implemented them.
This commit is contained in:
Christoph Oelckers 2020-08-27 21:25:09 +02:00
parent 10df3e094a
commit 43de0d8312
34 changed files with 288 additions and 254 deletions

View file

@ -347,14 +347,10 @@ void ctrlGetInput(void)
void registerinputcommands() void registerinputcommands()
{ {
C_RegisterFunction("pause", nullptr, [](CCmdFuncPtr)->int { BitsToSend.pause = 1; sendPause = true; return CCMD_OK; }); C_RegisterFunction("pause", nullptr, [](CCmdFuncPtr)->int { BitsToSend.pause = 1; sendPause = true; return CCMD_OK; });
C_RegisterFunction("jumpboots", nullptr, [](CCmdFuncPtr)->int { BitsToSend.useJumpBoots = 1; return CCMD_OK; });
C_RegisterFunction("medkit", nullptr, [](CCmdFuncPtr)->int { BitsToSend.useMedKit = 1; return CCMD_OK; });
C_RegisterFunction("centerview", nullptr, [](CCmdFuncPtr)->int { BitsToSend.lookCenter = 1; return CCMD_OK; }); 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("holsterweapon", nullptr, [](CCmdFuncPtr)->int { BitsToSend.holsterWeapon = 1; return CCMD_OK; });
C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { BitsToSend.prevItem = 1; return CCMD_OK; }); C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { BitsToSend.prevItem = 1; return CCMD_OK; });
C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { BitsToSend.nextItem = 1; return CCMD_OK; }); C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { BitsToSend.nextItem = 1; return CCMD_OK; });
C_RegisterFunction("crystalball", nullptr, [](CCmdFuncPtr)->int { BitsToSend.useCrystalBall = 1; return CCMD_OK; });
C_RegisterFunction("beastvision", nullptr, [](CCmdFuncPtr)->int { BitsToSend.useBeastVision = 1; return CCMD_OK; });
C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend.spin180 = 1; return CCMD_OK; }); C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend.spin180 = 1; return CCMD_OK; });
C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend.useItem = 1; return CCMD_OK; }); C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend.useItem = 1; return CCMD_OK; });
} }

View file

@ -1295,6 +1295,14 @@ int ActionScan(PLAYER *pPlayer, int *a2, int *a3)
void ProcessInput(PLAYER *pPlayer) void ProcessInput(PLAYER *pPlayer)
{ {
enum
{
Item_MedKit = 0,
Item_CrystalBall = 1,
Item_BeastVision = 2,
Item_JumpBoots = 3
};
spritetype *pSprite = pPlayer->pSprite; spritetype *pSprite = pPlayer->pSprite;
XSPRITE *pXSprite = pPlayer->pXSprite; XSPRITE *pXSprite = pPlayer->pXSprite;
int nSprite = pPlayer->nSprite; int nSprite = pPlayer->nSprite;
@ -1643,27 +1651,27 @@ void ProcessInput(PLAYER *pPlayer)
if (pPlayer->packSlots[pPlayer->packItemId].curAmount > 0) if (pPlayer->packSlots[pPlayer->packItemId].curAmount > 0)
packUseItem(pPlayer, pPlayer->packItemId); packUseItem(pPlayer, pPlayer->packItemId);
} }
if (pInput->syncFlags.useBeastVision) if (pInput->isItemUsed(Item_BeastVision))
{ {
pInput->syncFlags.useBeastVision = 0; pInput->clearItemUsed(Item_BeastVision);
if (pPlayer->packSlots[3].curAmount > 0) if (pPlayer->packSlots[3].curAmount > 0)
packUseItem(pPlayer, 3); packUseItem(pPlayer, 3);
} }
if (pInput->syncFlags.useCrystalBall) if (pInput->isItemUsed(Item_CrystalBall))
{ {
pInput->syncFlags.useCrystalBall = 0; pInput->clearItemUsed(Item_CrystalBall);
if (pPlayer->packSlots[2].curAmount > 0) if (pPlayer->packSlots[2].curAmount > 0)
packUseItem(pPlayer, 2); packUseItem(pPlayer, 2);
} }
if (pInput->syncFlags.useJumpBoots) if (pInput->isItemUsed(Item_JumpBoots))
{ {
pInput->syncFlags.useJumpBoots = 0; pInput->clearItemUsed(Item_JumpBoots);
if (pPlayer->packSlots[4].curAmount > 0) if (pPlayer->packSlots[4].curAmount > 0)
packUseItem(pPlayer, 4); packUseItem(pPlayer, 4);
} }
if (pInput->syncFlags.useMedKit) if (pInput->isItemUsed(Item_MedKit))
{ {
pInput->syncFlags.useMedKit = 0; pInput->clearItemUsed(Item_MedKit);
if (pPlayer->packSlots[0].curAmount > 0) if (pPlayer->packSlots[0].curAmount > 0)
packUseItem(pPlayer, 0); packUseItem(pPlayer, 0);
} }

View file

@ -42,7 +42,7 @@
#include "gamecontrol.h" #include "gamecontrol.h"
static int WeaponToSend = 0; static int WeaponToSend = 0;
ESyncBits ActionsToSend = 0;
//========================================================================== //==========================================================================
// //
// //
@ -259,6 +259,24 @@ CCMD(weapalt)
WeaponToSend = WeaponSel_Alt; // Only used by SW - should also be made usable by Blood ans Duke which put multiple weapons in the same slot. WeaponToSend = WeaponSel_Alt; // Only used by SW - should also be made usable by Blood ans Duke which put multiple weapons in the same slot.
} }
CCMD(useitem)
{
int max = (g_gameType & GAMEFLAG_PSEXHUMED)? 6 : (g_gameType & GAMEFLAG_SW)? 7 : (g_gameType & GAMEFLAG_BLOOD) ? 4 : 5;
if (argv.argc() != 2)
{
Printf("useitem <itemnum>: activates an inventory item (1-%d)", max);
}
auto slot = atoi(argv[1]);
if (slot >= 1 && slot <= max)
{
ActionsToSend |= ESyncBits::FromInt(SB_ITEM_BIT_1 << (slot - 1));
}
}
void ApplyGlobalInput(InputPacket& input, ControlInfo *info) void ApplyGlobalInput(InputPacket& input, ControlInfo *info)
{ {
if (WeaponToSend != 0) input.setNewWeapon(WeaponToSend); if (WeaponToSend != 0) input.setNewWeapon(WeaponToSend);
@ -275,5 +293,7 @@ void ApplyGlobalInput(InputPacket& input, ControlInfo *info)
info->dz = 0; info->dz = 0;
info->dyaw = 0; info->dyaw = 0;
} }
input.actions |= ActionsToSend;
ActionsToSend = 0;
} }

View file

@ -100,4 +100,4 @@ enum GameFunction_t
void SetupGameButtons(); void SetupGameButtons();
void ApplyGlobalInput(InputPacket& input, ControlInfo *info); void ApplyGlobalInput(InputPacket& input, ControlInfo *info);
extern ESyncBits ActionsToSend;

View file

@ -6,13 +6,24 @@
enum ESyncBits_ : uint32_t enum ESyncBits_ : uint32_t
{ {
SB_FIRST_WEAPON_BIT = 1 << 0, SB_FIRST_WEAPON_BIT = 1 << 0,
SB_ITEM_BIT_1 = 1 << 4,
SB_ITEM_BIT_2 = 1 << 5,
SB_ITEM_BIT_3 = 1 << 6,
SB_ITEM_BIT_4 = 1 << 7,
SB_ITEM_BIT_5 = 1 << 8,
SB_ITEM_BIT_6 = 1 << 9,
SB_ITEM_BIT_7 = 1 << 10,
// Exhumed has 6 items but doesn't use the network packet to activate them. Need to change
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_BUTTON_MASK = 0, // all input from buttons (i.e. active while held) SB_BUTTON_MASK = 0, // all input from buttons (i.e. active while held)
SB_INTERFACE_MASK = 0, // all input from CCMDs SB_INTERFACE_MASK = 0, // all input from CCMDs
SB_INTERFACE_BITS = (SB_WEAPONMASK_BITS | SB_INTERFACE_MASK) SB_INTERFACE_BITS = (SB_WEAPONMASK_BITS | SB_ITEMUSE_BITS | SB_INTERFACE_MASK)
}; };
// enforce type safe operations on the input bits. // enforce type safe operations on the input bits.
@ -52,11 +63,8 @@ enum EDukeSyncBits_ : uint32_t
SKB_RUN = 1 << 5, SKB_RUN = 1 << 5,
SKB_LOOK_LEFT = 1 << 6, SKB_LOOK_LEFT = 1 << 6,
SKB_LOOK_RIGHT = 1 << 7, SKB_LOOK_RIGHT = 1 << 7,
SKB_STEROIDS = 1 << 12,
SKB_LOOK_UP = 1 << 13, SKB_LOOK_UP = 1 << 13,
SKB_LOOK_DOWN = 1 << 14, SKB_LOOK_DOWN = 1 << 14,
SKB_NIGHTVISION = 1 << 15,
SKB_MEDKIT = 1 << 16,
SKB_MULTIFLAG = 1 << 17, SKB_MULTIFLAG = 1 << 17,
SKB_CENTER_VIEW = 1 << 18, SKB_CENTER_VIEW = 1 << 18,
SKB_HOLSTER = 1 << 19, SKB_HOLSTER = 1 << 19,
@ -64,8 +72,6 @@ enum EDukeSyncBits_ : uint32_t
SKB_PAUSE = 1 << 21, SKB_PAUSE = 1 << 21,
SKB_QUICK_KICK = 1 << 22, SKB_QUICK_KICK = 1 << 22,
SKB_AIMMODE = 1 << 23, SKB_AIMMODE = 1 << 23,
SKB_HOLODUKE = 1 << 24,
SKB_JETPACK = 1 << 25,
SKB_GAMEQUIT = 1 << 26, SKB_GAMEQUIT = 1 << 26,
SKB_INV_RIGHT = 1 << 27, SKB_INV_RIGHT = 1 << 27,
SKB_TURNAROUND = 1 << 28, SKB_TURNAROUND = 1 << 28,
@ -73,8 +79,8 @@ enum EDukeSyncBits_ : uint32_t
SKB_INVENTORY = 1 << 30, SKB_INVENTORY = 1 << 30,
SKB_ESCAPE = 1u << 31, SKB_ESCAPE = 1u << 31,
SKB_INTERFACE_BITS = (SKB_STEROIDS | SKB_NIGHTVISION | SKB_MEDKIT | SKB_QUICK_KICK | \ SKB_INTERFACE_BITS = (SKB_QUICK_KICK | \
SKB_HOLSTER | SKB_INV_LEFT | SKB_PAUSE | SKB_HOLODUKE | SKB_JETPACK | SKB_INV_RIGHT | \ SKB_HOLSTER | SKB_INV_LEFT | SKB_PAUSE | SKB_INV_RIGHT | \
SKB_TURNAROUND | SKB_OPEN | SKB_INVENTORY | SKB_ESCAPE), SKB_TURNAROUND | SKB_OPEN | SKB_INVENTORY | SKB_ESCAPE),
SKB_NONE = 0, SKB_NONE = 0,
@ -111,10 +117,6 @@ union SYNCFLAGS
unsigned int pause : 1; unsigned int pause : 1;
unsigned int quit : 1; unsigned int quit : 1;
unsigned int restart : 1; unsigned int restart : 1;
unsigned int useBeastVision : 1;
unsigned int useCrystalBall : 1;
unsigned int useJumpBoots : 1;
unsigned int useMedKit : 1;
}; };
}; };
@ -124,10 +126,6 @@ union SYNCFLAGS
// NETWORK - REDEFINABLE SHARED (SYNC) KEYS BIT POSITIONS // NETWORK - REDEFINABLE SHARED (SYNC) KEYS BIT POSITIONS
// //
#define SK_INV_HOTKEY_BIT0 4
#define SK_INV_HOTKEY_BIT1 5
#define SK_INV_HOTKEY_BIT2 6
#define SK_INV_HOTKEY_MASK (BIT(SK_INV_HOTKEY_BIT0)|BIT(SK_INV_HOTKEY_BIT1)|BIT(SK_INV_HOTKEY_BIT2))
#define SK_AUTO_AIM 7 #define SK_AUTO_AIM 7
#define SK_CENTER_VIEW 8 #define SK_CENTER_VIEW 8
@ -148,8 +146,6 @@ union SYNCFLAGS
#define SK_SNAP_DOWN 22 #define SK_SNAP_DOWN 22
#define SK_QUIT_GAME 23 #define SK_QUIT_GAME 23
#define SK_MULTI_VIEW 24
#define SK_TURN_180 25 #define SK_TURN_180 25
#define SK_INV_LEFT 26 #define SK_INV_LEFT 26
@ -210,6 +206,22 @@ struct InputPacket
{ {
actions = (actions & ~SB_WEAPONMASK_BITS) | (ESyncBits::FromInt(weap) & SB_WEAPONMASK_BITS); actions = (actions & ~SB_WEAPONMASK_BITS) | (ESyncBits::FromInt(weap) & SB_WEAPONMASK_BITS);
} }
bool isItemUsed(int num)
{
return !!(actions & ESyncBits::FromInt(SB_ITEM_BIT_1 << num));
}
void setItemUsed(int num)
{
actions |= ESyncBits::FromInt(SB_ITEM_BIT_1 << num);
}
void clearItemUsed(int num)
{
actions &= ~ESyncBits::FromInt(SB_ITEM_BIT_1 << num);
}
}; };

View file

@ -528,6 +528,25 @@ void GameTicker()
weap2 = SelectAltWeapon(weap2); weap2 = SelectAltWeapon(weap2);
} }
for (int i = 0; i < 6; i++)
{
if (localInput.isItemUsed(i))
{
localInput.clearItemUsed(i);
if (PlayerList[nLocalPlayer].items[i] > 0)
{
if (nItemMagic[i] <= PlayerList[nLocalPlayer].nMagic)
{
sPlayerInput[nLocalPlayer].nItem = i;
break;
}
}
}
}
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.

View file

@ -388,7 +388,7 @@ void registerinputcommands()
C_RegisterFunction("centerview", nullptr, ccmd_centerview); C_RegisterFunction("centerview", nullptr, ccmd_centerview);
C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { if (PlayerList[nLocalPlayer].nHealth > 0) SetPrevItem(nLocalPlayer); return CCMD_OK; }); C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { if (PlayerList[nLocalPlayer].nHealth > 0) SetPrevItem(nLocalPlayer); return CCMD_OK; });
C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { if (PlayerList[nLocalPlayer].nHealth > 0) SetNextItem(nLocalPlayer); return CCMD_OK; }); C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { if (PlayerList[nLocalPlayer].nHealth > 0) SetNextItem(nLocalPlayer); return CCMD_OK; });
C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { if (PlayerList[nLocalPlayer].nHealth > 0) UseCurItem(nLocalPlayer); return CCMD_OK; }); //C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { if (PlayerList[nLocalPlayer].nHealth > 0) UseCurItem(nLocalPlayer); return CCMD_OK; });
// These are only here to silence the engine when the keys bound to them are pressed. The functions do not exist. // These are only here to silence the engine when the keys bound to them are pressed. The functions do not exist.
C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { return CCMD_OK; }); C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { return CCMD_OK; });

View file

@ -316,22 +316,6 @@ void UseItem(short nPlayer, short nItem)
} }
} }
void UseCurItem(short nPlayer)
{
int nItem = nPlayerItem[nPlayer];
if (nItem >= 0)
{
if (PlayerList[nPlayer].items[nItem] > 0)
{
if (nItemMagic[nItem] <= PlayerList[nPlayer].nMagic)
{
sPlayerInput[nPlayer].nItem = nItem;
}
}
}
}
// TODO - bool return type? // TODO - bool return type?
int GrabItem(short nPlayer, short nItem) int GrabItem(short nPlayer, short nItem)
{ {

View file

@ -146,6 +146,16 @@ inline int PlayerNewWeapon(int pl)
return sync[pl].getNewWeapon(); return sync[pl].getNewWeapon();
} }
inline void PlayerSetItemUsed(int pl, int num)
{
sync[pl].setItemUsed(num - 1);
}
inline bool PlayerUseItem(int pl, int num)
{
return sync[pl].isItemUsed(num - 1);
}
inline int PlayerInputSideVel(int pl) inline int PlayerInputSideVel(int pl)
{ {
return sync[pl].svel; return sync[pl].svel;

View file

@ -210,19 +210,11 @@ void hud_input(int snum)
OnEvent(EVENT_INVENTORY, -1, snum, -1); OnEvent(EVENT_INVENTORY, -1, snum, -1);
if (GetGameVarID(g_iReturnVarID, -1, snum) == 0) if (GetGameVarID(g_iReturnVarID, -1, snum) == 0)
{ {
switch (p->inven_icon) if (p->inven_icon > ICON_NONE && p->inven_icon <= ICON_HEATS) PlayerSetItemUsed(snum, p->inven_icon);
{
// Yet another place where no symbolic constants were used. :(
case ICON_JETPACK: PlayerSetInput(snum, SKB_JETPACK); break;
case ICON_HOLODUKE: PlayerSetInput(snum, SKB_HOLODUKE); break;
case ICON_HEATS: PlayerSetInput(snum, SKB_NIGHTVISION); break;
case ICON_FIRSTAID: PlayerSetInput(snum, SKB_MEDKIT); break;
case ICON_STEROIDS: PlayerSetInput(snum, SKB_STEROIDS); break;
}
} }
} }
if (!isRR() && PlayerInput(snum, SKB_NIGHTVISION)) if (!isRR() && PlayerUseItem(snum, ICON_HEATS))
{ {
SetGameVarID(g_iReturnVarID, 0, -1, snum); SetGameVarID(g_iReturnVarID, 0, -1, snum);
OnEvent(EVENT_USENIGHTVISION, -1, snum, -1); OnEvent(EVENT_USENIGHTVISION, -1, snum, -1);
@ -236,7 +228,7 @@ void hud_input(int snum)
} }
} }
if (PlayerInput(snum, SKB_STEROIDS)) if (PlayerUseItem(snum, ICON_STEROIDS))
{ {
SetGameVarID(g_iReturnVarID, 0, -1, snum); SetGameVarID(g_iReturnVarID, 0, -1, snum);
OnEvent(EVENT_USESTEROIDS, -1, snum, -1); OnEvent(EVENT_USESTEROIDS, -1, snum, -1);
@ -363,7 +355,7 @@ void hud_input(int snum)
} }
} }
if (PlayerInput(snum, SKB_HOLODUKE) && (isRR() || p->newowner == -1)) if (PlayerUseItem(snum, ICON_HOLODUKE) && (isRR() || p->newowner == -1))
{ {
SetGameVarID(g_iReturnVarID, 0, -1, snum); SetGameVarID(g_iReturnVarID, 0, -1, snum);
OnEvent(EVENT_HOLODUKEON, -1, snum, -1); OnEvent(EVENT_HOLODUKEON, -1, snum, -1);
@ -419,7 +411,7 @@ void hud_input(int snum)
} }
} }
if (isRR() && PlayerInput(snum, SKB_NIGHTVISION) && p->newowner == -1) if (isRR() && PlayerUseItem(snum, ICON_HEATS) && p->newowner == -1)
{ {
SetGameVarID(g_iReturnVarID, 0, -1, snum); SetGameVarID(g_iReturnVarID, 0, -1, snum);
OnEvent(EVENT_USENIGHTVISION, -1, snum, -1); OnEvent(EVENT_USENIGHTVISION, -1, snum, -1);
@ -451,7 +443,7 @@ void hud_input(int snum)
} }
} }
if (PlayerInput(snum, SKB_MEDKIT)) if (PlayerUseItem(snum, ICON_FIRSTAID))
{ {
SetGameVarID(g_iReturnVarID, 0, -1, snum); SetGameVarID(g_iReturnVarID, 0, -1, snum);
OnEvent(EVENT_USEMEDKIT, -1, snum, -1); OnEvent(EVENT_USEMEDKIT, -1, snum, -1);
@ -504,7 +496,7 @@ void hud_input(int snum)
} }
} }
if (PlayerInput(snum, SKB_JETPACK) && (isRR() || p->newowner == -1)) if (PlayerUseItem(snum, ICON_JETPACK) && (isRR() || p->newowner == -1))
{ {
SetGameVarID(g_iReturnVarID, 0, -1, snum); SetGameVarID(g_iReturnVarID, 0, -1, snum);
OnEvent(EVENT_USEJETPACK, -1, snum, -1); OnEvent(EVENT_USEJETPACK, -1, snum, -1);
@ -1169,15 +1161,10 @@ void GetInput()
void registerinputcommands() void registerinputcommands()
{ {
C_RegisterFunction("pause", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_PAUSE; sendPause = true; return CCMD_OK; }); C_RegisterFunction("pause", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_PAUSE; sendPause = true; return CCMD_OK; });
C_RegisterFunction("steroids", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_STEROIDS; return CCMD_OK; });
C_RegisterFunction("nightvision", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_NIGHTVISION; return CCMD_OK; });
C_RegisterFunction("medkit", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_MEDKIT; return CCMD_OK; });
C_RegisterFunction("centerview", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_CENTER_VIEW; return CCMD_OK; }); C_RegisterFunction("centerview", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_CENTER_VIEW; return CCMD_OK; });
C_RegisterFunction("holsterweapon", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_HOLSTER; return CCMD_OK; }); C_RegisterFunction("holsterweapon", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_HOLSTER; return CCMD_OK; });
C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_INV_LEFT; return CCMD_OK; }); C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_INV_LEFT; return CCMD_OK; });
C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_INV_RIGHT; return CCMD_OK; }); C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_INV_RIGHT; return CCMD_OK; });
C_RegisterFunction("holoduke", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_HOLODUKE; return CCMD_OK; });
C_RegisterFunction("jetpack", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_JETPACK; return CCMD_OK; });
C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_TURNAROUND; return CCMD_OK; }); C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_TURNAROUND; return CCMD_OK; });
C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_INVENTORY; return CCMD_OK; }); C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_INVENTORY; return CCMD_OK; });
C_RegisterFunction("backoff", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_ESCAPE; return CCMD_OK; }); C_RegisterFunction("backoff", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= SKB_ESCAPE; return CCMD_OK; });

View file

@ -423,9 +423,6 @@ getinput(InputPacket *loc, SWBOOL tied)
loc->bits |= BitsToSend; loc->bits |= BitsToSend;
BitsToSend = 0; BitsToSend = 0;
SET(loc->bits, inv_hotkey<<SK_INV_HOTKEY_BIT0);
inv_hotkey = 0;
SET_LOC_KEY(loc->bits, SK_OPERATE, buttonMap.ButtonDown(gamefunc_Open)); 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_JUMP, buttonMap.ButtonDown(gamefunc_Jump));
SET_LOC_KEY(loc->bits, SK_CRAWL, buttonMap.ButtonDown(gamefunc_Crouch)); SET_LOC_KEY(loc->bits, SK_CRAWL, buttonMap.ButtonDown(gamefunc_Crouch));
@ -474,16 +471,10 @@ getinput(InputPacket *loc, SWBOOL tied)
void registerinputcommands() void registerinputcommands()
{ {
C_RegisterFunction("pause", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_PAUSE); sendPause = true; return CCMD_OK; }); C_RegisterFunction("pause", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_PAUSE); sendPause = true; return CCMD_OK; });
C_RegisterFunction("smoke_bomb", nullptr, [](CCmdFuncPtr)->int { inv_hotkey = INVENTORY_CLOAK + 1; return CCMD_OK; });
C_RegisterFunction("nightvision", nullptr, [](CCmdFuncPtr)->int { inv_hotkey = INVENTORY_NIGHT_VISION + 1; return CCMD_OK; });
C_RegisterFunction("medkit", nullptr, [](CCmdFuncPtr)->int { inv_hotkey = INVENTORY_MEDKIT + 1; return CCMD_OK; });
C_RegisterFunction("centerview", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_CENTER_VIEW); return CCMD_OK; }); C_RegisterFunction("centerview", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_CENTER_VIEW); return CCMD_OK; });
C_RegisterFunction("holsterweapon", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_HIDE_WEAPON); return CCMD_OK; }); C_RegisterFunction("holsterweapon", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_HIDE_WEAPON); return CCMD_OK; });
C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_INV_LEFT); return CCMD_OK; }); C_RegisterFunction("invprev", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_INV_LEFT); return CCMD_OK; });
C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_INV_RIGHT); return CCMD_OK; }); C_RegisterFunction("invnext", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_INV_RIGHT); return CCMD_OK; });
C_RegisterFunction("gas_bomb", nullptr, [](CCmdFuncPtr)->int { inv_hotkey = INVENTORY_CHEMBOMB + 1; return CCMD_OK; });
C_RegisterFunction("flash_bomb", nullptr, [](CCmdFuncPtr)->int { inv_hotkey = INVENTORY_FLASHBOMB + 1; return CCMD_OK; });
C_RegisterFunction("caltrops", nullptr, [](CCmdFuncPtr)->int { inv_hotkey = INVENTORY_CALTROPS + 1; return CCMD_OK; });
C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_TURN_180); return CCMD_OK; }); C_RegisterFunction("turnaround", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_TURN_180); return CCMD_OK; });
C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_INV_USE); return CCMD_OK; }); C_RegisterFunction("invuse", nullptr, [](CCmdFuncPtr)->int { BitsToSend |= BIT(SK_INV_USE); return CCMD_OK; });
} }

View file

@ -367,8 +367,6 @@ DoPlayerNightVisionPalette(PLAYERp pp)
void void
UseInventoryNightVision(PLAYERp pp) UseInventoryNightVision(PLAYERp pp)
{ {
#define NIGHT_INVENTORY_TIME 30
if (pp->InventoryActive[pp->InventoryNum]) if (pp->InventoryActive[pp->InventoryNum])
{ {
StopInventoryNightVision(pp, pp->InventoryNum); StopInventoryNightVision(pp, pp->InventoryNum);
@ -473,33 +471,33 @@ void InventoryKeys(PLAYERp pp)
FLAG_KEY_RESET(pp, SK_INV_USE); FLAG_KEY_RESET(pp, SK_INV_USE);
} }
// get hotkey number out of input bits // test all 7 items
inv_hotkey = TEST(pp->input.bits, SK_INV_HOTKEY_MASK) >> SK_INV_HOTKEY_BIT0; for (int i = 0; i <= 7; i++)
if (inv_hotkey)
{ {
if (FLAG_KEY_PRESSED(pp, SK_INV_HOTKEY_BIT0)) ESyncBits bit = ESyncBits::FromInt(SB_ITEM_BIT_1 << i);
if (pp->input.isItemUsed(i))
{ {
FLAG_KEY_RELEASE(pp, SK_INV_HOTKEY_BIT0); if (pp->KeyPressBits & bit)
inv_hotkey -= 1;
// switches you to this inventory item
pp->InventoryNum = inv_hotkey;
if (InventoryData[pp->InventoryNum].Init && !TEST(pp->Flags, PF_CLIMBING))
{ {
if (pp->InventoryAmount[pp->InventoryNum]) pp->KeyPressBits &= ~bit;
{
InventoryUse(pp); // switches you to this inventory item
} pp->InventoryNum = i;
}
if (InventoryData[pp->InventoryNum].Init && !TEST(pp->Flags, PF_CLIMBING))
{
if (pp->InventoryAmount[pp->InventoryNum])
{
InventoryUse(pp);
}
}
}
}
else
{
pp->KeyPressBits |= bit;
} }
} }
else
{
FLAG_KEY_RESET(pp, SK_INV_HOTKEY_BIT0);
}
} }
void InventoryTimer(PLAYERp pp) void InventoryTimer(PLAYERp pp)

View file

@ -83,22 +83,20 @@ 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); ppp->input.actions &= ~(SB_WEAPONMASK_BITS|SB_ITEMUSE_BITS);
ppp->KeyPressBits |= (SB_WEAPONMASK_BITS); ppp->KeyPressBits |= (SB_WEAPONMASK_BITS|SB_ITEMUSE_BITS);
RESET(ppp->input.bits, RESET(ppp->input.bits,
BIT(SK_SHOOT)|BIT(SK_OPERATE)|BIT(SK_INV_LEFT)|BIT(SK_INV_RIGHT)| BIT(SK_SHOOT)|BIT(SK_OPERATE)|BIT(SK_INV_LEFT)|BIT(SK_INV_RIGHT)|
BIT(SK_INV_USE)|BIT(SK_HIDE_WEAPON)| BIT(SK_INV_USE)|BIT(SK_HIDE_WEAPON)|
BIT(SK_AUTO_AIM)| BIT(SK_AUTO_AIM)|
BIT(SK_CENTER_VIEW)| BIT(SK_CENTER_VIEW)
SK_INV_HOTKEY_MASK
); );
SET(ppp->KeyPressFlags, SET(ppp->KeyPressFlags,
BIT(SK_SHOOT)|BIT(SK_OPERATE)|BIT(SK_INV_LEFT)|BIT(SK_INV_RIGHT)| BIT(SK_SHOOT)|BIT(SK_OPERATE)|BIT(SK_INV_LEFT)|BIT(SK_INV_RIGHT)|
BIT(SK_INV_USE)|BIT(SK_HIDE_WEAPON)| BIT(SK_INV_USE)|BIT(SK_HIDE_WEAPON)|
BIT(SK_AUTO_AIM)| BIT(SK_AUTO_AIM)|
BIT(SK_CENTER_VIEW)| BIT(SK_CENTER_VIEW)
SK_INV_HOTKEY_MASK
); );
// back up things so they won't get stepped on // back up things so they won't get stepped on

View file

@ -7518,7 +7518,7 @@ const char *DeathString(short SpriteNum)
case RADIATION_CLOUD: case RADIATION_CLOUD:
return GStrings("radiation"); return GStrings("radiation");
case CALTROPS: case CALTROPS:
return GStrings("caltrops"); return GStrings("useitem 7");
} }
return ""; return "";
} }

View file

@ -34,7 +34,7 @@ RCtrl "+Fire"
Pause "pause" Pause "pause"
` "toggleconsole" ` "toggleconsole"
T "+Send_Message" T "messagemode"
Tab "togglemap" Tab "togglemap"
mapbind F "togglefollow" mapbind F "togglefollow"
mapbind - "+Shrink_Screen" mapbind - "+Shrink_Screen"

View file

@ -584,15 +584,15 @@ OptionMenu "WeaponsControlMenu"// protected
} }
ifgame(Blood) ifgame(Blood)
{ {
Control "$CNTRLMNU_PROXIMITYBOMBS","proximitybombs" Control "$CNTRLMNU_PROXIMITYBOMBS","slot 11"
Control "$CNTRLMNU_REMOTEBOMBS" ,"remotebombs" Control "$CNTRLMNU_REMOTEBOMBS" ,"slot 12"
} }
ifgame(ShadowWarrior) ifgame(ShadowWarrior)
{ {
Control "$CNTRLMNU_SMOKEBOMB","smoke_bomb" Control "$CNTRLMNU_SMOKEBOMB","useitem 3"
Control "$CNTRLMNU_GASBOMB" ,"gas_bomb" Control "$CNTRLMNU_GASBOMB" ,"useitem 5"
Control "$CNTRLMNU_FLASHBOMB","flash_bomb" Control "$CNTRLMNU_FLASHBOMB","useitem 6"
Control "$CNTRLMNU_CALTROPS" ,"caltrops" Control "$CNTRLMNU_CALTROPS" ,"useitem 7"
} }
} }
@ -610,54 +610,65 @@ OptionMenu "InventoryControlsMenu"// protected
Control "$CNTRLMNU_NEXTITEM" , "invnext" Control "$CNTRLMNU_NEXTITEM" , "invnext"
Control "$CNTRLMNU_PREVIOUSITEM" , "invprev" Control "$CNTRLMNU_PREVIOUSITEM" , "invprev"
// Item numbers here are are defined by the games' internal order.
ifgame(Duke) ifgame(Duke)
{ {
StaticText "" StaticText ""
Control "$CNTRLMNU_HOLODUKE" , "holoduke" Control "$CNTRLMNU_HOLODUKE" , "useitem 3"
Control "$CNTRLMNU_JETPACK" , "jetpack" Control "$CNTRLMNU_JETPACK" , "useitem 4"
Control "$CNTRLMNU_NIGHTVISION" , "nightvision" Control "$CNTRLMNU_NIGHTVISION" , "useitem 5"
Control "$CNTRLMNU_MEDKIT" , "medkit" Control "$CNTRLMNU_MEDKIT" , "useitem 1"
Control "$CNTRLMNU_STEROIDS" , "steroids" Control "$CNTRLMNU_STEROIDS" , "useitem 2"
} }
ifgame(Nam) ifgame(Nam)
{ {
StaticText "" StaticText ""
Control "$CNTRLMNU_HOLOSOLDIER" , "holoduke" Control "$CNTRLMNU_HOLOSOLDIER" , "useitem 3"
Control "$CNTRLMNU_HUEY" , "jetpack" Control "$CNTRLMNU_HUEY" , "useitem 4"
Control "$CNTRLMNU_NIGHTVISION" , "nightvision" Control "$CNTRLMNU_NIGHTVISION" , "useitem 5"
Control "$CNTRLMNU_MEDKIT" , "medkit" Control "$CNTRLMNU_MEDKIT" , "useitem 1"
Control "$CNTRLMNU_TANKMODE" , "steroids" Control "$CNTRLMNU_TANKMODE" , "useitem 2"
} }
ifgame(WW2GI) ifgame(WW2GI)
{ {
StaticText "" StaticText ""
Control "$CNTRLMNU_FIRE MISSION" , "holoduke" Control "$CNTRLMNU_FIRE MISSION" , "useitem 3"
Control "$CNTRLMNU_NIGHTVISION" , "nightvision" Control "$CNTRLMNU_NIGHTVISION" , "useitem 5"
Control "$CNTRLMNU_MEDKIT" , "medkit" Control "$CNTRLMNU_MEDKIT" , "useitem 1"
Control "$CNTRLMNU_SMOKES" , "steroids" Control "$CNTRLMNU_SMOKES" , "useitem 2"
} }
ifgame(Redneck, RedneckRides) ifgame(Redneck, RedneckRides)
{ {
StaticText "" StaticText ""
Control "$CNTRLMNU_BEER" , "holoduke" Control "$CNTRLMNU_BEER" , "useitem 3"
Control "$CNTRLMNU_COWPIE" , "jetpack" Control "$CNTRLMNU_COWPIE" , "useitem 4"
Control "$CNTRLMNU_YEEHAA" , "nightvision" Control "$CNTRLMNU_YEEHAA" , "useitem 5"
Control "$CNTRLMNU_WHISKEY" , "medkit" Control "$CNTRLMNU_WHISKEY" , "useitem 1"
Control "$CNTRLMNU_MOONSHINE" , "steroids" Control "$CNTRLMNU_MOONSHINE" , "useitem 2"
} }
ifgame(Blood) ifgame(Blood)
{ {
StaticText "" StaticText ""
Control "$CNTRLMNU_CRYSTALBALL" , "crystalball" Control "$CNTRLMNU_CRYSTALBALL" , "useitem 2"
Control "$CNTRLMNU_JUMPBOOTS" , "jumpboots" Control "$CNTRLMNU_JUMPBOOTS" , "useitem 4"
Control "$CNTRLMNU_BEASTVISION" , "beastvision" Control "$CNTRLMNU_BEASTVISION" , "useitem 3"
Control "$CNTRLMNU_MEDKIT" , "medkit" Control "$CNTRLMNU_MEDKIT" , "useitem 1"
} }
ifgame(ShadowWarrior) ifgame(ShadowWarrior)
{ {
StaticText "" StaticText ""
Control "$CNTRLMNU_NIGHTVISION" , "nightvision" Control "$CNTRLMNU_NIGHTVISION" , "useitem 4"
Control "$CNTRLMNU_MEDKIT" , "medkit" Control "$CNTRLMNU_MEDKIT" , "useitem 1"
}
ifgame(Exhumed)
{
StaticText ""
Control "$TXT_USEINV1" , "useitem 1"
Control "$TXT_USEINV2" , "useitem 2"
Control "$TXT_USEINV3" , "useitem 3"
Control "$TXT_USEINV4" , "useitem 4"
Control "$TXT_USEINV5" , "useitem 5"
Control "$TXT_USEINV6" , "useitem 6"
} }
} }

View file

@ -1,11 +1,11 @@
U "+Mouse_Aiming" U "+Mouse_Aiming"
I "toggle cl_crosshair" I "toggle cl_crosshair"
Scroll "+Holster_Weapon" Scroll "+Holster_Weapon"
B "BeastVision" B "useitem 3"
C "CrystalBall" C "useitem 2"
P "ProximityBombs" P "slot 11"
R "RemoteBombs" R "slot 12"
X "+Alt_Fire" X "+Alt_Fire"
J "jumpboots" J "useitem 4"
M "MedKit" M "useitem 1"
Mouse2 "+Alt_Fire" Mouse2 "+Alt_Fire"

View file

@ -1,9 +1,9 @@
// //
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"
B "BeastVision" B "useitem 3"
C "CrystalBall" C "useitem 2"
P "ProximityBombs" P "slot 11"
R "RemoteBombs" R "slot 12"
X "+Alt_Fire" X "+Alt_Fire"
J "jumpboots" J "useitem 4"
M "MedKit" M "useitem 1"

View file

@ -1,10 +1,10 @@
// //
X "+Alt_Fire"
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"
B "BeastVision" B "useitem 3"
C "CrystalBall" C "useitem 2"
J "jumpboots" P "slot 11"
M "MedKit" R "slot 12"
P "ProximityBombs" X "+Alt_Fire"
R "RemoteBombs" J "useitem 4"
M "useitem 1"
Mouse2 "+Alt_Fire" Mouse2 "+Alt_Fire"

View file

@ -1,10 +1,10 @@
// //
R "Steroids" R "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
H "HoloDuke" H "useitem 3"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
C "+Toggle_Crouch" C "+Toggle_Crouch"
Mouse2 "Jetpack" Mouse2 "useitem 4"
Mouse3 "MediKit" Mouse3 "useitem 1"

View file

@ -1,7 +1,7 @@
H "HoloDuke" H "useitem 3"
R "Steroids" R "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"

View file

@ -1,13 +1,13 @@
// //
R "Steroids" R "useitem 2"
` "+Quick_Kick" ` "+Quick_Kick"
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"
H "Holo_Duke" H "Holo_Duke"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
C "toggleconsole" C "toggleconsole"
Mouse2 "Jetpack" Mouse2 "useitem 4"
Mouse3 "MediKit" Mouse3 "useitem 1"

View file

@ -1,10 +1,10 @@
// //
R "Steroids" R "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
H "HoloDuke" H "useitem 3"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
C "+Toggle_Crouch" C "+Toggle_Crouch"
Mouse2 "Jetpack" Mouse2 "useitem 4"
Mouse3 "MediKit" Mouse3 "useitem 1"

View file

@ -1,7 +1,7 @@
H "HoloDuke" H "useitem 3"
R "Steroids" R "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"

View file

@ -1,13 +1,13 @@
// //
R "Steroids" R "useitem 2"
` "+Quick_Kick" ` "+Quick_Kick"
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"
H "HoloDuke" H "useitem 3"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
C "toggleconsole" C "toggleconsole"
Mouse2 "Jetpack" Mouse2 "useitem 4"
Mouse3 "MediKit" Mouse3 "useitem 1"

View file

@ -1,10 +1,10 @@
// //
V "+Show_Opponents_Weapon" V "+Show_Opponents_Weapon"
B "HoloDuke" B "useitem 3"
C "Jetpack" C "useitem 4"
Y "NightVision" Y "useitem 5"
R "MedKit" R "useitem 1"
M "Steroids" M "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
Mouse2 "Jetpack" Mouse2 "useitem 4"
Mouse3 "MediKit" Mouse3 "useitem 1"

View file

@ -1,7 +1,7 @@
E "+Show_Opponents_Weapon" E "+Show_Opponents_Weapon"
M "Steroids" M "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
B "HoloDuke" B "useitem 3"
C "Jetpack" C "useitem 4"
Y "NightVision" Y "useitem 5"
W "MedKit" W "useitem 1"

View file

@ -1,8 +1,8 @@
V "toggleconsole" V "toggleconsole"
E "+Show_Opponents_Weapon" E "+Show_Opponents_Weapon"
M "Steroids" M "useitem 2"
` "+Quick_Kick" ` "+Quick_Kick"
B "HoloDuke" B "useitem 3"
C "Jetpack" C "useitem 4"
Y "NightVision" Y "useitem 5"
W "MedKit" W "useitem 1"

View file

@ -1,9 +1,9 @@
// //
I "toggle cl_crosshair" I "toggle cl_crosshair"
Mouse2 "MedKit" Mouse2 "useitem 1"
M "MedKit" M "useitem 1"
B "Smoke_Bomb" B "useitem 3"
N "Nightvision" N "useitem 4"
G "Gas_Bomb" G "useitem 5"
F "Flash_Bomb" F "useitem 6"
C "Caltrops" C "useitem 7"

View file

@ -1,6 +1,6 @@
M "MedKit" M "useitem 1"
B "Smoke_Bomb" B "useitem 3"
N "Nightvision" N "useitem 4"
G "Gas_Bomb" G "useitem 5"
F "Flash_Bomb" F "useitem 6"
C "Caltrops" C "useitem 7"

View file

@ -1,7 +1,7 @@
M "MedKit" M "useitem 1"
S "Smoke_Bomb" S "useitem 3"
N "Nightvision" N "useitem 4"
G "Gas_Bomb" G "useitem 5"
F "Flash_Bomb" F "useitem 6"
C "Caltrops" C "useitem 7"
Mouse2 "MedKit" Mouse2 "useitem 1"

View file

@ -1,10 +1,10 @@
// //
R "Steroids" R "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
H "HoloDuke" H "useitem 3"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
C "+Toggle_Crouch" C "+Toggle_Crouch"
Mouse2 "Jetpack" Mouse2 "useitem 4"
Mouse3 "MediKit" Mouse3 "useitem 1"

View file

@ -1,7 +1,7 @@
H "HoloDuke" H "useitem 3"
R "Steroids" R "useitem 2"
Q "+Quick_Kick" Q "+Quick_Kick"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"

View file

@ -1,13 +1,13 @@
// //
R "Steroids" R "useitem 2"
` "+Quick_Kick" ` "+Quick_Kick"
W "+Show_Opponents_Weapon" W "+Show_Opponents_Weapon"
H "HoloDuke" H "useitem 3"
J "Jetpack" J "useitem 4"
N "NightVision" N "useitem 5"
M "MedKit" M "useitem 1"
C "toggleconsole" C "toggleconsole"
Mouse2 "Jetpack" Mouse2 "useitem 4"
Mouse3 "MediKit" Mouse3 "useitem 1"