mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
- plugged all memory leaks that were reported with Shadow Warrior when starting the first level.
This commit is contained in:
parent
5e821de481
commit
b0cefdedce
21 changed files with 102 additions and 430 deletions
|
@ -237,7 +237,6 @@ void scrUnInit(void)
|
||||||
{
|
{
|
||||||
memset(palookup, 0, sizeof(palookup));
|
memset(palookup, 0, sizeof(palookup));
|
||||||
memset(blendtable, 0, sizeof(blendtable));
|
memset(blendtable, 0, sizeof(blendtable));
|
||||||
engineUnInit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -81,6 +81,7 @@ extern int32_t curbrightness;
|
||||||
|
|
||||||
extern int32_t paletteLoadLookupTable(FileReader &fp);
|
extern int32_t paletteLoadLookupTable(FileReader &fp);
|
||||||
extern void paletteSetupDefaultFog(void);
|
extern void paletteSetupDefaultFog(void);
|
||||||
|
void paletteFreeLookups();
|
||||||
extern void palettePostLoadLookups(void);
|
extern void palettePostLoadLookups(void);
|
||||||
extern void paletteFixTranslucencyMask(void);
|
extern void paletteFixTranslucencyMask(void);
|
||||||
|
|
||||||
|
|
|
@ -310,6 +310,11 @@ int GameMain()
|
||||||
I_ShowFatalError(err.what());
|
I_ShowFatalError(err.what());
|
||||||
r = -1;
|
r = -1;
|
||||||
}
|
}
|
||||||
|
M_ClearMenus(true);
|
||||||
|
if (gi)
|
||||||
|
{
|
||||||
|
gi->FreeGameData(); // Must be done before taking down any subsystems.
|
||||||
|
}
|
||||||
S_StopMusic(true);
|
S_StopMusic(true);
|
||||||
if (soundEngine) delete soundEngine;
|
if (soundEngine) delete soundEngine;
|
||||||
soundEngine = nullptr;
|
soundEngine = nullptr;
|
||||||
|
@ -325,9 +330,9 @@ int GameMain()
|
||||||
I_ShutdownGraphics();
|
I_ShutdownGraphics();
|
||||||
M_DeinitMenus();
|
M_DeinitMenus();
|
||||||
paletteFreeColorTables();
|
paletteFreeColorTables();
|
||||||
|
engineUnInit();
|
||||||
if (gi)
|
if (gi)
|
||||||
{
|
{
|
||||||
gi->FreeGameData();
|
|
||||||
delete gi;
|
delete gi;
|
||||||
gi = nullptr;
|
gi = nullptr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -422,7 +422,7 @@ void M_ActivateMenu(DMenu *menu)
|
||||||
|
|
||||||
bool M_SetMenu(FName menu, int param, FName caller)
|
bool M_SetMenu(FName menu, int param, FName caller)
|
||||||
{
|
{
|
||||||
#if 0
|
#if 0
|
||||||
// skip the menu and go right into the first level.
|
// skip the menu and go right into the first level.
|
||||||
// For tracking memory leaks that normally require operating the menu to start the game so that they always get the same allocation number.
|
// For tracking memory leaks that normally require operating the menu to start the game so that they always get the same allocation number.
|
||||||
GameStartupInfo.Episode = GameStartupInfo.Skill = 0;
|
GameStartupInfo.Episode = GameStartupInfo.Skill = 0;
|
||||||
|
@ -908,7 +908,7 @@ void M_Drawer (void)
|
||||||
//
|
//
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
|
|
||||||
void M_ClearMenus ()
|
void M_ClearMenus (bool final)
|
||||||
{
|
{
|
||||||
M_DemoNoPlay = false;
|
M_DemoNoPlay = false;
|
||||||
transition.previous = transition.current = nullptr;
|
transition.previous = transition.current = nullptr;
|
||||||
|
@ -923,8 +923,11 @@ void M_ClearMenus ()
|
||||||
}
|
}
|
||||||
DMenu::CurrentMenu = nullptr;
|
DMenu::CurrentMenu = nullptr;
|
||||||
menuactive = MENU_Off;
|
menuactive = MENU_Off;
|
||||||
mouseGrabInput(true);
|
if (!final)
|
||||||
gi->MenuClosed();
|
{
|
||||||
|
mouseGrabInput(true);
|
||||||
|
gi->MenuClosed();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Menu_Close(int playerid)
|
void Menu_Close(int playerid)
|
||||||
|
|
|
@ -769,7 +769,7 @@ void M_PreviousMenu();
|
||||||
void M_Init (void);
|
void M_Init (void);
|
||||||
void M_CreateMenus();
|
void M_CreateMenus();
|
||||||
void M_ActivateMenu(DMenu *menu);
|
void M_ActivateMenu(DMenu *menu);
|
||||||
void M_ClearMenus ();
|
void M_ClearMenus (bool final = false);
|
||||||
void M_ParseMenuDefs();
|
void M_ParseMenuDefs();
|
||||||
void M_StartupSkillMenu(FGameStartup *gs);
|
void M_StartupSkillMenu(FGameStartup *gs);
|
||||||
int M_GetDefaultSkill();
|
int M_GetDefaultSkill();
|
||||||
|
|
|
@ -94,6 +94,7 @@ void M_DeinitMenus()
|
||||||
}
|
}
|
||||||
MenuDescriptors.Clear();
|
MenuDescriptors.Clear();
|
||||||
OptionValues.Clear();
|
OptionValues.Clear();
|
||||||
|
|
||||||
DMenu::CurrentMenu = NULL;
|
DMenu::CurrentMenu = NULL;
|
||||||
DefaultListMenuSettings.mItems.Clear();
|
DefaultListMenuSettings.mItems.Clear();
|
||||||
}
|
}
|
||||||
|
|
|
@ -6435,7 +6435,6 @@ void nix()
|
||||||
|
|
||||||
void GameInterface::FreeGameData()
|
void GameInterface::FreeGameData()
|
||||||
{
|
{
|
||||||
engineUnInit();
|
|
||||||
G_Cleanup();
|
G_Cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1173,7 +1173,7 @@ int WINAPI wWinMain (HINSTANCE hInstance, HINSTANCE nothing, LPWSTR cmdline, int
|
||||||
|
|
||||||
// Use this to break at a specific allocation number.
|
// Use this to break at a specific allocation number.
|
||||||
|
|
||||||
_crtBreakAlloc = 250894;
|
//_crtBreakAlloc = 251490;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int ret = DoMain (hInstance);
|
int ret = DoMain (hInstance);
|
||||||
|
|
|
@ -7884,7 +7884,6 @@ void A_SpawnRandomGlass(int spriteNum, int wallNum, int glassCnt)
|
||||||
void GameInterface::FreeGameData()
|
void GameInterface::FreeGameData()
|
||||||
{
|
{
|
||||||
G_SetFog(0);
|
G_SetFog(0);
|
||||||
engineUnInit();
|
|
||||||
G_Cleanup();
|
G_Cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -58,335 +58,6 @@ Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms
|
||||||
|
|
||||||
BEGIN_SW_NS
|
BEGIN_SW_NS
|
||||||
|
|
||||||
// DEFINES ///////////////////////////////////////////////////////////////////////////////////
|
|
||||||
#define MAX_USER_ARGS 100
|
|
||||||
#define MAX_CONSOLE_COMMANDS 100
|
|
||||||
#define MAX_HISTORY 20
|
|
||||||
|
|
||||||
SWBOOL SpriteInfo = FALSE;
|
|
||||||
extern SWBOOL QuitFlag;
|
|
||||||
extern SWBOOL MultiPlayQuitFlag;
|
|
||||||
|
|
||||||
// FUNCTION PROTOTYPES ///////////////////////////////////////////////////////////////////////
|
|
||||||
void CON_ProcessOptions(void);
|
|
||||||
void CON_ClearConsole(void);
|
|
||||||
uint8_t CON_CommandCmp(const char *str1, const char *str2, int len);
|
|
||||||
void CheatInput(void);
|
|
||||||
|
|
||||||
// Modify actor routines
|
|
||||||
void CON_Sound(void);
|
|
||||||
void CON_Reverb(void);
|
|
||||||
void CON_Heap(void);
|
|
||||||
void CON_Cache(void);
|
|
||||||
void CON_SoundTest(void);
|
|
||||||
void CON_SpriteInfo(void);
|
|
||||||
void CON_KillSprite(void);
|
|
||||||
void CON_SpriteDetail(void);
|
|
||||||
void CON_UserDetail(void);
|
|
||||||
void CON_Quit(void);
|
|
||||||
void CON_LoadSetup(void);
|
|
||||||
void CON_DamageData(void);
|
|
||||||
void CON_WinPachinko(void);
|
|
||||||
void CON_Bunny(void);
|
|
||||||
void CON_CheckHeap(void);
|
|
||||||
void CON_DumpHeap(void);
|
|
||||||
void CON_ShowMirror(void);
|
|
||||||
void CON_MultiNameChange(void);
|
|
||||||
|
|
||||||
// STRUCTURES ////////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
const char *command; // Text string representing the command that calls this function
|
|
||||||
void (*function)(void); // Function assigned to the command, take no parameters
|
|
||||||
|
|
||||||
} CON_COMMAND, *CON_COMMANDp;
|
|
||||||
|
|
||||||
// Contains any commands that don't get added by particular setup functions
|
|
||||||
CON_COMMAND pre_commands[] =
|
|
||||||
{
|
|
||||||
#if DEBUG
|
|
||||||
{"bobbing", CON_ProcessOptions},
|
|
||||||
{"swnext", CheatInput},
|
|
||||||
{"swprev", CheatInput},
|
|
||||||
{"swsecret", CheatInput},
|
|
||||||
{"swstart", CheatInput},
|
|
||||||
{"swres", CheatInput},
|
|
||||||
{"swloc", CheatInput},
|
|
||||||
{"swroom", CheatInput},
|
|
||||||
{"swmap", CheatInput},
|
|
||||||
{"swvox", CheatInput},
|
|
||||||
{"swsave", CheatInput},
|
|
||||||
#endif
|
|
||||||
#if DEBUG
|
|
||||||
{"george", CheatInput},
|
|
||||||
{"blackburn", CheatInput},
|
|
||||||
{"reverb", CON_Reverb},
|
|
||||||
{"showmirror", CON_ShowMirror},
|
|
||||||
{"clear", CON_ClearConsole},
|
|
||||||
#endif
|
|
||||||
{"swgod", CheatInput},
|
|
||||||
{"swchan", CheatInput},
|
|
||||||
{"swgimme", CheatInput},
|
|
||||||
{"swtrek##", CheatInput},
|
|
||||||
{"swgreed", CheatInput},
|
|
||||||
{"swghost", CheatInput},
|
|
||||||
{"swstart", CheatInput},
|
|
||||||
{"swres", CheatInput},
|
|
||||||
{"swloc", CheatInput},
|
|
||||||
{"swmap", CheatInput},
|
|
||||||
{"swsave", CheatInput},
|
|
||||||
{"swmedic", CheatInput},
|
|
||||||
{"swkeys", CheatInput},
|
|
||||||
{"swredcard", CheatInput},
|
|
||||||
{"swbluecard", CheatInput},
|
|
||||||
{"swgreencard", CheatInput},
|
|
||||||
{"swyellowcard", CheatInput},
|
|
||||||
{"swgoldkey", CheatInput},
|
|
||||||
{"swsilverkey", CheatInput},
|
|
||||||
{"swbronzekey", CheatInput},
|
|
||||||
{"swredkey", CheatInput},
|
|
||||||
{"swgun#", CheatInput},
|
|
||||||
{"swquit", CheatInput},
|
|
||||||
{"swexit", CheatInput},
|
|
||||||
{"swtrix", CON_Bunny},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
// GLOBALS ///////////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
CON_COMMAND commandlist[MAX_CONSOLE_COMMANDS]; // Console command array
|
|
||||||
CON_COMMANDp commandptr; // Pointer to a command
|
|
||||||
|
|
||||||
int16_t numcommands=0; // Total number of commands in the command list
|
|
||||||
|
|
||||||
char command_history[MAX_HISTORY][256]; // History of what has been typed in lately
|
|
||||||
int16_t curr_history=0; // Line currently being pointed to in the history array
|
|
||||||
int16_t numhistory=0;
|
|
||||||
|
|
||||||
// Array which stores all the user arguments passed into the game.
|
|
||||||
static char user_args[MAX_USER_ARGS][256];
|
|
||||||
static uint8_t con_argnum=0; // Total number of arguments that were passed into the game
|
|
||||||
|
|
||||||
char con_message[80]; // Holds the current console message to send to adduserquote
|
|
||||||
|
|
||||||
// FUNCTIONS /////////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// Frank's neato input string checker, useful for my stuff too.
|
|
||||||
//
|
|
||||||
uint8_t CON_CommandCmp(const char *str1, const char *str2, int len)
|
|
||||||
{
|
|
||||||
const char *cp1 = str1;
|
|
||||||
const char *cp2 = str2;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
if (*cp1 != *cp2)
|
|
||||||
{
|
|
||||||
if (*cp1 != '#' && *cp2 != '#')
|
|
||||||
return FALSE;
|
|
||||||
else if ((*cp1 == '#' && !isdigit(*cp2)) || (*cp2 == '#' && !isdigit(*cp1)))
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
cp1++;
|
|
||||||
cp2++;
|
|
||||||
}
|
|
||||||
while (--len);
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
SWBOOL IsCommand(const char *str)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
char first[512];
|
|
||||||
|
|
||||||
sscanf(str,"%s",first);
|
|
||||||
|
|
||||||
for (i = 0; i < numcommands; i++)
|
|
||||||
{
|
|
||||||
// Don't even try if they aren't the same length
|
|
||||||
if (strlen(first) != strlen(commandlist[i].command))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// See if it's in there
|
|
||||||
if (CON_CommandCmp(first, commandlist[i].command, strlen(first)))
|
|
||||||
{
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Stores user arguments passed in on the command line for later inspection
|
|
||||||
//
|
|
||||||
void CON_StoreArg(const char *userarg)
|
|
||||||
{
|
|
||||||
if (con_argnum < MAX_USER_ARGS)
|
|
||||||
{
|
|
||||||
strcpy(&user_args[con_argnum][0],userarg);
|
|
||||||
Bstrlwr(&user_args[con_argnum][0]);
|
|
||||||
con_argnum++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Checkes the user command array to see if user did in fact pass in a particular argument
|
|
||||||
//
|
|
||||||
SWBOOL CON_CheckParm(const char *userarg)
|
|
||||||
{
|
|
||||||
int16_t i;
|
|
||||||
|
|
||||||
for (i=0; i<con_argnum; i++)
|
|
||||||
{
|
|
||||||
if (!strcmp(&user_args[i][0],userarg))
|
|
||||||
return TRUE; // Yep, it's in there
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE; // Not a parameter that was passed in
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Scrolls up and down through previous user commands like DosKey
|
|
||||||
// Copies the history text string into the MessageInputCommand
|
|
||||||
//
|
|
||||||
void CON_CommandHistory(signed char dir)
|
|
||||||
{
|
|
||||||
if (curr_history + dir < numhistory)
|
|
||||||
curr_history += dir;
|
|
||||||
if (curr_history < 0) curr_history = 0;
|
|
||||||
if (curr_history > MAX_HISTORY) curr_history = MAX_HISTORY;
|
|
||||||
|
|
||||||
strcpy(MessageInputString, command_history[curr_history]);
|
|
||||||
}
|
|
||||||
|
|
||||||
void CON_AddHistory(const char *commandstr)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i=MAX_HISTORY-1; i>=0; i--)
|
|
||||||
{
|
|
||||||
strcpy(command_history[i],command_history[i-1]);
|
|
||||||
}
|
|
||||||
strcpy(command_history[0],commandstr);
|
|
||||||
if ((++numhistory) > MAX_HISTORY) numhistory = MAX_HISTORY;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// Adds a command name to the command list and assigns the appropriate function pointer
|
|
||||||
//
|
|
||||||
SWBOOL CON_AddCommand(const char *command, void (*function)(void))
|
|
||||||
{
|
|
||||||
if (command != NULL && function != NULL && numcommands < MAX_CONSOLE_COMMANDS)
|
|
||||||
{
|
|
||||||
// strcpy(commandlist[numcommands].command, command);
|
|
||||||
commandlist[numcommands].command = command;
|
|
||||||
commandlist[numcommands].function = function;
|
|
||||||
|
|
||||||
// Increment counter to set up for next command insertion
|
|
||||||
numcommands++;
|
|
||||||
|
|
||||||
ASSERT(numcommands <= MAX_CONSOLE_COMMANDS);
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Process commands
|
|
||||||
// Returns TRUE upon success
|
|
||||||
//
|
|
||||||
void CON_ProcessUserCommand(void)
|
|
||||||
{
|
|
||||||
int16_t i=0;
|
|
||||||
char temp_message[256],command_str[256];
|
|
||||||
|
|
||||||
strcpy(temp_message,MessageInputString);
|
|
||||||
sscanf(Bstrlwr(temp_message),"%s", command_str); // Get the base command type
|
|
||||||
|
|
||||||
for (i = 0; i < numcommands; i++)
|
|
||||||
{
|
|
||||||
// Don't even try if they aren't the same length
|
|
||||||
if (strlen(command_str) != strlen(commandlist[i].command)) continue;
|
|
||||||
// See if it's in there
|
|
||||||
if (CON_CommandCmp(command_str, commandlist[i].command, strlen(command_str)))
|
|
||||||
{
|
|
||||||
if (commandlist[i].function)
|
|
||||||
{
|
|
||||||
(*commandlist[i].function)();
|
|
||||||
CON_AddHistory(MessageInputString); // Keep history only of valid input
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ConPanel)
|
|
||||||
OSD_Printf("Syntax Error or Command not enabled!");
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Initialize the console command list with the pre_command startup array
|
|
||||||
//
|
|
||||||
void CON_InitConsole(void)
|
|
||||||
{
|
|
||||||
CON_COMMANDp i;
|
|
||||||
|
|
||||||
for (i = &pre_commands[0]; i->command != NULL; i++)
|
|
||||||
{
|
|
||||||
if (!CON_AddCommand(i->command, i->function))
|
|
||||||
{
|
|
||||||
printf("CON_InitConsole: Failed to add command contained in pre_commands list.\n");
|
|
||||||
TerminateGame();
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//printf("CON_InitConsole: Command list initialized.\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Process as a command, anything that could be set in the options menu as well
|
|
||||||
//
|
|
||||||
void CON_ProcessOptions(void)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Clear the console screen
|
|
||||||
void CON_ClearConsole(void)
|
|
||||||
{
|
|
||||||
short i;
|
|
||||||
|
|
||||||
for (i=0; i<MAXCONQUOTES; i++)
|
|
||||||
strcpy(con_quote[i],"\0");
|
|
||||||
}
|
|
||||||
|
|
||||||
void CON_Reverb(void)
|
|
||||||
{
|
|
||||||
char base[80];
|
|
||||||
int16_t op1=0;
|
|
||||||
PLAYERp pp = Player + screenpeek;
|
|
||||||
|
|
||||||
// Format: reverb [number]
|
|
||||||
if (sscanf(MessageInputString,"%s %hd",base,&op1) < 2)
|
|
||||||
{
|
|
||||||
strcpy(MessageInputString,"help reverb");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
OSD_Printf("Reverb is now set to %d.",op1);
|
|
||||||
COVER_SetReverb(op1);
|
|
||||||
pp->Reverb = op1;
|
|
||||||
}
|
|
||||||
void CON_Bunny(void)
|
void CON_Bunny(void)
|
||||||
{
|
{
|
||||||
PLAYERp pp = Player + myconnectindex;
|
PLAYERp pp = Player + myconnectindex;
|
||||||
|
|
|
@ -228,9 +228,7 @@ DemoReadHeader(void)
|
||||||
|
|
||||||
if (DF_ERR(DemoFileIn))
|
if (DF_ERR(DemoFileIn))
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_Error("File %s is not a valid demo file.",DemoFileName);
|
||||||
printf("File %s is not a valid demo file.",DemoFileName);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DREAD(&dh, sizeof(dh), 1, DemoFileIn);
|
DREAD(&dh, sizeof(dh), 1, DemoFileIn);
|
||||||
|
@ -542,7 +540,6 @@ DemoPlayBack(void)
|
||||||
{
|
{
|
||||||
TerminateLevel();
|
TerminateLevel();
|
||||||
TerminateGame();
|
TerminateGame();
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1464,7 +1464,7 @@ void PrintSpriteInfo(PLAYERp pp)
|
||||||
Printf("COUNTER:%d, ", u->Counter);
|
Printf("COUNTER:%d, ", u->Counter);
|
||||||
Printf("COUNTER2:%d\n", u->Counter);
|
Printf("COUNTER2:%d\n", u->Counter);
|
||||||
}
|
}
|
||||||
if (SpriteInfo > 1)
|
if (sp)
|
||||||
{
|
{
|
||||||
Printf("POSX:%d, ", TrackerCast(sp->x));
|
Printf("POSX:%d, ", TrackerCast(sp->x));
|
||||||
Printf("POSY:%d, ", TrackerCast(sp->y));
|
Printf("POSY:%d, ", TrackerCast(sp->y));
|
||||||
|
|
|
@ -424,9 +424,7 @@ AllocMem(int size)
|
||||||
// Used for debugging, we can remove this at ship time
|
// Used for debugging, we can remove this at ship time
|
||||||
if (bp == NULL)
|
if (bp == NULL)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_FatalError("Memory could NOT be allocated in AllocMem: size = %d\n",size);
|
||||||
printf("Memory could NOT be allocated in AllocMem: size = %d\n",size);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ASSERT(bp != NULL);
|
ASSERT(bp != NULL);
|
||||||
|
@ -489,9 +487,7 @@ CallocMem(int size, int num)
|
||||||
// Used for debugging, we can remove this at ship time
|
// Used for debugging, we can remove this at ship time
|
||||||
if (bp == NULL)
|
if (bp == NULL)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_FatalError("Memory could NOT be allocated in CallocMem: size = %d, num = %d\n",size,num);
|
||||||
printf("Memory could NOT be allocated in CallocMem: size = %d, num = %d\n",size,num);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ASSERT(bp != NULL);
|
ASSERT(bp != NULL);
|
||||||
|
@ -532,6 +528,7 @@ ValidPtr(void *ptr)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
void *
|
void *
|
||||||
AllocMem(int size)
|
AllocMem(int size)
|
||||||
{
|
{
|
||||||
|
@ -555,6 +552,7 @@ FreeMem(void *ptr)
|
||||||
{
|
{
|
||||||
free(ptr);
|
free(ptr);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -632,18 +630,13 @@ void TerminateGame(void)
|
||||||
SybexScreen();
|
SybexScreen();
|
||||||
//TenScreen();
|
//TenScreen();
|
||||||
}
|
}
|
||||||
|
throw ExitEvent(3);
|
||||||
engineUnInit();
|
|
||||||
|
|
||||||
timerUninit();
|
|
||||||
Bexit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LoadLevel(const char *filename)
|
bool LoadLevel(const char *filename)
|
||||||
{
|
{
|
||||||
if (engineLoadBoard(filename, SW_SHAREWARE ? 1 : 0, (vec3_t *)&Player[0], &Player[0].pang, &Player[0].cursectnum) == -1)
|
if (engineLoadBoard(filename, SW_SHAREWARE ? 1 : 0, (vec3_t *)&Player[0], &Player[0].pang, &Player[0].cursectnum) == -1)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
|
||||||
Printf("Level not found: %s", filename);
|
Printf("Level not found: %s", filename);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -787,12 +780,6 @@ bool InitGame()
|
||||||
|
|
||||||
timerInit(120);
|
timerInit(120);
|
||||||
|
|
||||||
CON_InitConsole(); // Init console command list
|
|
||||||
|
|
||||||
////DSPRINTF(ds,"%s, %d",__FILE__,__LINE__); MONO_PRINT(ds);
|
|
||||||
|
|
||||||
//InitFX();
|
|
||||||
|
|
||||||
memcpy(palette_data,palette,768);
|
memcpy(palette_data,palette,768);
|
||||||
InitPalette();
|
InitPalette();
|
||||||
// sets numplayers, connecthead, connectpoint2, myconnectindex
|
// sets numplayers, connecthead, connectpoint2, myconnectindex
|
||||||
|
@ -2483,7 +2470,7 @@ void Control()
|
||||||
}
|
}
|
||||||
|
|
||||||
CleanExit = TRUE;
|
CleanExit = TRUE;
|
||||||
TerminateGame();
|
throw ExitEvent(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3986,6 +3973,13 @@ GameStats GameInterface::getStats()
|
||||||
return { pp->Kills, TotalKillable, pp->SecretsFound, LevelSecrets, PlayClock / 120, 0 };
|
return { pp->Kills, TotalKillable, pp->SecretsFound, LevelSecrets, PlayClock / 120, 0 };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GameInterface::FreeGameData()
|
||||||
|
{
|
||||||
|
TerminateLevel();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#if 0 // the message input needs to be moved out of the game code!
|
#if 0 // the message input needs to be moved out of the game code!
|
||||||
void GetMessageInput(PLAYERp pp)
|
void GetMessageInput(PLAYERp pp)
|
||||||
{
|
{
|
||||||
|
@ -4045,12 +4039,6 @@ void GetMessageInput(PLAYERp pp)
|
||||||
{
|
{
|
||||||
if (memcmp(MessageInputString, TEAM_MENU, sizeof(TEAM_MENU)) != 0)
|
if (memcmp(MessageInputString, TEAM_MENU, sizeof(TEAM_MENU)) != 0)
|
||||||
{
|
{
|
||||||
// see if its a command
|
|
||||||
if (IsCommand(MessageInputString))
|
|
||||||
{
|
|
||||||
TeamSendAll = TRUE;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
strcpy(HoldMessageInputString, MessageInputString);
|
strcpy(HoldMessageInputString, MessageInputString);
|
||||||
strcpy(MessageInputString, TEAM_MENU);
|
strcpy(MessageInputString, TEAM_MENU);
|
||||||
|
@ -4072,7 +4060,6 @@ void GetMessageInput(PLAYERp pp)
|
||||||
inputState.ClearKeysDown();
|
inputState.ClearKeysDown();
|
||||||
inputState.keyFlushChars();
|
inputState.keyFlushChars();
|
||||||
buttonMap.ClearButton(gamefunc_Inventory);
|
buttonMap.ClearButton(gamefunc_Inventory);
|
||||||
CON_ProcessUserCommand(); // Check to see if it's a cheat or command
|
|
||||||
|
|
||||||
for (i = 0; i < NUMGAMEFUNCTIONS; i++)
|
for (i = 0; i < NUMGAMEFUNCTIONS; i++)
|
||||||
buttonMap.ClearButton(i);
|
buttonMap.ClearButton(i);
|
||||||
|
|
|
@ -858,7 +858,6 @@ SWBOOL CON_CheckParm(const char *userarg);
|
||||||
void CON_CommandHistory(signed char dir);
|
void CON_CommandHistory(signed char dir);
|
||||||
SWBOOL CON_AddCommand(const char *command, void (*function)(void));
|
SWBOOL CON_AddCommand(const char *command, void (*function)(void));
|
||||||
void CON_ProcessUserCommand(void);
|
void CON_ProcessUserCommand(void);
|
||||||
void CON_InitConsole(void);
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
|
@ -1756,10 +1755,18 @@ typedef struct
|
||||||
} MEM_HDR,*MEM_HDRp;
|
} MEM_HDR,*MEM_HDRp;
|
||||||
|
|
||||||
SWBOOL ValidPtr(void *ptr);
|
SWBOOL ValidPtr(void *ptr);
|
||||||
|
#if 0
|
||||||
void *AllocMem(int size);
|
void *AllocMem(int size);
|
||||||
void *CallocMem(int size, int num);
|
void *CallocMem(int size, int num);
|
||||||
void *ReAllocMem(void *ptr, int size);
|
void *ReAllocMem(void *ptr, int size);
|
||||||
void FreeMem(void *ptr);
|
void FreeMem(void *ptr);
|
||||||
|
#else
|
||||||
|
// Make these #defines so that MSVC's allocation tracker gets correct line numbers
|
||||||
|
#define AllocMem malloc
|
||||||
|
#define CallocMem calloc
|
||||||
|
#define ReAllocMem realloc
|
||||||
|
#define FreeMem free
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
|
@ -2423,6 +2430,7 @@ void LoadSaveMsg(const char *msg);
|
||||||
struct GameInterface : ::GameInterface
|
struct GameInterface : ::GameInterface
|
||||||
{
|
{
|
||||||
int app_main() override;
|
int app_main() override;
|
||||||
|
void FreeGameData() override;
|
||||||
bool validate_hud(int) override;
|
bool validate_hud(int) override;
|
||||||
void set_hud_layout(int size) override;
|
void set_hud_layout(int size) override;
|
||||||
void set_hud_scale(int size) override;
|
void set_hud_scale(int size) override;
|
||||||
|
|
|
@ -387,9 +387,8 @@ void JS_InitMirrors(void)
|
||||||
|
|
||||||
if (!Found_Cam)
|
if (!Found_Cam)
|
||||||
{
|
{
|
||||||
printf("Cound not find the camera view sprite for match %d\n",TrackerCast(wall[i].hitag));
|
Printf("Cound not find the camera view sprite for match %d\n",TrackerCast(wall[i].hitag));
|
||||||
printf("Map Coordinates: x = %d, y = %d\n",TrackerCast(wall[i].x),TrackerCast(wall[i].y));
|
Printf("Map Coordinates: x = %d, y = %d\n",TrackerCast(wall[i].x),TrackerCast(wall[i].y));
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Found_Cam = FALSE;
|
Found_Cam = FALSE;
|
||||||
|
@ -413,10 +412,9 @@ void JS_InitMirrors(void)
|
||||||
|
|
||||||
if (!Found_Cam)
|
if (!Found_Cam)
|
||||||
{
|
{
|
||||||
printf("Did not find drawtotile for camera number %d\n",mirrorcnt);
|
Printf("Did not find drawtotile for camera number %d\n",mirrorcnt);
|
||||||
printf("wall[%d].hitag == %d\n",i,TrackerCast(wall[i].hitag));
|
Printf("wall[%d].hitag == %d\n",i,TrackerCast(wall[i].hitag));
|
||||||
printf("Map Coordinates: x = %d, y = %d\n", TrackerCast(wall[i].x), TrackerCast(wall[i].y));
|
Printf("Map Coordinates: x = %d, y = %d\n", TrackerCast(wall[i].x), TrackerCast(wall[i].y));
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -692,10 +690,8 @@ JS_DrawMirrors(PLAYERp pp, int tx, int ty, int tz, short tpang, int tphoriz)
|
||||||
|
|
||||||
if (mirror[cnt].campic == -1)
|
if (mirror[cnt].campic == -1)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
Printf("Missing campic for mirror %d. Map Coordinates: x = %d, y = %d\n", cnt,midx,midy);
|
||||||
printf("Missing campic for mirror %d\n",cnt);
|
return;
|
||||||
printf("Map Coordinates: x = %d, y = %d\n",midx,midy);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// BOOL2 = Oscilate camera
|
// BOOL2 = Oscilate camera
|
||||||
|
@ -1086,22 +1082,33 @@ JS_UnInitLockouts(void)
|
||||||
{
|
{
|
||||||
OrgTileP tp=NULL, next_tp=NULL;
|
OrgTileP tp=NULL, next_tp=NULL;
|
||||||
|
|
||||||
|
if (orgwalllist.Next)
|
||||||
TRAVERSE(&orgwalllist, tp, next_tp)
|
|
||||||
{
|
{
|
||||||
KillOrgTile(tp);
|
TRAVERSE(&orgwalllist, tp, next_tp)
|
||||||
|
{
|
||||||
|
KillOrgTile(tp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
TRAVERSE(&orgwalloverlist, tp, next_tp)
|
if (orgwalloverlist.Next)
|
||||||
{
|
{
|
||||||
KillOrgTile(tp);
|
TRAVERSE(&orgwalloverlist, tp, next_tp)
|
||||||
|
{
|
||||||
|
KillOrgTile(tp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
TRAVERSE(&orgsectorceilinglist, tp, next_tp)
|
if (orgsectorceilinglist.Next)
|
||||||
{
|
{
|
||||||
KillOrgTile(tp);
|
TRAVERSE(&orgsectorceilinglist, tp, next_tp)
|
||||||
|
{
|
||||||
|
KillOrgTile(tp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
TRAVERSE(&orgsectorfloorlist, tp, next_tp)
|
if (orgsectorfloorlist.Next)
|
||||||
{
|
{
|
||||||
KillOrgTile(tp);
|
TRAVERSE(&orgsectorfloorlist, tp, next_tp)
|
||||||
|
{
|
||||||
|
KillOrgTile(tp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1120,24 +1127,22 @@ JS_UnInitLockouts(void)
|
||||||
void
|
void
|
||||||
JS_PlockError(short wall_num, short t)
|
JS_PlockError(short wall_num, short t)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
Printf("ERROR: JS_InitLockouts(), out of range tile number\n");
|
||||||
printf("ERROR: JS_InitLockouts(), out of range tile number\n");
|
|
||||||
switch (t)
|
switch (t)
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
printf("wall %d, x %d, y %d, pic %d\n", wall_num, TrackerCast(wall[wall_num].x), TrackerCast(wall[wall_num].y), TrackerCast(wall[wall_num].picnum));
|
Printf("wall %d, x %d, y %d, pic %d\n", wall_num, TrackerCast(wall[wall_num].x), TrackerCast(wall[wall_num].y), TrackerCast(wall[wall_num].picnum));
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
printf("wall %d, x %d, y %d, OVERpic %d\n", wall_num, TrackerCast(wall[wall_num].x), TrackerCast(wall[wall_num].y), TrackerCast(wall[wall_num].overpicnum));
|
Printf("wall %d, x %d, y %d, OVERpic %d\n", wall_num, TrackerCast(wall[wall_num].x), TrackerCast(wall[wall_num].y), TrackerCast(wall[wall_num].overpicnum));
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
printf("sector %d, ceiling %d\n", wall_num, TrackerCast(sector[wall_num].ceilingpicnum));
|
Printf("sector %d, ceiling %d\n", wall_num, TrackerCast(sector[wall_num].ceilingpicnum));
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
printf("sector %d, floor %d\n", wall_num, TrackerCast(sector[wall_num].floorpicnum));
|
Printf("sector %d, floor %d\n", wall_num, TrackerCast(sector[wall_num].floorpicnum));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1163,7 +1168,10 @@ JS_InitLockouts(void)
|
||||||
|
|
||||||
picnum = wall[i].picnum;
|
picnum = wall[i].picnum;
|
||||||
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
||||||
JS_PlockError(i,1);
|
{
|
||||||
|
JS_PlockError(i, 1);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (aVoxelArray[picnum].Parental >= 0)
|
if (aVoxelArray[picnum].Parental >= 0)
|
||||||
{
|
{
|
||||||
|
@ -1175,7 +1183,10 @@ JS_InitLockouts(void)
|
||||||
|
|
||||||
picnum = wall[i].overpicnum;
|
picnum = wall[i].overpicnum;
|
||||||
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
||||||
JS_PlockError(i,2);
|
{
|
||||||
|
JS_PlockError(i, 2);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (aVoxelArray[picnum].Parental >= 0)
|
if (aVoxelArray[picnum].Parental >= 0)
|
||||||
{
|
{
|
||||||
|
@ -1192,7 +1203,10 @@ JS_InitLockouts(void)
|
||||||
|
|
||||||
picnum = sector[i].ceilingpicnum;
|
picnum = sector[i].ceilingpicnum;
|
||||||
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
||||||
JS_PlockError(i,3);
|
{
|
||||||
|
JS_PlockError(i, 3);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (aVoxelArray[picnum].Parental >= 0)
|
if (aVoxelArray[picnum].Parental >= 0)
|
||||||
{
|
{
|
||||||
|
@ -1204,7 +1218,10 @@ JS_InitLockouts(void)
|
||||||
|
|
||||||
picnum = sector[i].floorpicnum;
|
picnum = sector[i].floorpicnum;
|
||||||
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
if (aVoxelArray[picnum].Parental >= INVISTILE)
|
||||||
JS_PlockError(i,2);
|
{
|
||||||
|
JS_PlockError(i, 2);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (aVoxelArray[picnum].Parental >= 0)
|
if (aVoxelArray[picnum].Parental >= 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -648,7 +648,6 @@ waitforeverybody(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
TerminateGame();
|
TerminateGame();
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4578,9 +4578,7 @@ PlayerOnLadder(PLAYERp pp)
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
if (wall[wal].nextsector < 0)
|
if (wall[wal].nextsector < 0)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_Error("Take out white wall ladder x = %d, y = %d",wall[wal].x, wall[wal].y);
|
||||||
printf("Take out white wall ladder x = %d, y = %d",wall[wal].x, wall[wal].y);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -4733,9 +4731,7 @@ GetOverlapSector(int x, int y, short *over, short *under)
|
||||||
|
|
||||||
if (!found)
|
if (!found)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_Error("GetOverlapSector x = %d, y = %d, over %d, under %d", x, y, *over, *under);
|
||||||
printf("GetOverlapSector x = %d, y = %d, over %d, under %d", x, y, *over, *under);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PRODUCTION_ASSERT(found != 0);
|
PRODUCTION_ASSERT(found != 0);
|
||||||
|
@ -4823,9 +4819,7 @@ GetOverlapSector2(int x, int y, short *over, short *under)
|
||||||
|
|
||||||
if (!found)
|
if (!found)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_Error("GetOverlapSector x = %d, y = %d, over %d, under %d", x, y, *over, *under);
|
||||||
printf("GetOverlapSector x = %d, y = %d, over %d, under %d", x, y, *over, *under);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PRODUCTION_ASSERT(found != 0);
|
PRODUCTION_ASSERT(found != 0);
|
||||||
|
@ -8252,7 +8246,6 @@ PlayerSpawnPosition(PLAYERp pp)
|
||||||
spawn_sprite = headspritestat[STAT_MULTI_START + 0];
|
spawn_sprite = headspritestat[STAT_MULTI_START + 0];
|
||||||
//TerminateGame();
|
//TerminateGame();
|
||||||
//printf("Map does not contain a spawn position for Player %d.", pp - Player);
|
//printf("Map does not contain a spawn position for Player %d.", pp - Player);
|
||||||
//exit(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ASSERT(spawn_sprite >= 0);
|
ASSERT(spawn_sprite >= 0);
|
||||||
|
|
|
@ -710,6 +710,7 @@ void COVER_SetReverb(int amt)
|
||||||
|
|
||||||
void DeleteNoSoundOwner(short spritenum)
|
void DeleteNoSoundOwner(short spritenum)
|
||||||
{
|
{
|
||||||
|
if (!soundEngine) return;
|
||||||
SPRITEp sp = &sprite[spritenum];
|
SPRITEp sp = &sprite[spritenum];
|
||||||
|
|
||||||
soundEngine->EnumerateChannels([=](FSoundChan* chan)
|
soundEngine->EnumerateChannels([=](FSoundChan* chan)
|
||||||
|
@ -945,7 +946,8 @@ SWBOOL PlaySong(const char* mapname, const char* song_file_name, int cdaudio_tra
|
||||||
|
|
||||||
void StopSound(void)
|
void StopSound(void)
|
||||||
{
|
{
|
||||||
soundEngine->StopAllChannels();
|
// This gets also called on shutdown.
|
||||||
|
if (soundEngine) soundEngine->StopAllChannels();
|
||||||
Mus_Stop();
|
Mus_Stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2896,9 +2896,7 @@ SpriteSetup(void)
|
||||||
{
|
{
|
||||||
if (sprite[i].hitag == sp->hitag && sprite[i].lotag == sp->lotag)
|
if (sprite[i].hitag == sp->hitag && sprite[i].lotag == sp->lotag)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_Error("Two VIEW_THRU_ tags with same match found on level\n1: x %d, y %d \n2: x %d, y %d", TrackerCast(sp->x), TrackerCast(sp->y), TrackerCast(sprite[i].x), TrackerCast(sprite[i].y));
|
||||||
printf("Two VIEW_THRU_ tags with same match found on level\n1: x %d, y %d \n2: x %d, y %d", TrackerCast(sp->x), TrackerCast(sp->y), TrackerCast(sprite[i].x), TrackerCast(sprite[i].y));
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
change_sprite_stat(SpriteNum, STAT_FAF);
|
change_sprite_stat(SpriteNum, STAT_FAF);
|
||||||
|
@ -4964,11 +4962,10 @@ ActorDrop(short SpriteNum, int x, int y, int z, short new_sector, short min_heig
|
||||||
#if 0
|
#if 0
|
||||||
if (florhit < 0 || ceilhit < 0)
|
if (florhit < 0 || ceilhit < 0)
|
||||||
{
|
{
|
||||||
|
Printf("ERROR: FAFgetzrange() returned -1 for floor or ceiling check.\n");
|
||||||
|
Printf("Most likely a sprite has been placed too close to a white wall.\n");
|
||||||
|
Printf("spnum %d, sect %d, x %d, y %d, z %d, florhit %d, pic %d\n", SpriteNum, sp->sectnum, sp->x, sp->y, z - DIV2(SPRITEp_SIZE_Z(sp)), florhit, sp->picnum);
|
||||||
TerminateGame();
|
TerminateGame();
|
||||||
printf("ERROR: FAFgetzrange() returned -1 for floor or ceiling check.\n");
|
|
||||||
printf("Most likely a sprite has been placed too close to a white wall.\n");
|
|
||||||
printf("spnum %d, sect %d, x %d, y %d, z %d, florhit %d, pic %d\n", SpriteNum, sp->sectnum, sp->x, sp->y, z - DIV2(SPRITEp_SIZE_Z(sp)), florhit, sp->picnum);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if (florhit < 0 || ceilhit < 0)
|
if (florhit < 0 || ceilhit < 0)
|
||||||
|
|
|
@ -526,9 +526,7 @@ demosync_test(int cnt)
|
||||||
if (sync_val != (*SyncFunc[i])())
|
if (sync_val != (*SyncFunc[i])())
|
||||||
{
|
{
|
||||||
TerminateLevel();
|
TerminateLevel();
|
||||||
TerminateGame();
|
I_Error("Demo out of sync - Sync Byte Number %d - Iteration %d.", i, cnt);
|
||||||
printf("Demo out of sync - Sync Byte Number %d - Iteration %d.", i, cnt);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -880,9 +880,7 @@ SectorObjectSetupBounds(SECTOR_OBJECTp sop)
|
||||||
|
|
||||||
if (!FoundOutsideLoop)
|
if (!FoundOutsideLoop)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_Error("Forgot to tag outer loop for Sector Object #%d", (int)(sop - SectorObject));
|
||||||
printf("Forgot to tag outer loop for Sector Object #%d", (int)(sop - SectorObject));
|
|
||||||
exit(1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < (int)SIZ(StatList); i++)
|
for (i = 0; i < (int)SIZ(StatList); i++)
|
||||||
|
@ -3660,9 +3658,7 @@ ActorTrackDecide(TRACK_POINTp tpoint, short SpriteNum)
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
if (wall[hit_wall].nextsector < 0)
|
if (wall[hit_wall].nextsector < 0)
|
||||||
{
|
{
|
||||||
TerminateGame();
|
I_Error("Take out white wall ladder x = %d, y = %d",wall[hit_wall].x, wall[hit_wall].y);
|
||||||
printf("Take out white wall ladder x = %d, y = %d",wall[hit_wall].x, wall[hit_wall].y);
|
|
||||||
exit(0);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue