*/
// host.c -- coordinates spawning and killing of local servers
-#include <time.h>
#include "quakedef.h"
+
+#include <time.h>
#include "libcurl.h"
#include "cdaudio.h"
+#include "cl_gecko.h"
#include "cl_video.h"
#include "progsvm.h"
#include "csprogs.h"
+#include "sv_demo.h"
/*
// shows time used by certain subsystems
cvar_t host_speeds = {0, "host_speeds","0", "reports how much time is used in server/graphics/sound"};
// LordHavoc: framerate upper cap
-cvar_t cl_maxfps = {CVAR_SAVE, "cl_maxfps", "1000", "maximum fps cap, if game is running faster than this it will wait before running another frame (useful to make cpu time available to other programs)"};
-cvar_t cl_maxidlefps = {CVAR_SAVE, "cl_maxidlefps", "10", "maximum fps cap when the game is not the active window (makes cpu time available to other programs"};
+cvar_t cl_maxfps = {CVAR_SAVE, "cl_maxfps", "1000000", "maximum fps cap, if game is running faster than this it will wait before running another frame (useful to make cpu time available to other programs)"};
+cvar_t cl_maxidlefps = {CVAR_SAVE, "cl_maxidlefps", "20", "maximum fps cap when the game is not the active window (makes cpu time available to other programs"};
cvar_t developer = {0, "developer","0", "prints additional debugging messages and information (recommended for modders and level designers)"};
cvar_t developer_entityparsing = {0, "developer_entityparsing", "0", "prints detailed network entities information each time a packet is received"};
int i;
Con_Printf("Client \"%s\" dropped\n", host_client->name);
+ SV_StopDemoRecording(host_client);
+
// make sure edict is not corrupt (from a level change for example)
host_client->edict = PRVM_EDICT_NUM(host_client - svs.clients + 1);
// update server listing on the master because player count changed
// (which the master uses for filtering empty/full servers)
NetConn_Heartbeat(1);
+
+ if (sv.loadgame)
+ {
+ for (i = 0;i < svs.maxclients;i++)
+ if (svs.clients[i].active && !svs.clients[i].spawned)
+ break;
+ if (i == svs.maxclients)
+ {
+ Con_Printf("Loaded game, everyone rejoined - unpausing\n");
+ sv.paused = sv.loadgame = false; // we're basically done with loading now
+ }
+ }
}
/*
==================
Host_TimeReport
-Returns a time report string, for example for
+Returns a time report string, for example for
==================
*/
const char *Host_TimingReport()
svs.perf_acc_realtime = svs.perf_acc_sleeptime = svs.perf_acc_lost = svs.perf_acc_offset = svs.perf_acc_offset_squared = svs.perf_acc_offset_max = svs.perf_acc_offset_samples = 0;
}
- if (slowmo.value < 0)
+ if (slowmo.value < 0.00001 && slowmo.value != 0)
Cvar_SetValue("slowmo", 0);
if (host_framerate.value < 0.00001 && host_framerate.value != 0)
Cvar_SetValue("host_framerate", 0);
- if (cl_maxfps.value < 1)
- Cvar_SetValue("cl_maxfps", 1);
// keep the random time dependent, but not when playing demos/benchmarking
if(!*sv_random_seed.string && !cls.demoplayback)
}
}
else if (vid_activewindow)
- clframetime = cl.realframetime = max(cl_timer, 1.0 / cl_maxfps.value);
+ clframetime = cl.realframetime = max(cl_timer, 1.0 / max(5.0f, cl_maxfps.value));
else
- clframetime = cl.realframetime = max(cl_timer, 1.0 / cl_maxidlefps.value);
+ clframetime = cl.realframetime = max(cl_timer, 1.0 / max(5.0f, cl_maxidlefps.value));
// apply slowmo scaling
clframetime *= cl.movevars_timescale;
//ui_update();
- CL_VideoFrame();
+ CL_Video_Frame();
+#ifdef SUPPORT_GECKO
+ CL_Gecko_Frame();
+#endif
CL_UpdateScreen();
int i;
const char* os;
+ if (COM_CheckParm("-profilegameonly"))
+ Sys_AllowProfiling(false);
+
// LordHavoc: quake never seeded the random number generator before... heh
if (COM_CheckParm("-benchmark"))
srand(0); // predictable random sequence for -benchmark
// AK shutdown PRVM
// AK hmm, no PRVM_Shutdown(); yet
+#ifdef SUPPORT_GECKO
+ CL_Gecko_Shutdown();
+#endif
CL_Video_Shutdown();
Host_SaveConfig_f();