- Blood code cleanup

deleting blocks of unused code, in particular some networking leftovers.
Also moving a few functions around
This commit is contained in:
Christoph Oelckers 2020-09-01 19:49:05 +02:00
parent 6726c19f9c
commit 31fc39b051
18 changed files with 107 additions and 378 deletions

View file

@ -136,6 +136,52 @@ void AddCmdDefine(char *text, int value)
nCmdDefines++; nCmdDefines++;
} }
static void SplitPath(const char *pzPath, char *pzDirectory, char *pzFile, char *pzType)
{
int const nLength = strlen(pzPath);
const char *pDirectory = pzPath+nLength;
const char *pDot = NULL;
for (int i = nLength-1; i >= 0; i--)
{
if (pzPath[i] == '/' || pzPath[i] == '\\')
{
strncpy(pzDirectory, pzPath, i);
pzDirectory[i] = 0;
if (!pDot)
{
strcpy(pzFile, pzPath+i+1);
strcpy(pzType, "");
}
else
{
strncpy(pzFile, pzPath+i+1, pDot-(pzPath+i+1));
pzFile[pDot-(pzPath+i+1)] = 0;
strcpy(pzType, pDot+1);
}
return;
}
else if (pzPath[i] == '.')
{
pDot = pzPath+i;
}
}
strcpy(pzDirectory, "/");
if (!pDot)
{
strcpy(pzFile, pzPath);
strcpy(pzType, "");
}
else
{
strncpy(pzFile, pzPath, pDot-pzPath);
pzFile[pDot-pzPath] = 0;
strcpy(pzType, pDot+1);
}
}
// 174 bytes // 174 bytes
struct RFS struct RFS
{ {

View file

@ -110,8 +110,6 @@ void StartLevel(MapRecord *level)
EndLevel(); EndLevel();
gInput = {}; gInput = {};
gStartNewGame = nullptr; gStartNewGame = nullptr;
ready2send = 0;
netWaitForEveryone(0);
currentLevel = level; currentLevel = level;
if (gGameOptions.nGameType == 0) if (gGameOptions.nGameType == 0)
@ -255,11 +253,9 @@ void StartLevel(MapRecord *level)
M_ClearMenus(); M_ClearMenus();
// viewSetMessage(""); // viewSetMessage("");
viewSetErrorMessage(""); viewSetErrorMessage("");
netWaitForEveryone(0);
gameclock = 0; gameclock = 0;
lastTic = -1; lastTic = -1;
paused = 0; paused = 0;
ready2send = 1;
levelTryPlayMusic(); levelTryPlayMusic();
} }
@ -281,31 +277,6 @@ void ProcessFrame(void)
} }
gNetFifoTail++; gNetFifoTail++;
#if 0
for (int i = connecthead; i >= 0; i = connectpoint2[i])
{
if (gPlayer[i].input.syncFlags.quit)
{
gPlayer[i].input.syncFlags.quit = 0;
netBroadcastPlayerLogoff(i);
if (i == myconnectindex)
{
// netBroadcastMyLogoff(gQuitRequest == 2);
gQuitGame = true;
gRestartGame = gQuitRequest == 2;
netDeinitialize();
netResetToSinglePlayer();
return;
}
}
if (gPlayer[i].input.syncFlags.restart)
{
gPlayer[i].input.syncFlags.restart = 0;
levelRestart();
return;
}
}
#endif
// This is single player only. // This is single player only.
if (gameRestart) if (gameRestart)
{ {
@ -364,18 +335,6 @@ void ProcessFrame(void)
gFrameClock += 4; gFrameClock += 4;
if ((gGameOptions.uGameFlags&1) != 0 && !gStartNewGame) if ((gGameOptions.uGameFlags&1) != 0 && !gStartNewGame)
{ {
ready2send = 0;
#if 0
if (gNetPlayers > 1 && gNetMode == NETWORK_SERVER && gPacketMode == PACKETMODE_1 && myconnectindex == connecthead)
{
while (gNetFifoMasterTail < gNetFifoTail)
{
netGetPackets();
h andleevents();
netMasterUpdate();
}
}
#endif
seqKillAll(); seqKillAll();
if (gGameOptions.uGameFlags&2) if (gGameOptions.uGameFlags&2)
{ {
@ -414,11 +373,6 @@ void ProcessFrame(void)
void ParseOptions(void)
{
}
void ReadAllRFS(); void ReadAllRFS();
void GameInterface::app_init() void GameInterface::app_init()
@ -458,7 +412,6 @@ void GameInterface::app_init()
Printf(PRINT_NONOTIFY, "Initializing weapon animations\n"); Printf(PRINT_NONOTIFY, "Initializing weapon animations\n");
WeaponInit(); WeaponInit();
LoadSaveSetup(); LoadSaveSetup();
LoadSavedInfo();
Printf(PRINT_NONOTIFY, "Initializing network users\n"); Printf(PRINT_NONOTIFY, "Initializing network users\n");
netInitialize(true); netInitialize(true);
@ -479,19 +432,7 @@ static void gameInit()
gViewIndex = myconnectindex; gViewIndex = myconnectindex;
gMe = gView = &gPlayer[myconnectindex]; gMe = gView = &gPlayer[myconnectindex];
netBroadcastPlayerInfo(myconnectindex); netBroadcastPlayerInfo(myconnectindex);
#if 0
Printf("Waiting for network players!\n");
netWaitForEveryone(0);
if (gRestartGame)
{
// Network error
gQuitGame = false;
gRestartGame = false;
netDeinitialize();
netResetToSinglePlayer();
goto RESTART;
}
#endif
UpdateNetworkMenus(); UpdateNetworkMenus();
gQuitGame = 0; gQuitGame = 0;
gRestartGame = 0; gRestartGame = 0;
@ -510,8 +451,8 @@ static void gameTicker()
{ {
viewUpdatePrediction(&gFifoInput[gPredictTail & 255][myconnectindex]); viewUpdatePrediction(&gFifoInput[gPredictTail & 255][myconnectindex]);
} }
if (numplayers == 1)
gBufferJitter = 0; int gBufferJitter = 0;
int const currentTic = I_GetTime(); int const currentTic = I_GetTime();
gameclock = I_GetBuildTime(); gameclock = I_GetBuildTime();
@ -519,7 +460,7 @@ static void gameTicker()
gameupdatetime.Reset(); gameupdatetime.Reset();
gameupdatetime.Clock(); gameupdatetime.Clock();
while (currentTic - lastTic >= 1 && ready2send) while (currentTic - lastTic >= 1)
{ {
gNetInput = gInput; gNetInput = gInput;
gInput = {}; gInput = {};
@ -544,8 +485,6 @@ static void gameTicker()
videoClearScreen(0); videoClearScreen(0);
else else
{ {
netCheckSync();
drawtime.Reset(); drawtime.Reset();
drawtime.Clock(); drawtime.Clock();
viewDrawScreen(); viewDrawScreen();
@ -557,10 +496,6 @@ static void drawBackground()
{ {
twod->ClearScreen(); twod->ClearScreen();
DrawTexture(twod, tileGetTexture(2518, true), 0, 0, DTA_FullscreenEx, FSMode_ScaleToFit43, TAG_DONE); DrawTexture(twod, tileGetTexture(2518, true), 0, 0, DTA_FullscreenEx, FSMode_ScaleToFit43, TAG_DONE);
#if 0
if (gQuitRequest && !gQuitGame)
netBroadcastMyLogoff(gQuitRequest == 2);
#endif
} }
static void commonTicker() static void commonTicker()
@ -617,7 +552,6 @@ static void commonTicker()
void GameInterface::RunGameFrame() void GameInterface::RunGameFrame()
{ {
commonTicker(); commonTicker();
netGetPackets();
ctrlGetInput(); ctrlGetInput();
switch (gamestate) switch (gamestate)
@ -661,26 +595,10 @@ void GameInterface::RunGameFrame()
} }
} }
bool DemoRecordStatus(void) {
return false;
}
bool VanillaMode() {
return false;
}
int sndTryPlaySpecialMusic(int nMusic)
{
if (Mus_Play(nullptr, quoteMgr.GetQuote(nMusic), true))
{
return 0;
}
return 1;
}
void sndPlaySpecialMusicOrNothing(int nMusic) void sndPlaySpecialMusicOrNothing(int nMusic)
{ {
if (sndTryPlaySpecialMusic(nMusic)) if (!Mus_Play(nullptr, quoteMgr.GetQuote(nMusic), true))
{ {
Mus_Stop(); Mus_Stop();
} }
@ -690,7 +608,6 @@ extern IniFile* BloodINI;
void GameInterface::FreeGameData() void GameInterface::FreeGameData()
{ {
if (BloodINI) delete BloodINI; if (BloodINI) delete BloodINI;
netDeinitialize();
} }
ReservedSpace GameInterface::GetReservedScreenSpace(int viewsize) ReservedSpace GameInterface::GetReservedScreenSpace(int viewsize)

View file

@ -60,9 +60,16 @@ void PreloadCache(void);
void StartLevel(MapRecord *gameOptions); void StartLevel(MapRecord *gameOptions);
void ProcessFrame(void); void ProcessFrame(void);
void ScanINIFiles(void); void ScanINIFiles(void);
bool DemoRecordStatus(void);
bool VanillaMode(void); inline bool DemoRecordStatus(void)
int sndTryPlaySpecialMusic(int nMusic); {
return false;
}
inline bool VanillaMode()
{
return false;
}
void sndPlaySpecialMusicOrNothing(int nMusic); void sndPlaySpecialMusicOrNothing(int nMusic);
struct GameInterface : ::GameInterface struct GameInterface : ::GameInterface

View file

@ -44,21 +44,8 @@ bool bSilentAim = false;
int iTurnCount = 0; int iTurnCount = 0;
void ctrlInit(void)
{
}
void ctrlTerm(void)
{
}
int32_t mouseyaxismode = -1; int32_t mouseyaxismode = -1;
int32_t GetTime(void)
{
return gameclock;
}
fixed_t gViewLook, gViewAngle; fixed_t gViewLook, gViewAngle;
float gViewAngleAdjust; float gViewAngleAdjust;
float gViewLookAdjust; float gViewLookAdjust;

View file

@ -34,7 +34,6 @@ extern float gViewAngleAdjust;
extern float gViewLookAdjust; extern float gViewLookAdjust;
extern int gViewLookRecenter; extern int gViewLookRecenter;
void ctrlInit();
void ctrlGetInput(); void ctrlGetInput();
END_BLD_NS END_BLD_NS

View file

@ -42,6 +42,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "gstrings.h" #include "gstrings.h"
#include "gamestate.h" #include "gamestate.h"
#include "raze_sound.h" #include "raze_sound.h"
#include "d_net.h"
BEGIN_BLD_NS BEGIN_BLD_NS
@ -120,20 +121,9 @@ void CEndGameMgr::Draw(void)
void CEndGameMgr::ProcessKeys(void) void CEndGameMgr::ProcessKeys(void)
{ {
//if (dword_28E3D4 == 1)
//{
// if (gGameOptions.gameType >= 0 || numplayers > 1)
// netWaitForEveryone(0);
// Finish();
//}
//else
{
if (!inputState.CheckAllInput()) if (!inputState.CheckAllInput())
return; return;
if (gGameOptions.nGameType > 0 || numplayers > 1)
netWaitForEveryone(0);
Finish(); Finish();
}
} }
extern void EndLevel(void); extern void EndLevel(void);
@ -148,13 +138,11 @@ void CEndGameMgr::Setup(void)
sndStartSample(268, 128, -1, false); sndStartSample(268, 128, -1, false);
} }
extern int gInitialNetPlayers;
void CEndGameMgr::Finish(void) void CEndGameMgr::Finish(void)
{ {
int ep = volfromlevelnum(currentLevel->levelNumber); int ep = volfromlevelnum(currentLevel->levelNumber);
gStartNewGame = FindMapByLevelNum(levelnum(ep, gNextLevel)); gStartNewGame = FindMapByLevelNum(levelnum(ep, gNextLevel));
gInitialNetPlayers = numplayers;
soundEngine->StopAllChannels(); soundEngine->StopAllChannels();
at0 = 0; at0 = 0;
} }
@ -211,13 +199,13 @@ void CKillMgr::Draw(void)
viewDrawText(3, GStrings("NAME"), 100, 35, -128, 0, 0, 1); viewDrawText(3, GStrings("NAME"), 100, 35, -128, 0, 0, 1);
viewDrawText(3, GStrings("FRAGS"), 210, 35, -128, 0, 0, 1); viewDrawText(3, GStrings("FRAGS"), 210, 35, -128, 0, 0, 1);
int nStart = 0; int nStart = 0;
int nEnd = gInitialNetPlayers; int nEnd = kMaxPlayers;
//if (dword_28E3D4 == 1) //if (dword_28E3D4 == 1)
//{ //{
// nStart++; // nStart++;
// nEnd++; // nEnd++;
//} //}
for (int i = nStart; i < nEnd; i++) for (int i = nStart; i < nEnd; i++) if (playeringame[i])
{ {
sprintf(pBuffer, "%-2d", i); sprintf(pBuffer, "%-2d", i);
viewDrawText(3, pBuffer, 85, 50+8*i, -128, 0, 0, 1); viewDrawText(3, pBuffer, 85, 50+8*i, -128, 0, 0, 1);

View file

@ -35,6 +35,45 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_BLD_NS BEGIN_BLD_NS
static void *ResReadLine(char *buffer, unsigned int nBytes, void **pRes)
{
unsigned int i;
char ch;
if (!pRes || !*pRes || *((char*)*pRes) == 0)
return NULL;
for (i = 0; i < nBytes; i++)
{
ch = *((char*)*pRes);
if(ch == 0 || ch == '\n')
break;
buffer[i] = ch;
*pRes = ((char*)*pRes)+1;
}
if (*((char*)*pRes) == '\n' && i < nBytes)
{
ch = *((char*)*pRes);
buffer[i] = ch;
*pRes = ((char*)*pRes)+1;
i++;
}
else
{
while (true)
{
ch = *((char*)*pRes);
if (ch == 0 || ch == '\n')
break;
*pRes = ((char*)*pRes)+1;
}
if (*((char*)*pRes) == '\n')
*pRes = ((char*)*pRes)+1;
}
if (i < nBytes)
buffer[i] = 0;
return *pRes;
}
IniFile::IniFile(const char *fileName) IniFile::IniFile(const char *fileName)
{ {

View file

@ -58,7 +58,6 @@ int gNextLevel; // fixme: let this contain a full level number.
int gLevelTime; int gLevelTime;
char BloodIniFile[BMAX_PATH] = "BLOOD.INI"; char BloodIniFile[BMAX_PATH] = "BLOOD.INI";
char BloodIniPre[BMAX_PATH];
bool bINIOverride = false; bool bINIOverride = false;
IniFile *BloodINI; IniFile *BloodINI;
@ -69,8 +68,6 @@ void levelInitINI(const char *pzIni)
ThrowError("Initialization: %s does not exist", pzIni); ThrowError("Initialization: %s does not exist", pzIni);
BloodINI = new IniFile(pzIni); BloodINI = new IniFile(pzIni);
Bstrncpy(BloodIniFile, pzIni, BMAX_PATH); Bstrncpy(BloodIniFile, pzIni, BMAX_PATH);
Bstrncpy(BloodIniPre, pzIni, BMAX_PATH);
ChangeExtension(BloodIniPre, "");
} }

View file

@ -81,7 +81,6 @@ extern GAMEOPTIONS gSingleGameOptions;
extern GAMEOPTIONS gGameOptions; extern GAMEOPTIONS gGameOptions;
extern int gSkill; extern int gSkill;
extern char BloodIniFile[]; extern char BloodIniFile[];
extern char BloodIniPre[];
extern bool bINIOverride; extern bool bINIOverride;
extern int gEpisodeCount; extern int gEpisodeCount;
extern int gNextLevel; extern int gNextLevel;

View file

@ -501,31 +501,17 @@ bool GameInterface::LoadGame(FSaveGameNode* node)
if (!bVanilla && !gMe->packSlots[1].isActive) // if diving suit is not active, turn off reverb sound effect if (!bVanilla && !gMe->packSlots[1].isActive) // if diving suit is not active, turn off reverb sound effect
sfxSetReverb(0); sfxSetReverb(0);
ambInit(); ambInit();
memset(myMinLag, 0, sizeof(myMinLag));
otherMinLag = 0;
myMaxLag = 0;
gNetFifoTail = 0; gNetFifoTail = 0;
memset(gNetFifoHead, 0, sizeof(gNetFifoHead)); memset(gNetFifoHead, 0, sizeof(gNetFifoHead));
gPredictTail = 0; gPredictTail = 0;
gNetFifoMasterTail = 0;
memset(gFifoInput, 0, sizeof(gFifoInput)); memset(gFifoInput, 0, sizeof(gFifoInput));
gSendCheckTail = 0;
gCheckTail = 0;
gBufferJitter = 0;
bOutOfSync = 0;
for (int i = 0; i < gNetPlayers; i++) for (int i = 0; i < gNetPlayers; i++)
playerSetRace(&gPlayer[i], gPlayer[i].lifeMode); playerSetRace(&gPlayer[i], gPlayer[i].lifeMode);
viewSetErrorMessage(""); viewSetErrorMessage("");
if (gamestate != GS_LEVEL)
{
netWaitForEveryone(0);
memset(gPlayerReady, 0, sizeof(gPlayerReady));
}
gFrameCount = 0; gFrameCount = 0;
gameclock = 0; gameclock = 0;
lastTic = -1; lastTic = -1;
paused = 0; paused = 0;
ready2send = 1;
gamestate = GS_LEVEL; gamestate = GS_LEVEL;
bVanilla = false; bVanilla = false;
@ -762,14 +748,6 @@ void MyLoadSave::Save(void)
Write(skyInfo, sizeof(*skyInfo)); Write(skyInfo, sizeof(*skyInfo));
} }
void LoadSavedInfo(void)
{
}
void UpdateSavedInfo(int nSlot)
{
}
static MyLoadSave *myLoadSave; static MyLoadSave *myLoadSave;

View file

@ -45,8 +45,6 @@ public:
static void SaveGame(FSavegameNode*); static void SaveGame(FSavegameNode*);
}; };
void UpdateSavedInfo(int nSlot);
void LoadSavedInfo(void);
void LoadSaveSetup(void); void LoadSaveSetup(void);
END_BLD_NS END_BLD_NS

View file

@ -50,12 +50,9 @@ MIRROR mirror[16];
void InitMirrors(void) void InitMirrors(void)
{ {
#ifdef USE_OPENGL
r_rortexture = 4080; r_rortexture = 4080;
r_rortexturerange = 16; r_rortexturerange = 16;
#endif
mirrorcnt = 0; mirrorcnt = 0;
tileDelete(504); tileDelete(504);
@ -342,9 +339,7 @@ void DrawMirrors(int x, int y, int z, fixed_t a, fixed_t horiz, int smooth, int
{ {
renderPrepareMirror(x,y,z,a,horiz,nWall,&cx,&cy,&ca); renderPrepareMirror(x,y,z,a,horiz,nWall,&cx,&cy,&ca);
} }
yax_preparedrawrooms();
int32_t didmirror = renderDrawRoomsQ16(cx, cy, z, ca,horiz,mirrorsector|MAXSECTORS); int32_t didmirror = renderDrawRoomsQ16(cx, cy, z, ca,horiz,mirrorsector|MAXSECTORS);
yax_drawrooms(viewProcessSprites, mirrorsector, didmirror, smooth);
viewProcessSprites(cx,cy,z,FixedToInt(ca),smooth); viewProcessSprites(cx,cy,z,FixedToInt(ca),smooth);
renderDrawMasks(); renderDrawMasks();
if (GetWallType(nWall) != kWallStack) if (GetWallType(nWall) != kWallStack)
@ -357,9 +352,6 @@ void DrawMirrors(int x, int y, int z, fixed_t a, fixed_t horiz, int smooth, int
} }
case 1: case 1:
{ {
#ifdef USE_OPENGL
r_rorphase = 1;
#endif
int nSector = mirror[i].at4; int nSector = mirror[i].at4;
int bakCstat; int bakCstat;
if (viewPlayer >= 0) if (viewPlayer >= 0)
@ -374,9 +366,7 @@ void DrawMirrors(int x, int y, int z, fixed_t a, fixed_t horiz, int smooth, int
gPlayer[viewPlayer].pSprite->cstat |= 514; gPlayer[viewPlayer].pSprite->cstat |= 514;
} }
} }
yax_preparedrawrooms();
renderDrawRoomsQ16(x+mirror[i].at8, y+mirror[i].atc, z+mirror[i].at10, a, horiz, nSector|MAXSECTORS); renderDrawRoomsQ16(x+mirror[i].at8, y+mirror[i].atc, z+mirror[i].at10, a, horiz, nSector|MAXSECTORS);
yax_drawrooms(viewProcessSprites, nSector, 0, smooth);
viewProcessSprites(x+mirror[i].at8, y+mirror[i].atc, z+mirror[i].at10, FixedToInt(a), smooth); viewProcessSprites(x+mirror[i].at8, y+mirror[i].atc, z+mirror[i].at10, FixedToInt(a), smooth);
short fstat = sector[nSector].floorstat; short fstat = sector[nSector].floorstat;
sector[nSector].floorstat |= 1; sector[nSector].floorstat |= 1;
@ -388,16 +378,10 @@ void DrawMirrors(int x, int y, int z, fixed_t a, fixed_t horiz, int smooth, int
{ {
gPlayer[viewPlayer].pSprite->cstat = bakCstat; gPlayer[viewPlayer].pSprite->cstat = bakCstat;
} }
#ifdef USE_OPENGL
r_rorphase = 0;
#endif
return; return;
} }
case 2: case 2:
{ {
#ifdef USE_OPENGL
r_rorphase = 1;
#endif
int nSector = mirror[i].at4; int nSector = mirror[i].at4;
int bakCstat; int bakCstat;
if (viewPlayer >= 0) if (viewPlayer >= 0)
@ -426,9 +410,7 @@ void DrawMirrors(int x, int y, int z, fixed_t a, fixed_t horiz, int smooth, int
{ {
gPlayer[viewPlayer].pSprite->cstat = bakCstat; gPlayer[viewPlayer].pSprite->cstat = bakCstat;
} }
#ifdef USE_OPENGL
r_rorphase = 0;
#endif
return; return;
} }
} }

View file

@ -30,44 +30,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_BLD_NS BEGIN_BLD_NS
void *ResReadLine(char *buffer, unsigned int nBytes, void **pRes)
{
unsigned int i;
char ch;
if (!pRes || !*pRes || *((char*)*pRes) == 0)
return NULL;
for (i = 0; i < nBytes; i++)
{
ch = *((char*)*pRes);
if(ch == 0 || ch == '\n')
break;
buffer[i] = ch;
*pRes = ((char*)*pRes)+1;
}
if (*((char*)*pRes) == '\n' && i < nBytes)
{
ch = *((char*)*pRes);
buffer[i] = ch;
*pRes = ((char*)*pRes)+1;
i++;
}
else
{
while (true)
{
ch = *((char*)*pRes);
if (ch == 0 || ch == '\n')
break;
*pRes = ((char*)*pRes)+1;
}
if (*((char*)*pRes) == '\n')
*pRes = ((char*)*pRes)+1;
}
if (i < nBytes)
buffer[i] = 0;
return *pRes;
}
unsigned int randSeed = 1; unsigned int randSeed = 1;
unsigned int qrand(void) unsigned int qrand(void)
@ -92,75 +54,5 @@ void wsrand(int seed)
wRandSeed = seed; wRandSeed = seed;
} }
void ChangeExtension(char *pzFile, const char *pzExt)
{
#if 0
char drive[BMAX_PATH];
char dir[BMAX_PATH];
char filename[BMAX_PATH];
_splitpath(pzFile, drive, dir, filename, NULL);
_makepath(pzFile, drive, dir, filename, pzExt);
#else
int const nLength = Bstrlen(pzFile);
char * pDot = pzFile+nLength;
for (int i = nLength-1; i >= 0; i--)
{
if (pzFile[i] == '/' || pzFile[i] == '\\')
break;
if (pzFile[i] == '.')
{
pDot = pzFile+i;
break;
}
}
*pDot = '\0';
Bstrcat(pDot, pzExt);
#endif
}
void SplitPath(const char *pzPath, char *pzDirectory, char *pzFile, char *pzType)
{
int const nLength = Bstrlen(pzPath);
const char *pDirectory = pzPath+nLength;
const char *pDot = NULL;
for (int i = nLength-1; i >= 0; i--)
{
if (pzPath[i] == '/' || pzPath[i] == '\\')
{
Bstrncpy(pzDirectory, pzPath, i);
pzDirectory[i] = 0;
if (!pDot)
{
Bstrcpy(pzFile, pzPath+i+1);
Bstrcpy(pzType, "");
}
else
{
Bstrncpy(pzFile, pzPath+i+1, pDot-(pzPath+i+1));
pzFile[pDot-(pzPath+i+1)] = 0;
Bstrcpy(pzType, pDot+1);
}
return;
}
else if (pzPath[i] == '.')
{
pDot = pzPath+i;
}
}
Bstrcpy(pzDirectory, "/");
if (!pDot)
{
Bstrcpy(pzFile, pzPath);
Bstrcpy(pzType, "");
}
else
{
Bstrncpy(pzFile, pzPath, pDot-pzPath);
pzFile[pDot-pzPath] = 0;
Bstrcpy(pzType, pDot+1);
}
}
END_BLD_NS END_BLD_NS

View file

@ -28,12 +28,9 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_BLD_NS BEGIN_BLD_NS
void playlogos(); void playlogos();
void *ResReadLine(char *buffer, unsigned int nBytes, void **pRes);
unsigned int qrand(void); unsigned int qrand(void);
int wrand(void); int wrand(void);
void wsrand(int); void wsrand(int);
void ChangeExtension(char *pzFile, const char *pzExt);
void SplitPath(const char *pzPath, char *pzDirectory, char *pzFile, char *pzType);
void FireInit(void); void FireInit(void);
void FireProcess(void); void FireProcess(void);
void UpdateNetworkMenus(void); void UpdateNetworkMenus(void);

View file

@ -39,39 +39,17 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_BLD_NS BEGIN_BLD_NS
MapRecord *gStartNewGame = 0; MapRecord *gStartNewGame = 0;
PACKETMODE gPacketMode = PACKETMODE_1;
int gNetFifoTail = 0; int gNetFifoTail = 0;
int gNetFifoHead[8]; int gNetFifoHead[8];
int gPredictTail = 0; int gPredictTail = 0;
int gNetFifoMasterTail = 0;
InputPacket gFifoInput[256][8]; InputPacket gFifoInput[256][8];
int myMinLag[8];
int otherMinLag = 0;
int myMaxLag = 0;
int gSendCheckTail = 0;
int gCheckTail = 0;
int gInitialNetPlayers = 0;
int gBufferJitter = 1;
int gPlayerReady[8];
bool bNoResend = true;
bool gRobust = false;
bool bOutOfSync = false;
bool ready2send = false;
NETWORKMODE gNetMode = NETWORK_NONE;
char gNetAddress[32];
// PORT-TODO: Use different port?
int gNetPort = kNetDefaultPort;
const short word_1328AC = 0x214;
void netResetToSinglePlayer(void) void netResetToSinglePlayer(void)
{ {
myconnectindex = connecthead = 0; myconnectindex = connecthead = 0;
gInitialNetPlayers = gNetPlayers = numplayers = 1; gNetPlayers = numplayers = 1;
connectpoint2[0] = -1; connectpoint2[0] = -1;
gGameOptions.nGameType = 0; gGameOptions.nGameType = 0;
gNetMode = NETWORK_NONE;
UpdateNetworkMenus(); UpdateNetworkMenus();
} }
@ -79,17 +57,9 @@ void netReset(void)
{ {
gFrameClock = gameclock = 0; gFrameClock = gameclock = 0;
lastTic = -1; lastTic = -1;
gNetFifoMasterTail = 0;
gPredictTail = 0; gPredictTail = 0;
gNetFifoTail = 0; gNetFifoTail = 0;
memset(gNetFifoHead, 0, sizeof(gNetFifoHead)); memset(gNetFifoHead, 0, sizeof(gNetFifoHead));
memset(myMinLag, 0, sizeof(myMinLag));
otherMinLag = 0;
myMaxLag = 0;
gSendCheckTail = 0;
gCheckTail = 0;
bOutOfSync = 0;
gBufferJitter = 1;
} }
void netBroadcastPlayerInfo(int nPlayer) void netBroadcastPlayerInfo(int nPlayer)
@ -99,8 +69,6 @@ void netBroadcastPlayerInfo(int nPlayer)
pProfile->skill = gSkill; pProfile->skill = gSkill;
pProfile->nAutoAim = cl_autoaim; pProfile->nAutoAim = cl_autoaim;
pProfile->nWeaponSwitch = cl_weaponswitch; pProfile->nWeaponSwitch = cl_weaponswitch;
if (numplayers < 2)
return;
} }
void netGetInput(void) void netGetInput(void)
@ -111,35 +79,13 @@ void netGetInput(void)
InputPacket &input = gFifoInput[gNetFifoHead[myconnectindex]&255][myconnectindex]; InputPacket &input = gFifoInput[gNetFifoHead[myconnectindex]&255][myconnectindex];
input = gNetInput; input = gNetInput;
gNetFifoHead[myconnectindex]++; gNetFifoHead[myconnectindex]++;
if (gGameOptions.nGameType == 0 || numplayers == 1)
{
for (int p = connecthead; p >= 0; p = connectpoint2[p])
{
if (p != myconnectindex)
{
InputPacket *pInput1 = &gFifoInput[(gNetFifoHead[p]-1)&255][p];
InputPacket *pInput2 = &gFifoInput[gNetFifoHead[p]&255][p];
memcpy(pInput2, pInput1, sizeof(InputPacket));
gNetFifoHead[p]++;
}
}
return;
}
} }
void netInitialize(bool bConsole) void netInitialize(bool bConsole)
{ {
memset(gPlayerReady, 0, sizeof(gPlayerReady));
netReset(); netReset();
netResetToSinglePlayer(); netResetToSinglePlayer();
} }
void netDeinitialize(void)
{
}
void netPlayerQuit(int nPlayer)
{
}
END_BLD_NS END_BLD_NS

View file

@ -28,58 +28,16 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_BLD_NS BEGIN_BLD_NS
enum PACKETMODE {
PACKETMODE_0 = 0,
PACKETMODE_1,
PACKETMODE_2,
PACKETMODE_3,
};
enum NETWORKMODE {
NETWORK_NONE = 0,
NETWORK_SERVER,
NETWORK_CLIENT
};
#define kNetDefaultPort 23513
extern MapRecord *gStartNewGame; extern MapRecord *gStartNewGame;
extern PACKETMODE gPacketMode;
extern int gNetFifoTail; extern int gNetFifoTail;
extern int gNetFifoHead[8]; extern int gNetFifoHead[8];
extern int gPredictTail; extern int gPredictTail;
extern int gNetFifoMasterTail;
extern InputPacket gFifoInput[256][8]; extern InputPacket gFifoInput[256][8];
extern int myMinLag[8];
extern int otherMinLag;
extern int myMaxLag;
extern int gSendCheckTail;
extern int gCheckTail;
extern int gInitialNetPlayers;
extern int gBufferJitter;
extern int gPlayerReady[8];
extern bool bNoResend;
extern bool gRobust;
extern bool bOutOfSync;
extern bool ready2send;
extern NETWORKMODE gNetMode;
extern char gNetAddress[32];
extern int gNetPort;
void netReset(void); void netReset(void);
void netResetToSinglePlayer(void); void netResetToSinglePlayer(void);
inline void netWaitForEveryone(char a1) {}
inline void netGetPackets(void) {}
inline void CalcGameChecksum(void) {}
inline void netBroadcastPlayerLogoff(int nPlayer) {}
inline void netBroadcastMyLogoff(bool bRestart) {}
void netInitialize(bool bConsole); void netInitialize(bool bConsole);
void netBroadcastPlayerInfo(int nPlayer); void netBroadcastPlayerInfo(int nPlayer);
inline void netCheckSync(void) {}
void netMasterUpdate(void);
void netGetInput(void); void netGetInput(void);
void netPlayerQuit(int nPlayer);
void netDeinitialize(void);
END_BLD_NS END_BLD_NS

View file

@ -273,8 +273,6 @@ void nnExtInitModernStuff(bool bSaveLoad) {
}*/ }*/
if (!gAllowTrueRandom) Printf("> STD randomness is not available, using in-game random function(s)");
else Printf("> Using STD randomness function(s).");
for (int i = 0; i < kMaxXSprites; i++) { for (int i = 0; i < kMaxXSprites; i++) {

View file

@ -50,6 +50,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "view.h" #include "view.h"
#include "messages.h" #include "messages.h"
#include "nnexts.h" #include "nnexts.h"
#include "d_net.h"
BEGIN_BLD_NS BEGIN_BLD_NS
@ -250,7 +251,7 @@ void LifeLeechOperate(spritetype *pSprite, XSPRITE *pXSprite, EVENT event)
case kCmdSpritePush: case kCmdSpritePush:
{ {
int nPlayer = pXSprite->data4; int nPlayer = pXSprite->data4;
if (nPlayer >= 0 && nPlayer < gNetPlayers) if (nPlayer >= 0 && nPlayer < kMaxPlayers && playeringame[nPlayer])
{ {
PLAYER *pPlayer = &gPlayer[nPlayer]; PLAYER *pPlayer = &gPlayer[nPlayer];
if (pPlayer->pXSprite->health > 0) if (pPlayer->pXSprite->health > 0)