cvar_t timestamps = {CVAR_SAVE, "timestamps", "0"};
cvar_t timeformat = {CVAR_SAVE, "timeformat", "[%b %e %X] "};
-/*
-================
-Host_EndGame
-================
-*/
-void Host_EndGame (const char *format, ...)
-{
- va_list argptr;
- char string[1024];
-
- va_start (argptr,format);
- vsprintf (string,format,argptr);
- va_end (argptr);
- Con_DPrintf("Host_EndGame: %s\n",string);
-
- if (sv.active)
- Host_ShutdownServer (false);
-
- if (cls.state == ca_dedicated)
- Sys_Error ("Host_EndGame: %s\n",string); // dedicated servers exit
-
- if (cls.demonum != -1)
- CL_NextDemo ();
- else
- CL_Disconnect ();
-
- longjmp (host_abortserver, 1);
-}
-
/*
================
Host_Error
PRVM_ProcessError();
- if (sv.active)
- Host_ShutdownServer (false);
+ Host_ShutdownServer (false);
if (cls.state == ca_dedicated)
Sys_Error ("Host_Error: %s\n",hosterrorstring2); // dedicated servers exit
sizebuf_t buf;
char message[4];
+ Con_DPrintf("Host_ShutdownServer\n");
+
if (!sv.active)
return;
// print out where the crash happened, if it was caused by QC
PR_Crash();
- sv.active = false;
-
-// stop all client sounds immediately
- CL_Disconnect();
-
NetConn_Heartbeat(2);
NetConn_Heartbeat(2);
NetConn_CloseServerPorts();
+ sv.active = false;
+
//
// clear structures
//
*/
void Host_Init (void)
{
+ int i;
+
// LordHavoc: quake never seeded the random number generator before... heh
srand(time(NULL));
Cbuf_InsertText("exec teu.rc\n");
else
Cbuf_InsertText("exec quake.rc\n");
+
+ // check for special benchmark mode
+ i = COM_CheckParm("-benchmark");
+ if (i && i + 1 < com_argc)
+ Cbuf_InsertText(va("timedemo %s\n", com_argv[i + 1]));
+
Cbuf_Execute();
+
+ // We must wait for the log_file cvar to be initialized to start the log
+ Log_Start ();
}