mirror of
https://github.com/ZDoom/raze-gles.git
synced 2024-12-30 13:21:04 +00:00
- this should be all we need from GZDoom to hook up the main loop.
This commit is contained in:
parent
1e0b8038e5
commit
367b4ce051
11 changed files with 182 additions and 123 deletions
|
@ -80,5 +80,6 @@ struct doomcom_t
|
||||||
};
|
};
|
||||||
|
|
||||||
extern doomcom_t doomcom;
|
extern doomcom_t doomcom;
|
||||||
|
extern bool netgame, multiplayer;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -92,7 +92,6 @@ static FGameTexture *conback;
|
||||||
static uint32_t conshade;
|
static uint32_t conshade;
|
||||||
static bool conline;
|
static bool conline;
|
||||||
|
|
||||||
extern int gametic;
|
|
||||||
extern bool advancedemo;
|
extern bool advancedemo;
|
||||||
|
|
||||||
extern FBaseCVar *CVars;
|
extern FBaseCVar *CVars;
|
||||||
|
|
|
@ -56,10 +56,9 @@ extern int gametic;
|
||||||
|
|
||||||
// Placeholders to make it compile.
|
// Placeholders to make it compile.
|
||||||
FILE* debugfile;
|
FILE* debugfile;
|
||||||
extern bool netgame;
|
|
||||||
bool demoplayback;
|
bool demoplayback;
|
||||||
int Net_Arbitrator;
|
int Net_Arbitrator;
|
||||||
bool playeringame[MAXPLAYERS];
|
bool playeringame[MAXPLAYERS] = { true }; // as long as network isn't working - true for the first player, false for all others.
|
||||||
bool singletics;
|
bool singletics;
|
||||||
char* startmap;
|
char* startmap;
|
||||||
int rngseed;
|
int rngseed;
|
||||||
|
@ -68,7 +67,6 @@ bool usergame;
|
||||||
void D_ReadUserInfoStrings(int, uint8_t**, bool) {}
|
void D_ReadUserInfoStrings(int, uint8_t**, bool) {}
|
||||||
void D_WriteUserInfoStrings(int, uint8_t**, bool) {}
|
void D_WriteUserInfoStrings(int, uint8_t**, bool) {}
|
||||||
FString GetPlayerName(int num);
|
FString GetPlayerName(int num);
|
||||||
void G_BuildTiccmd(ticcmd_t*) {}
|
|
||||||
|
|
||||||
//#define SIMULATEERRORS (RAND_MAX/3)
|
//#define SIMULATEERRORS (RAND_MAX/3)
|
||||||
#define SIMULATEERRORS 0
|
#define SIMULATEERRORS 0
|
||||||
|
|
|
@ -72,6 +72,9 @@ extern int ticdup;
|
||||||
extern bool nodeingame[MAXNETNODES]; // set false as nodes leave game
|
extern bool nodeingame[MAXNETNODES]; // set false as nodes leave game
|
||||||
extern bool hadlate;
|
extern bool hadlate;
|
||||||
extern uint64_t lastglobalrecvtime; // Identify the last time a packet was received.
|
extern uint64_t lastglobalrecvtime; // Identify the last time a packet was received.
|
||||||
|
extern bool playeringame[MAXPLAYERS]; // as long as network isn't working - true for the first player, false for all others.
|
||||||
|
extern ticcmd_t playercmds[MAXPLAYERS];
|
||||||
|
extern short consistancy[MAXPLAYERS][BACKUPTICS];
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -426,7 +426,6 @@ void UserConfig::ProcessOptions()
|
||||||
C_DoCommand("stat coord");
|
C_DoCommand("stat coord");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
|
@ -939,8 +938,6 @@ void app_loop()
|
||||||
{
|
{
|
||||||
I_SetFrameTime();
|
I_SetFrameTime();
|
||||||
TickSubsystems();
|
TickSubsystems();
|
||||||
twod->SetSize(screen->GetWidth(), screen->GetHeight());
|
|
||||||
twodpsp.SetSize(screen->GetWidth(), screen->GetHeight());
|
|
||||||
|
|
||||||
handleevents();
|
handleevents();
|
||||||
updatePauseStatus();
|
updatePauseStatus();
|
||||||
|
|
|
@ -13,6 +13,7 @@ extern FString currentGame;
|
||||||
extern FString LumpFilter;
|
extern FString LumpFilter;
|
||||||
class FArgs;
|
class FArgs;
|
||||||
extern bool GUICapture;
|
extern bool GUICapture;
|
||||||
|
extern bool AppActive;
|
||||||
|
|
||||||
extern FMemArena dump; // this is for memory blocks than cannot be deallocated without some huge effort. Put them in here so that they do not register on shutdown.
|
extern FMemArena dump; // this is for memory blocks than cannot be deallocated without some huge effort. Put them in here so that they do not register on shutdown.
|
||||||
|
|
||||||
|
|
|
@ -95,8 +95,11 @@ struct GameInterface
|
||||||
virtual void GetInput(InputPacket* packet) {}
|
virtual void GetInput(InputPacket* packet) {}
|
||||||
virtual void UpdateSounds() {}
|
virtual void UpdateSounds() {}
|
||||||
virtual void ErrorCleanup() {}
|
virtual void ErrorCleanup() {}
|
||||||
|
virtual void Startup() {}
|
||||||
|
virtual void DrawBackground() {}
|
||||||
virtual void Render() {}
|
virtual void Render() {}
|
||||||
virtual void Ticker() {}
|
virtual void Ticker() {}
|
||||||
|
virtual int GetPlayerChecksum(int pnum) { return 0x12345678 + pnum; }
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -160,6 +160,8 @@ int32_t handleevents(void)
|
||||||
setViewport(hud_size);
|
setViewport(hud_size);
|
||||||
setsizeneeded = false;
|
setsizeneeded = false;
|
||||||
}
|
}
|
||||||
|
twod->SetSize(screen->GetWidth(), screen->GetHeight());
|
||||||
|
twodpsp.SetSize(screen->GetWidth(), screen->GetHeight());
|
||||||
|
|
||||||
I_StartFrame();
|
I_StartFrame();
|
||||||
I_StartTic();
|
I_StartTic();
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
// For TryRunTics the following applies:
|
// For G_Ticker and TryRunTics the following applies:
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
// $Id:$
|
// $Id:$
|
||||||
|
@ -72,18 +72,22 @@
|
||||||
#include "raze_sound.h"
|
#include "raze_sound.h"
|
||||||
#include "raze_music.h"
|
#include "raze_music.h"
|
||||||
#include "vm.h"
|
#include "vm.h"
|
||||||
|
#include "gamestate.h"
|
||||||
|
#include "screenjob.h"
|
||||||
|
#include "mmulti.h"
|
||||||
|
#include "c_console.h"
|
||||||
|
#include "menu.h"
|
||||||
|
#include "uiinput.h"
|
||||||
|
#include "v_video.h"
|
||||||
|
#include "glbackend/glbackend.h"
|
||||||
|
#include "palette.h"
|
||||||
|
|
||||||
|
CVAR(Bool, vid_activeinbackground, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
||||||
|
|
||||||
// Forces playsim processing time to be consistent across frames.
|
|
||||||
// This improves interpolation for frames in between tics.
|
|
||||||
//
|
|
||||||
// With this cvar off the mods with a high playsim processing time will appear
|
|
||||||
// less smooth as the measured time used for interpolation will vary.
|
|
||||||
|
|
||||||
CVAR(Bool, r_ticstability, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
CVAR(Bool, r_ticstability, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
||||||
CVAR(Bool, cl_capfps, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
CVAR(Bool, cl_capfps, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
||||||
|
|
||||||
|
ticcmd_t playercmds[MAXPLAYERS];
|
||||||
|
|
||||||
static uint64_t stabilityticduration = 0;
|
static uint64_t stabilityticduration = 0;
|
||||||
static uint64_t stabilitystarttime = 0;
|
static uint64_t stabilitystarttime = 0;
|
||||||
|
|
||||||
|
@ -94,6 +98,158 @@ int oldentertics;
|
||||||
int gametic;
|
int gametic;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void G_BuildTiccmd(ticcmd_t* cmd)
|
||||||
|
{
|
||||||
|
gi->GetInput(&cmd->ucmd);
|
||||||
|
cmd->consistancy = consistancy[myconnectindex][(maketic / ticdup) % BACKUPTICS];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void G_Ticker()
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
handleevents();
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
// Todo: Migrate state changes to here instead of doing them ad-hoc
|
||||||
|
while (gameaction != ga_nothing)
|
||||||
|
{
|
||||||
|
if (gameaction == ga_newgame2)
|
||||||
|
{
|
||||||
|
gameaction = ga_newgame;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (gameaction)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
C_AdjustBottom();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// get commands, check consistancy, and build new consistancy check
|
||||||
|
int buf = (gametic / ticdup) % BACKUPTICS;
|
||||||
|
|
||||||
|
for (i = 0; i < MAXPLAYERS; i++)
|
||||||
|
{
|
||||||
|
if (playeringame[i])
|
||||||
|
{
|
||||||
|
ticcmd_t* cmd = &playercmds[i];
|
||||||
|
ticcmd_t* newcmd = &netcmds[i][buf];
|
||||||
|
|
||||||
|
if ((gametic % ticdup) == 0)
|
||||||
|
{
|
||||||
|
RunNetSpecs(i, buf);
|
||||||
|
}
|
||||||
|
#if 0
|
||||||
|
if (demorecording)
|
||||||
|
{
|
||||||
|
G_WriteDemoTiccmd(newcmd, i, buf);
|
||||||
|
}
|
||||||
|
if (demoplayback)
|
||||||
|
{
|
||||||
|
G_ReadDemoTiccmd(cmd, i);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
*cmd = *newcmd;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (netgame && /*!demoplayback &&*/ (gametic % ticdup) == 0)
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
//players[i].inconsistant = 0;
|
||||||
|
if (gametic > BACKUPTICS * ticdup && consistancy[i][buf] != cmd->consistancy)
|
||||||
|
{
|
||||||
|
players[i].inconsistant = gametic - BACKUPTICS * ticdup;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
consistancy[i][buf] = gi->GetPlayerChecksum(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
C_RunDelayedCommands();
|
||||||
|
|
||||||
|
switch (gamestate)
|
||||||
|
{
|
||||||
|
default:
|
||||||
|
case GS_STARTUP:
|
||||||
|
gi->Startup();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GS_MENUSCREEN:
|
||||||
|
case GS_FULLCONSOLE:
|
||||||
|
gi->DrawBackground();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GS_LEVEL:
|
||||||
|
gi->Ticker();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GS_INTERMISSION:
|
||||||
|
case GS_INTRO:
|
||||||
|
RunScreenJobFrame();
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//==========================================================================
|
||||||
|
//
|
||||||
|
// D_Display
|
||||||
|
//
|
||||||
|
// Draw current display, possibly wiping it from the previous
|
||||||
|
//
|
||||||
|
//==========================================================================
|
||||||
|
|
||||||
|
void D_Display()
|
||||||
|
{
|
||||||
|
FGameTexture* wipe = nullptr;
|
||||||
|
|
||||||
|
if (screen == NULL)
|
||||||
|
return; // for comparative timing / profiling
|
||||||
|
|
||||||
|
if (!AppActive && (screen->IsFullscreen() || !vid_activeinbackground))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
screen->FrameTime = I_msTimeFS();
|
||||||
|
screen->BeginFrame();
|
||||||
|
twod->ClearClipRect();
|
||||||
|
if ((gamestate == GS_LEVEL) && gametic != 0)
|
||||||
|
{
|
||||||
|
// [ZZ] execute event hook that we just started the frame
|
||||||
|
//E_RenderFrame();
|
||||||
|
//
|
||||||
|
gi->Render();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Draw overlay elements to the 2D drawer
|
||||||
|
NetUpdate(); // send out any new accumulation
|
||||||
|
CT_Drawer();
|
||||||
|
C_DrawConsole();
|
||||||
|
M_Drawer();
|
||||||
|
FStat::PrintStat(twod);
|
||||||
|
|
||||||
|
// Handle the final 2D overlays.
|
||||||
|
if (gamestate == GS_LEVEL) DrawFullscreenBlends();
|
||||||
|
DrawRateStuff();
|
||||||
|
|
||||||
|
videoShowFrame(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Forces playsim processing time to be consistent across frames.
|
||||||
|
// This improves interpolation for frames in between tics.
|
||||||
|
//
|
||||||
|
// With this cvar off the mods with a high playsim processing time will appear
|
||||||
|
// less smooth as the measured time used for interpolation will vary.
|
||||||
|
|
||||||
static void TicStabilityWait()
|
static void TicStabilityWait()
|
||||||
{
|
{
|
||||||
using namespace std::chrono;
|
using namespace std::chrono;
|
||||||
|
@ -278,7 +434,7 @@ void TryRunTics (void)
|
||||||
//if (debugfile) fprintf (debugfile, "run tic %d\n", gametic);
|
//if (debugfile) fprintf (debugfile, "run tic %d\n", gametic);
|
||||||
C_Ticker ();
|
C_Ticker ();
|
||||||
M_Ticker ();
|
M_Ticker ();
|
||||||
gi->Ticker();
|
G_Ticker();
|
||||||
gametic++;
|
gametic++;
|
||||||
|
|
||||||
NetUpdate (); // check for new console commands
|
NetUpdate (); // check for new console commands
|
||||||
|
@ -299,10 +455,7 @@ void TryRunTics (void)
|
||||||
|
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
//
|
//
|
||||||
// D_DoomLoop
|
// MainLoop - will never return aside from exceptions being thrown.
|
||||||
//
|
|
||||||
// Manages timing and IO, calls all ?_Responder, ?_Ticker, and ?_Drawer,
|
|
||||||
// calls I_GetTime, I_StartFrame, and I_StartTic
|
|
||||||
//
|
//
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
|
|
||||||
|
@ -313,8 +466,6 @@ void MainLoop ()
|
||||||
// Clamp the timer to TICRATE until the playloop has been entered.
|
// Clamp the timer to TICRATE until the playloop has been entered.
|
||||||
r_NoInterpolate = true;
|
r_NoInterpolate = true;
|
||||||
|
|
||||||
//vid_cursor.Callback();
|
|
||||||
|
|
||||||
for (;;)
|
for (;;)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
@ -330,7 +481,8 @@ void MainLoop ()
|
||||||
TryRunTics (); // will run at least one tic
|
TryRunTics (); // will run at least one tic
|
||||||
// Update display, next frame, with current state.
|
// Update display, next frame, with current state.
|
||||||
I_StartTic ();
|
I_StartTic ();
|
||||||
gi->Render();
|
|
||||||
|
D_Display();
|
||||||
Mus_UpdateMusic(); // must be at the end.
|
Mus_UpdateMusic(); // must be at the end.
|
||||||
}
|
}
|
||||||
catch (CRecoverableError &error)
|
catch (CRecoverableError &error)
|
||||||
|
@ -352,102 +504,3 @@ void MainLoop ()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
// The one and only main loop in the entire engine. Yay!
|
|
||||||
//
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
#if 0
|
|
||||||
|
|
||||||
void _TickSubsystems()
|
|
||||||
{
|
|
||||||
// run these on an independent timer until we got something working for the games.
|
|
||||||
static const uint64_t tickInterval = 1'000'000'000 / 30;
|
|
||||||
static uint64_t nexttick = 0;
|
|
||||||
|
|
||||||
auto nowtick = I_nsTime();
|
|
||||||
if (nexttick == 0) nexttick = nowtick;
|
|
||||||
int cnt = 0;
|
|
||||||
while (nexttick <= nowtick && cnt < 5)
|
|
||||||
{
|
|
||||||
nexttick += tickInterval;
|
|
||||||
C_Ticker();
|
|
||||||
M_Ticker();
|
|
||||||
C_RunDelayedCommands();
|
|
||||||
cnt++;
|
|
||||||
}
|
|
||||||
// If this took too long the engine was most likely suspended so recalibrate the timer.
|
|
||||||
// Perfect precision is not needed here.
|
|
||||||
if (cnt == 5) nexttick = nowtick + tickInterval;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _updatePauseStatus()
|
|
||||||
{
|
|
||||||
// This must go through the network in multiplayer games.
|
|
||||||
if (M_Active() || System_WantGuiCapture())
|
|
||||||
{
|
|
||||||
paused = 1;
|
|
||||||
}
|
|
||||||
else if (!M_Active() || !System_WantGuiCapture())
|
|
||||||
{
|
|
||||||
if (!pausedWithKey)
|
|
||||||
{
|
|
||||||
paused = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sendPause)
|
|
||||||
{
|
|
||||||
sendPause = false;
|
|
||||||
paused = pausedWithKey ? 0 : 2;
|
|
||||||
pausedWithKey = !!paused;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
paused ? S_PauseSound(!pausedWithKey, !paused) : S_ResumeSound(paused);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void _app_loop()
|
|
||||||
{
|
|
||||||
gamestate = GS_STARTUP;
|
|
||||||
|
|
||||||
while (true)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
I_SetFrameTime();
|
|
||||||
TickSubsystems();
|
|
||||||
twod->SetSize(screen->GetWidth(), screen->GetHeight());
|
|
||||||
twodpsp.SetSize(screen->GetWidth(), screen->GetHeight());
|
|
||||||
|
|
||||||
handleevents();
|
|
||||||
updatePauseStatus();
|
|
||||||
D_ProcessEvents();
|
|
||||||
|
|
||||||
gi->RunGameFrame();
|
|
||||||
|
|
||||||
// Draw overlay elements to the 2D drawer
|
|
||||||
FStat::PrintStat(twod);
|
|
||||||
CT_Drawer();
|
|
||||||
C_DrawConsole();
|
|
||||||
M_Drawer();
|
|
||||||
|
|
||||||
// Handle the final 2D overlays.
|
|
||||||
if (gamestate == GS_LEVEL) DrawFullscreenBlends();
|
|
||||||
DrawRateStuff();
|
|
||||||
|
|
||||||
|
|
||||||
videoShowFrame(0);
|
|
||||||
videoSetBrightness(0); // immediately reset this so that the value doesn't stick around in the backend.
|
|
||||||
}
|
|
||||||
catch (CRecoverableError& err)
|
|
||||||
{
|
|
||||||
C_FullConsole();
|
|
||||||
Printf(TEXTCOLOR_RED "%s\n", err.what());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -186,5 +186,6 @@ extern glblend_t glblend[MAXBLENDTABS];
|
||||||
FRenderStyle GetRenderStyle(int blend, int def);
|
FRenderStyle GetRenderStyle(int blend, int def);
|
||||||
extern void SetRenderStyleFromBlend(uint8_t enable, uint8_t blend, uint8_t def);
|
extern void SetRenderStyleFromBlend(uint8_t enable, uint8_t blend, uint8_t def);
|
||||||
float GetAlphaFromBlend(uint32_t maskprops, uint32_t blend);
|
float GetAlphaFromBlend(uint32_t maskprops, uint32_t blend);
|
||||||
|
void DrawFullscreenBlends();
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -495,6 +495,7 @@ void videoShowFrame(int32_t w)
|
||||||
screen->SetSceneRenderTarget(useSSAO);
|
screen->SetSceneRenderTarget(useSSAO);
|
||||||
twodpsp.Clear();
|
twodpsp.Clear();
|
||||||
twod->Clear();
|
twod->Clear();
|
||||||
|
videoSetBrightness(0); // immediately reset this after rendering so that the value doesn't stick around in the backend.
|
||||||
}
|
}
|
||||||
|
|
||||||
TMap<int64_t, bool> cachemap;
|
TMap<int64_t, bool> cachemap;
|
||||||
|
|
Loading…
Reference in a new issue