From: cloudwalk Date: Mon, 30 Nov 2020 18:11:10 +0000 (+0000) Subject: cl_demo: Fix demo loop playback bugs. Should behave like Quake again. X-Git-Url: http://git.xonotic.org/?p=xonotic%2Fdarkplaces.git;a=commitdiff_plain;h=dda36cceb63d6454348bb583db55f85dd203bb4a;hp=f1319d4e655eb486d830e0337d9b4e25bad79ee4 cl_demo: Fix demo loop playback bugs. Should behave like Quake again. git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@13059 d7cf8633-e32d-0410-b094-e92efae38249 --- diff --git a/cl_demo.c b/cl_demo.c index 4b91f9e3..6858aea6 100644 --- a/cl_demo.c +++ b/cl_demo.c @@ -99,9 +99,6 @@ void CL_StopPlayback (void) if (!cls.demostarting) // only quit if not starting another demo if (Sys_CheckParm("-demo") || Sys_CheckParm("-capturedemo")) host.state = host_shutdown; - - cls.demonum = -1; - } /* @@ -409,7 +406,7 @@ void CL_Record_f(cmd_state_t *cmd) ==================== CL_PlayDemo_f -play [demoname] +playdemo [demoname] ==================== */ void CL_PlayDemo_f(cmd_state_t *cmd) @@ -421,7 +418,7 @@ void CL_PlayDemo_f(cmd_state_t *cmd) if (Cmd_Argc(cmd) != 2) { - Con_Print("play : plays a demo\n"); + Con_Print("playdemo : plays a demo\n"); return; } @@ -439,8 +436,10 @@ void CL_PlayDemo_f(cmd_state_t *cmd) cls.demostarting = true; // disconnect from server - CL_Disconnect (); - SV_Shutdown (); + if(cls.state == ca_connected) + CL_Disconnect(); + if(sv.active) + SV_Shutdown(); // update networking ports (this is mainly just needed at startup) NetConn_UpdateSockets(); @@ -695,8 +694,7 @@ static void CL_Stopdemo_f(cmd_state_t *cmd) { if (!cls.demoplayback) return; - CL_Disconnect (); - SV_Shutdown (); + CL_Disconnect(); } // LadyHavoc: pausedemo command