diff --git a/source/games/duke/src/funct.h b/source/games/duke/src/funct.h index 5cb8e16bf..81cda40ab 100644 --- a/source/games/duke/src/funct.h +++ b/source/games/duke/src/funct.h @@ -234,7 +234,7 @@ void apply_seasick(player_struct* p, double scalefactor); void calcviewpitch(player_struct* p, double factor); void sethorizon(int snum, ESyncBits actions, double factor, fixed_t adjustment); bool movementBlocked(int snum); -void GetInput(); +void GetInput(InputPacket &loc); void startmainmenu(); void loadcons(); diff --git a/source/games/duke/src/gameloop.cpp b/source/games/duke/src/gameloop.cpp index a6893fa5c..db51adb06 100644 --- a/source/games/duke/src/gameloop.cpp +++ b/source/games/duke/src/gameloop.cpp @@ -333,7 +333,7 @@ bool GameTicker() { lastTic = currentTic; - GetInput(); + GetInput(loc); auto const pPlayer = &ps[myconnectindex]; auto const q16ang = fix16_to_int(pPlayer->q16ang); auto& input = nextinput(myconnectindex); @@ -366,7 +366,7 @@ bool GameTicker() if (!cl_syncinput) { - GetInput(); + GetInput(loc); } drawtime.Reset(); diff --git a/source/games/duke/src/input.cpp b/source/games/duke/src/input.cpp index 3fed36a2d..8633d686e 100644 --- a/source/games/duke/src/input.cpp +++ b/source/games/duke/src/input.cpp @@ -565,28 +565,28 @@ enum // //--------------------------------------------------------------------------- -static void processInputBits(player_struct *p, ControlInfo &info) +static void processInputBits(InputPacket &locInput, player_struct *p, ControlInfo &info) { ApplyGlobalInput(loc, &info); - if (isRR() && (loc.actions & SB_CROUCH)) loc.actions &= ~SB_JUMP; + if (isRR() && (locInput.actions & SB_CROUCH)) locInput.actions &= ~SB_JUMP; if (p->OnMotorcycle || p->OnBoat) { // mask out all actions not compatible with vehicles. - loc.actions &= ~(SB_WEAPONMASK_BITS | SB_TURNAROUND | SB_CENTERVIEW | SB_HOLSTER | SB_JUMP | SB_CROUCH | SB_RUN | + locInput.actions &= ~(SB_WEAPONMASK_BITS | SB_TURNAROUND | SB_CENTERVIEW | SB_HOLSTER | SB_JUMP | SB_CROUCH | SB_RUN | SB_AIM_UP | SB_AIM_DOWN | SB_AIMMODE | SB_LOOK_UP | SB_LOOK_DOWN | SB_LOOK_LEFT | SB_LOOK_RIGHT); } else { if (buttonMap.ButtonDown(gamefunc_Quick_Kick)) // this shares a bit with another function so cannot be in the common code. - loc.actions |= SB_QUICK_KICK; + locInput.actions |= SB_QUICK_KICK; if (buttonMap.ButtonDown(gamefunc_Toggle_Crouch) || p->crouch_toggle) { - loc.actions |= SB_CROUCH; + locInput.actions |= SB_CROUCH; } - if ((isRR() && p->drink_amt > 88)) loc.actions |= SB_LOOK_LEFT; - if ((isRR() && p->drink_amt > 99)) loc.actions |= SB_LOOK_DOWN; + if ((isRR() && p->drink_amt > 88)) locInput.actions |= SB_LOOK_LEFT; + if ((isRR() && p->drink_amt > 99)) locInput.actions |= SB_LOOK_DOWN; } } @@ -632,12 +632,12 @@ int getticssincelastupdate() // //--------------------------------------------------------------------------- -static void processMovement(player_struct *p, InputPacket &input, ControlInfo &info, double scaleFactor) +static void processMovement(player_struct *p, InputPacket& locInput, InputPacket &input, ControlInfo &info, double scaleFactor) { - bool mouseaim = !!(loc.actions & SB_AIMMODE); + bool mouseaim = !!(locInput.actions & SB_AIMMODE); // JBF: Run key behaviour is selectable - int running = !!(loc.actions & SB_RUN); + int running = !!(locInput.actions & SB_RUN); int turnamount = NORMALTURN << running; int keymove = NORMALKEYMOVE << running; @@ -659,7 +659,7 @@ static void processMovement(player_struct *p, InputPacket &input, ControlInfo &i if (buttonMap.ButtonDown(gamefunc_Strafe)) { - if (!loc.svel) + if (!locInput.svel) { if (buttonMap.ButtonDown(gamefunc_Turn_Left)) input.svel = keymove; @@ -690,7 +690,7 @@ static void processMovement(player_struct *p, InputPacket &input, ControlInfo &i } - if (abs(loc.svel) < keymove) + if (abs(locInput.svel) < keymove) { if (buttonMap.ButtonDown(gamefunc_Strafe_Left)) input.svel += keymove; @@ -699,7 +699,7 @@ static void processMovement(player_struct *p, InputPacket &input, ControlInfo &i input.svel += -keymove; } - if (abs(loc.fvel) < keymove) + if (abs(locInput.fvel) < keymove) { if (isRR() && p->drink_amt >= 66 && p->drink_amt <= 87) { @@ -910,7 +910,7 @@ static double boatApplyTurn(player_struct *p, int turnl, int turnr, int boat_tur // //--------------------------------------------------------------------------- -static void processVehicleInput(player_struct *p, ControlInfo& info, InputPacket& input, double scaleAdjust) +static void processVehicleInput(player_struct *p, ControlInfo& info, InputPacket& locInput, InputPacket& input, double scaleAdjust) { auto turnspeed = info.mousex + scaleAdjust * info.dyaw * (1. / 32); // originally this was 64, not 32. Why the change? int turnl = buttonMap.ButtonDown(gamefunc_Turn_Left) || buttonMap.ButtonDown(gamefunc_Strafe_Left); @@ -928,17 +928,17 @@ static void processVehicleInput(player_struct *p, ControlInfo& info, InputPacket if (p->OnBoat || !p->moto_underwater) { if (buttonMap.ButtonDown(gamefunc_Move_Forward) || buttonMap.ButtonDown(gamefunc_Strafe)) - loc.actions |= SB_JUMP; + locInput.actions |= SB_JUMP; if (buttonMap.ButtonDown(gamefunc_Move_Backward)) - loc.actions |= SB_AIM_UP; - if (loc.actions & SB_RUN) - loc.actions |= SB_CROUCH; + locInput.actions |= SB_AIM_UP; + if (locInput.actions & SB_RUN) + locInput.actions |= SB_CROUCH; } if (turnl) - loc.actions |= SB_AIM_DOWN; + locInput.actions |= SB_AIM_DOWN; if (turnr) - loc.actions |= SB_LOOK_LEFT; + locInput.actions |= SB_LOOK_LEFT; double turnvel; @@ -968,7 +968,7 @@ static void processVehicleInput(player_struct *p, ControlInfo& info, InputPacket // //--------------------------------------------------------------------------- -static void FinalizeInput(int playerNum, InputPacket& input, bool vehicle) +static void FinalizeInput(int playerNum, InputPacket& locInput, InputPacket& input, bool vehicle) { auto p = &ps[playerNum]; bool blocked = movementBlocked(playerNum) || sprite[p->i].extra <= 0 || (p->dead_flag && !ud.god); @@ -981,8 +981,8 @@ static void FinalizeInput(int playerNum, InputPacket& input, bool vehicle) ud.folavel = fix16_to_int(input.q16avel); } - loc.fvel = loc.svel = 0; - loc.q16avel = loc.q16horz = 0; + locInput.fvel = locInput.svel = 0; + locInput.q16avel = locInput.q16horz = 0; input.q16avel = input.q16horz = 0; } else @@ -991,21 +991,21 @@ static void FinalizeInput(int playerNum, InputPacket& input, bool vehicle) { if (!vehicle) { - loc.fvel = clamp(loc.fvel + input.fvel, -MAXVEL, MAXVEL); - loc.svel = clamp(loc.svel + input.svel, -MAXSVEL, MAXSVEL); + locInput.fvel = clamp(locInput.fvel + input.fvel, -MAXVEL, MAXVEL); + locInput.svel = clamp(locInput.svel + input.svel, -MAXSVEL, MAXSVEL); } else - loc.fvel = clamp(input.fvel, -(MAXVELMOTO / 8), MAXVELMOTO); + locInput.fvel = clamp(input.fvel, -(MAXVELMOTO / 8), MAXVELMOTO); } else { - loc.fvel = input.fvel = 0; - loc.svel = input.svel = 0; + locInput.fvel = input.fvel = 0; + locInput.svel = input.svel = 0; } if (p->on_crane < 0 && p->newowner == -1) { - loc.q16avel = fix16_clamp(loc.q16avel + input.q16avel, F16(-MAXANGVEL), F16(MAXANGVEL)); + locInput.q16avel = fix16_clamp(locInput.q16avel + input.q16avel, F16(-MAXANGVEL), F16(MAXANGVEL)); if (!cl_syncinput && input.q16avel) { p->one_eighty_count = 0; @@ -1013,16 +1013,16 @@ static void FinalizeInput(int playerNum, InputPacket& input, bool vehicle) } else { - loc.q16avel = input.q16avel = 0; + locInput.q16avel = input.q16avel = 0; } if (p->newowner == -1 && p->return_to_center <= 0) { - loc.q16horz = fix16_clamp(loc.q16horz + input.q16horz, F16(-MAXHORIZVEL), F16(MAXHORIZVEL)); + locInput.q16horz = fix16_clamp(locInput.q16horz + input.q16horz, F16(-MAXHORIZVEL), F16(MAXHORIZVEL)); } else { - loc.q16horz = input.q16horz = 0; + locInput.q16horz = input.q16horz = 0; } } } @@ -1033,7 +1033,7 @@ static void FinalizeInput(int playerNum, InputPacket& input, bool vehicle) // //--------------------------------------------------------------------------- -void GetInput() +void GetInput(InputPacket &locInput) { double elapsedInputTicks; auto const p = &ps[myconnectindex]; @@ -1064,9 +1064,9 @@ void GetInput() if (isRRRA() && (p->OnMotorcycle || p->OnBoat)) { p->crouch_toggle = 0; - processInputBits(p, info); - processVehicleInput(p, info, input, scaleAdjust); - FinalizeInput(myconnectindex, input, true); + processInputBits(locInput, p, info); + processVehicleInput(p, info, locInput, input, scaleAdjust); + FinalizeInput(myconnectindex, locInput, input, true); if (!cl_syncinput && sprite[p->i].extra > 0) { @@ -1075,10 +1075,10 @@ void GetInput() } else { - processInputBits(p, info); - processMovement(p, input, info, scaleAdjust); + processInputBits(locInput, p, info); + processMovement(p, input, locInput, info, scaleAdjust); checkCrouchToggle(p); - FinalizeInput(myconnectindex, input, false); + FinalizeInput(myconnectindex, locInput, input, false); } if (!cl_syncinput) @@ -1086,7 +1086,7 @@ void GetInput() // Do these in the same order as the old code. calcviewpitch(p, scaleAdjust); applylook(myconnectindex, scaleAdjust, input.q16avel); - sethorizon(myconnectindex, loc.actions, scaleAdjust, input.q16horz); + sethorizon(myconnectindex, locInput.actions, scaleAdjust, input.q16horz); } }