mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-16 20:50:38 +00:00
- input code cleanup.
The input queues are mostly abstracted now and some EDuke specific handling that isn't needed anymore was removed.
This commit is contained in:
parent
9300c0bdeb
commit
f4e763e252
10 changed files with 87 additions and 141 deletions
|
@ -41,17 +41,80 @@ BEGIN_DUKE_NS
|
||||||
void GetNextInput();
|
void GetNextInput();
|
||||||
|
|
||||||
|
|
||||||
/*
|
//---------------------------------------------------------------------------
|
||||||
static inline int movefifoend(int myconnectindex)
|
//
|
||||||
|
// abstract the queue's implementation
|
||||||
|
// All access to the input queues should go through this function interface.
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
static input_t inputfifo[MOVEFIFOSIZ][MAXPLAYERS];
|
||||||
|
static int movefifoend[MAXPLAYERS];
|
||||||
|
static int movefifoplc;
|
||||||
|
|
||||||
|
|
||||||
|
void clearfifo(void)
|
||||||
{
|
{
|
||||||
#if 1
|
localInput = {};
|
||||||
return g_player[myconnectindex].movefifoend;
|
memset(&inputfifo, 0, sizeof(inputfifo));
|
||||||
#else
|
|
||||||
return movefifoend[myconnectindex];
|
for (int p = 0; p <= MAXPLAYERS - 1; ++p)
|
||||||
|
{
|
||||||
|
if (g_player[p].input != NULL)
|
||||||
|
*g_player[p].input = {};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline void GetNextInput()
|
||||||
|
{
|
||||||
|
for (int i = connecthead; i >= 0; i = connectpoint2[i])
|
||||||
|
memcpy(g_player[i].input /*originally: &sync[i] */, &inputfifo[movefifoplc & (MOVEFIFOSIZ - 1)][i], sizeof(input_t));
|
||||||
|
|
||||||
|
movefifoplc++;
|
||||||
|
}
|
||||||
|
|
||||||
|
void advancequeue(int myconnectindex)
|
||||||
|
{
|
||||||
|
movefifoend[myconnectindex]++;
|
||||||
|
}
|
||||||
|
|
||||||
|
input_t& nextinput(int myconnectindex)
|
||||||
|
{
|
||||||
|
return inputfifo[movefifoend[myconnectindex] & (MOVEFIFOSIZ - 1)][myconnectindex];
|
||||||
|
}
|
||||||
|
|
||||||
|
bool shouldprocessinput(int myconnectindex)
|
||||||
|
{
|
||||||
|
if (movefifoend[myconnectindex] - movefifoplc > bufferjitter)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for (i = connecthead; i >= 0; i = connectpoint2[i])
|
||||||
|
if (movefifoplc == movefifoend[i]) return false;
|
||||||
|
if (i >= 0) return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void fakedomovethings()
|
||||||
|
{
|
||||||
|
// prediction
|
||||||
|
}
|
||||||
|
|
||||||
|
static void fakedomovethingscorrect()
|
||||||
|
{
|
||||||
|
// unprediction
|
||||||
|
}
|
||||||
|
|
||||||
|
void prediction()
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
// We currently have no net code driving this.
|
||||||
|
if (numplayers > 1)
|
||||||
|
while (fakemovefifoplc < movefifoend[myconnectindex]) fakedomovethings();
|
||||||
|
getpackets();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
|
@ -70,22 +133,6 @@ int menuloop(void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
//
|
|
||||||
//
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
static void fakedomovethings()
|
|
||||||
{
|
|
||||||
// prediction
|
|
||||||
}
|
|
||||||
|
|
||||||
static void fakedomovethingscorrect()
|
|
||||||
{
|
|
||||||
// unprediction
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
|
@ -254,28 +301,20 @@ int domovethings()
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
/*
|
|
||||||
|
|
||||||
char moveloop()
|
|
||||||
|
int moveloop()
|
||||||
{
|
{
|
||||||
int i;
|
prediction();
|
||||||
|
|
||||||
if (numplayers > 1)
|
|
||||||
while (fakemovefifoplc < movefifoend[myconnectindex]) fakedomovethings();
|
|
||||||
|
|
||||||
getpackets();
|
|
||||||
|
|
||||||
if (numplayers < 2) bufferjitter = 0;
|
if (numplayers < 2) bufferjitter = 0;
|
||||||
while (movefifoend(myconnectindex)-movefifoplc > bufferjitter)
|
while (shouldprocessinput(myconnectindex))
|
||||||
{
|
{
|
||||||
for(i=connecthead;i>=0;i=connectpoint2[i])
|
|
||||||
if (movefifoplc == movefifoend(i)) break;
|
|
||||||
if (i >= 0) break;
|
|
||||||
if( domovethings() ) return 1;
|
if( domovethings() ) return 1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
|
||||||
END_DUKE_NS
|
END_DUKE_NS
|
||||||
|
|
||||||
|
|
|
@ -82,15 +82,11 @@ G_EXTERN uint8_t packbuf[PACKBUF_SIZE];
|
||||||
G_EXTERN input_t localInput;
|
G_EXTERN input_t localInput;
|
||||||
G_EXTERN input_t recsync[RECSYNCBUFSIZ];
|
G_EXTERN input_t recsync[RECSYNCBUFSIZ];
|
||||||
|
|
||||||
//G_EXTERN uint8_t syncstat, syncval[MAXPLAYERS][MOVEFIFOSIZ];
|
|
||||||
//G_EXTERN int32_t syncvalhead[MAXPLAYERS], syncvaltail, syncvaltottail;
|
|
||||||
|
|
||||||
G_EXTERN int32_t avgfvel, avgsvel, avgbits;
|
G_EXTERN int32_t avgfvel, avgsvel, avgbits;
|
||||||
G_EXTERN fix16_t avgavel, avghorz;
|
G_EXTERN fix16_t avgavel, avghorz;
|
||||||
G_EXTERN int8_t avgextbits;
|
G_EXTERN int8_t avgextbits;
|
||||||
|
|
||||||
G_EXTERN int32_t movefifosendplc;
|
G_EXTERN int32_t movefifosendplc;
|
||||||
G_EXTERN int32_t movefifoplc;
|
|
||||||
|
|
||||||
G_EXTERN int32_t predictfifoplc;
|
G_EXTERN int32_t predictfifoplc;
|
||||||
G_EXTERN vec3_t mypos, omypos, myvel;
|
G_EXTERN vec3_t mypos, omypos, myvel;
|
||||||
|
@ -257,7 +253,6 @@ extern playerdata_t *const g_player;
|
||||||
#endif
|
#endif
|
||||||
G_EXTERN playerspawn_t g_playerSpawnPoints[MAXPLAYERS];
|
G_EXTERN playerspawn_t g_playerSpawnPoints[MAXPLAYERS];
|
||||||
#define po g_playerSpawnPoints
|
#define po g_playerSpawnPoints
|
||||||
G_EXTERN input_t inputfifo[MOVEFIFOSIZ][MAXPLAYERS];
|
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
G_EXTERN int32_t g_noEnemies;
|
G_EXTERN int32_t g_noEnemies;
|
||||||
|
|
|
@ -137,7 +137,6 @@ typedef struct {
|
||||||
uint32_t bits;
|
uint32_t bits;
|
||||||
int16_t fvel, svel;
|
int16_t fvel, svel;
|
||||||
fix16_t q16avel, q16horz;
|
fix16_t q16avel, q16horz;
|
||||||
int8_t extbits;
|
|
||||||
} input_t;
|
} input_t;
|
||||||
|
|
||||||
#pragma pack(push,1)
|
#pragma pack(push,1)
|
||||||
|
@ -315,7 +314,6 @@ typedef struct
|
||||||
float horizAngleAdjust;
|
float horizAngleAdjust;
|
||||||
fix16_t horizSkew;
|
fix16_t horizSkew;
|
||||||
|
|
||||||
int32_t movefifoend, syncvalhead, myminlag;
|
|
||||||
int32_t pcolor, pteam;
|
int32_t pcolor, pteam;
|
||||||
// NOTE: wchoice[HANDREMOTE_WEAPON .. MAX_WEAPONS-1] unused
|
// NOTE: wchoice[HANDREMOTE_WEAPON .. MAX_WEAPONS-1] unused
|
||||||
uint8_t frags[MAXPLAYERS];
|
uint8_t frags[MAXPLAYERS];
|
||||||
|
@ -366,7 +364,6 @@ typedef struct {
|
||||||
int32_t shade;
|
int32_t shade;
|
||||||
} hudweapon_t;
|
} hudweapon_t;
|
||||||
|
|
||||||
extern input_t inputfifo[MOVEFIFOSIZ][MAXPLAYERS];
|
|
||||||
extern playerspawn_t g_playerSpawnPoints[MAXPLAYERS];
|
extern playerspawn_t g_playerSpawnPoints[MAXPLAYERS];
|
||||||
extern playerdata_t *const g_player;
|
extern playerdata_t *const g_player;
|
||||||
extern hudweapon_t hudweap;
|
extern hudweapon_t hudweap;
|
||||||
|
|
|
@ -38,7 +38,7 @@ void P_ResetPlayer(int playerNum);
|
||||||
void resetplayerstats(int playerNum);
|
void resetplayerstats(int playerNum);
|
||||||
void resetweapons(int playerNum);
|
void resetweapons(int playerNum);
|
||||||
void resetprestat(int snum, int g);
|
void resetprestat(int snum, int g);
|
||||||
void G_ClearFIFO(void);
|
void clearfifo(void);
|
||||||
void G_ResetInterpolations(void);
|
void G_ResetInterpolations(void);
|
||||||
void setmapfog(int fogtype);
|
void setmapfog(int fogtype);
|
||||||
void G_InitRRRASkies(void);
|
void G_InitRRRASkies(void);
|
||||||
|
|
|
@ -313,14 +313,6 @@ void doanimations(void)
|
||||||
{
|
{
|
||||||
ps[p].posz += v;
|
ps[p].posz += v;
|
||||||
ps[p].poszv = 0;
|
ps[p].poszv = 0;
|
||||||
#if 0
|
|
||||||
if (p == myconnectindex)
|
|
||||||
{
|
|
||||||
myz += v;
|
|
||||||
myzvel = 0;
|
|
||||||
myzbak[((movefifoplc - 1) & (MOVEFIFOSIZ - 1))] = ps[p].posz;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (j = headspritesect[dasect]; j >= 0; j = nextspritesect[j])
|
for (j = headspritesect[dasect]; j >= 0; j = nextspritesect[j])
|
||||||
|
|
|
@ -56,8 +56,10 @@ void SetDispatcher();
|
||||||
void InitCheats();
|
void InitCheats();
|
||||||
void checkcommandline();
|
void checkcommandline();
|
||||||
int registerosdcommands(void);
|
int registerosdcommands(void);
|
||||||
int32_t G_MoveLoop(void);
|
int32_t moveloop(void);
|
||||||
int menuloop(void);
|
int menuloop(void);
|
||||||
|
void advancequeue(int myconnectindex);
|
||||||
|
input_t& nextinput(int myconnectindex);
|
||||||
|
|
||||||
int16_t max_ammo_amount[MAX_WEAPONS];
|
int16_t max_ammo_amount[MAX_WEAPONS];
|
||||||
int32_t spriteqamount = 64;
|
int32_t spriteqamount = 64;
|
||||||
|
@ -203,14 +205,14 @@ void G_HandleLocalKeys(void)
|
||||||
if (SHIFTS_IS_PRESSED)
|
if (SHIFTS_IS_PRESSED)
|
||||||
{
|
{
|
||||||
Printf(PRINT_NOTIFY, *CombatMacros[ridiculeNum-1]);
|
Printf(PRINT_NOTIFY, *CombatMacros[ridiculeNum-1]);
|
||||||
Net_SendTaunt(ridiculeNum);
|
//Net_SendTaunt(ridiculeNum);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Not SHIFT -- that is, either some ALT or WIN.
|
// Not SHIFT -- that is, either some ALT or WIN.
|
||||||
if (startrts(ridiculeNum, 1))
|
if (startrts(ridiculeNum, 1))
|
||||||
{
|
{
|
||||||
Net_SendRTS(ridiculeNum);
|
//Net_SendRTS(ridiculeNum);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -772,8 +774,6 @@ MAIN_LOOP_RESTART:
|
||||||
}
|
}
|
||||||
|
|
||||||
G_NewGame_EnterLevel();
|
G_NewGame_EnterLevel();
|
||||||
|
|
||||||
Net_WaitForEverybody();
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -811,9 +811,6 @@ MAIN_LOOP_RESTART:
|
||||||
|
|
||||||
Net_GetPackets();
|
Net_GetPackets();
|
||||||
|
|
||||||
// only allow binds to function if the player is actually in a game (not in a menu, typing, et cetera) or demo
|
|
||||||
inputState.SetBindsEnabled(!!(g_player[myconnectindex].ps->gm & (MODE_GAME|MODE_DEMO)));
|
|
||||||
|
|
||||||
G_HandleLocalKeys();
|
G_HandleLocalKeys();
|
||||||
|
|
||||||
C_RunDelayedCommands();
|
C_RunDelayedCommands();
|
||||||
|
@ -836,7 +833,7 @@ MAIN_LOOP_RESTART:
|
||||||
// this is where we fill the input_t struct that is actually processed by P_ProcessInput()
|
// this is where we fill the input_t struct that is actually processed by P_ProcessInput()
|
||||||
auto const pPlayer = g_player[myconnectindex].ps;
|
auto const pPlayer = g_player[myconnectindex].ps;
|
||||||
auto const q16ang = fix16_to_int(pPlayer->q16ang);
|
auto const q16ang = fix16_to_int(pPlayer->q16ang);
|
||||||
auto & input = inputfifo[g_player[myconnectindex].movefifoend&(MOVEFIFOSIZ-1)][myconnectindex];
|
auto& input = nextinput(myconnectindex);
|
||||||
|
|
||||||
input = localInput;
|
input = localInput;
|
||||||
input.fvel = mulscale9(localInput.fvel, sintable[(q16ang + 2560) & 2047]) +
|
input.fvel = mulscale9(localInput.fvel, sintable[(q16ang + 2560) & 2047]) +
|
||||||
|
@ -847,12 +844,12 @@ MAIN_LOOP_RESTART:
|
||||||
pPlayer->fric.y;
|
pPlayer->fric.y;
|
||||||
localInput = {};
|
localInput = {};
|
||||||
|
|
||||||
g_player[myconnectindex].movefifoend++;
|
advancequeue(myconnectindex);
|
||||||
|
|
||||||
if (((!System_WantGuiCapture() && (g_player[myconnectindex].ps->gm&MODE_MENU) != MODE_MENU) || ud.recstat == 2 || (g_netServer || ud.multimode > 1)) &&
|
if (((!System_WantGuiCapture() && (g_player[myconnectindex].ps->gm&MODE_MENU) != MODE_MENU) || ud.recstat == 2 || (g_netServer || ud.multimode > 1)) &&
|
||||||
(g_player[myconnectindex].ps->gm&MODE_GAME))
|
(g_player[myconnectindex].ps->gm&MODE_GAME))
|
||||||
{
|
{
|
||||||
G_MoveLoop();
|
moveloop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -894,39 +891,6 @@ MAIN_LOOP_RESTART:
|
||||||
while (1);
|
while (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int domovethings();
|
|
||||||
int32_t G_MoveLoop()
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
if (numplayers > 1)
|
|
||||||
while (predictfifoplc < g_player[myconnectindex].movefifoend) Net_DoPrediction();
|
|
||||||
|
|
||||||
Net_GetPackets();
|
|
||||||
|
|
||||||
if (numplayers < 2) bufferjitter = 0;
|
|
||||||
while (g_player[myconnectindex].movefifoend-movefifoplc > bufferjitter)
|
|
||||||
{
|
|
||||||
for(TRAVERSE_CONNECT(i))
|
|
||||||
{
|
|
||||||
if (movefifoplc == g_player[i].movefifoend) break;
|
|
||||||
}
|
|
||||||
if (i >= 0) break;
|
|
||||||
if (domovethings()) return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void GetNextInput()
|
|
||||||
{
|
|
||||||
for (bssize_t TRAVERSE_CONNECT(i))
|
|
||||||
Bmemcpy(g_player[i].input, &inputfifo[movefifoplc & (MOVEFIFOSIZ - 1)][i], sizeof(input_t));
|
|
||||||
|
|
||||||
movefifoplc++;
|
|
||||||
}
|
|
||||||
|
|
||||||
void GameInterface::FreeGameData()
|
void GameInterface::FreeGameData()
|
||||||
{
|
{
|
||||||
setmapfog(0);
|
setmapfog(0);
|
||||||
|
|
|
@ -29,8 +29,6 @@ BEGIN_DUKE_NS
|
||||||
|
|
||||||
user_defs ud;
|
user_defs ud;
|
||||||
|
|
||||||
const char *s_buildDate = "20120522";
|
|
||||||
|
|
||||||
char g_gametypeNames[MAXGAMETYPES][33]
|
char g_gametypeNames[MAXGAMETYPES][33]
|
||||||
= { "DukeMatch (Spawn)", "Cooperative Play", "DukeMatch (No Spawn)", "Team DM (Spawn)", "Team DM (No Spawn)" };
|
= { "DukeMatch (Spawn)", "Cooperative Play", "DukeMatch (No Spawn)", "Team DM (Spawn)", "Team DM (No Spawn)" };
|
||||||
|
|
||||||
|
@ -57,8 +55,6 @@ int32_t g_tripbombRadius = 3880;
|
||||||
|
|
||||||
int16_t weaponsandammosprites[15];
|
int16_t weaponsandammosprites[15];
|
||||||
|
|
||||||
char CheatKeys[2] = { sc_D, sc_N };
|
|
||||||
|
|
||||||
TileInfo tileinfo[MAXTILES]; // This is not from EDuke32.
|
TileInfo tileinfo[MAXTILES]; // This is not from EDuke32.
|
||||||
|
|
||||||
END_DUKE_NS
|
END_DUKE_NS
|
||||||
|
|
|
@ -106,8 +106,6 @@ void P_GetInput(int const playerNum)
|
||||||
|
|
||||||
localInput = {};
|
localInput = {};
|
||||||
localInput.bits = (((int32_t)g_gameQuit) << SK_GAMEQUIT);
|
localInput.bits = (((int32_t)g_gameQuit) << SK_GAMEQUIT);
|
||||||
localInput.extbits |= (1 << 7);
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -354,13 +352,6 @@ void P_GetInput(int const playerNum)
|
||||||
else if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
|
else if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
|
||||||
input.fvel = 0;
|
input.fvel = 0;
|
||||||
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Move_Forward) || (input.fvel > 0));
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Move_Backward) || (input.fvel < 0)) << 1;
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Strafe_Left) || (input.svel > 0)) << 2;
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Strafe_Right) || (input.svel < 0)) << 3;
|
|
||||||
localInput.extbits |= buttonMap.ButtonDown(gamefunc_Turn_Left)<<4;
|
|
||||||
localInput.extbits |= buttonMap.ButtonDown(gamefunc_Turn_Right)<<5;
|
|
||||||
|
|
||||||
int const movementLocked = P_CheckLockedMovement(playerNum);
|
int const movementLocked = P_CheckLockedMovement(playerNum);
|
||||||
|
|
||||||
if ((ud.scrollmode && ud.overhead_on) || (movementLocked & IL_NOTHING) == IL_NOTHING)
|
if ((ud.scrollmode && ud.overhead_on) || (movementLocked & IL_NOTHING) == IL_NOTHING)
|
||||||
|
@ -465,8 +456,6 @@ void P_GetInputMotorcycle(int playerNum)
|
||||||
|
|
||||||
localInput = {};
|
localInput = {};
|
||||||
localInput.bits = (((int32_t)g_gameQuit) << SK_GAMEQUIT);
|
localInput.bits = (((int32_t)g_gameQuit) << SK_GAMEQUIT);
|
||||||
localInput.extbits |= (1 << 7);
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -533,11 +522,6 @@ void P_GetInputMotorcycle(int playerNum)
|
||||||
if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
|
if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
|
||||||
input.fvel = 0;
|
input.fvel = 0;
|
||||||
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Move_Forward) || (input.fvel > 0));
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Move_Backward) || (input.fvel < 0)) << 1;
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Strafe_Left) || (input.svel > 0)) << 2;
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Strafe_Right) || (input.svel < 0)) << 3;
|
|
||||||
|
|
||||||
int turnAmount;
|
int turnAmount;
|
||||||
int const turn = input.q16avel / 32;
|
int const turn = input.q16avel / 32;
|
||||||
int turnLeft = buttonMap.ButtonDown(gamefunc_Turn_Left) || buttonMap.ButtonDown(gamefunc_Strafe_Left);
|
int turnLeft = buttonMap.ButtonDown(gamefunc_Turn_Left) || buttonMap.ButtonDown(gamefunc_Strafe_Left);
|
||||||
|
@ -671,8 +655,6 @@ void P_GetInputBoat(int playerNum)
|
||||||
|
|
||||||
localInput = {};
|
localInput = {};
|
||||||
localInput.bits = (((int32_t)g_gameQuit) << SK_GAMEQUIT);
|
localInput.bits = (((int32_t)g_gameQuit) << SK_GAMEQUIT);
|
||||||
localInput.extbits |= (1 << 7);
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -739,11 +721,6 @@ void P_GetInputBoat(int playerNum)
|
||||||
if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
|
if (buttonMap.ButtonDown(gamefunc_Dpad_Aiming))
|
||||||
input.fvel = 0;
|
input.fvel = 0;
|
||||||
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Move_Forward) || (input.fvel > 0));
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Move_Backward) || (input.fvel < 0)) << 1;
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Strafe_Left) || (input.svel > 0)) << 2;
|
|
||||||
localInput.extbits |= (buttonMap.ButtonDown(gamefunc_Strafe_Right) || (input.svel < 0)) << 3;
|
|
||||||
|
|
||||||
int turnAmount;
|
int turnAmount;
|
||||||
int const turn = input.q16avel / 32;
|
int const turn = input.q16avel / 32;
|
||||||
int turnLeft = buttonMap.ButtonDown(gamefunc_Turn_Left) || buttonMap.ButtonDown(gamefunc_Strafe_Left);
|
int turnLeft = buttonMap.ButtonDown(gamefunc_Turn_Left) || buttonMap.ButtonDown(gamefunc_Strafe_Left);
|
||||||
|
|
|
@ -184,20 +184,6 @@ void G_ResetTimers(uint8_t keepgtics)
|
||||||
actor[camsprite].t_data[0] = 0;
|
actor[camsprite].t_data[0] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void G_ClearFIFO(void)
|
|
||||||
{
|
|
||||||
Net_ClearFIFO();
|
|
||||||
|
|
||||||
memset(&localInput, 0, sizeof(input_t));
|
|
||||||
memset(&inputfifo, 0, sizeof(input_t) * MOVEFIFOSIZ * MAXPLAYERS);
|
|
||||||
|
|
||||||
for (bsize_t p = 0; p <= MAXPLAYERS - 1; ++p)
|
|
||||||
{
|
|
||||||
if (g_player[p].input != NULL)
|
|
||||||
Bmemset(g_player[p].input, 0, sizeof(input_t));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int G_FindLevelByFile(const char *fileName)
|
int G_FindLevelByFile(const char *fileName)
|
||||||
{
|
{
|
||||||
for (bssize_t volumeNum = 0; volumeNum < MAXVOLUMES; volumeNum++)
|
for (bssize_t volumeNum = 0; volumeNum < MAXVOLUMES; volumeNum++)
|
||||||
|
@ -444,7 +430,7 @@ int G_EnterLevel(int gameMode)
|
||||||
|
|
||||||
ud.last_level = ud.level_number+1;
|
ud.last_level = ud.level_number+1;
|
||||||
|
|
||||||
G_ClearFIFO();
|
clearfifo();
|
||||||
|
|
||||||
for (i=numinterpolations-1; i>=0; i--) bakipos[i] = *curipos[i];
|
for (i=numinterpolations-1; i>=0; i--) bakipos[i] = *curipos[i];
|
||||||
|
|
||||||
|
|
|
@ -1450,7 +1450,7 @@ static void postloadplayer(int32_t savegamep)
|
||||||
if (savegamep)
|
if (savegamep)
|
||||||
{
|
{
|
||||||
ready2send = 1;
|
ready2send = 1;
|
||||||
G_ClearFIFO();
|
clearfifo();
|
||||||
Net_WaitForEverybody();
|
Net_WaitForEverybody();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue