2007-06-21 22:00:00 +02:00
|
|
|
/*
|
|
|
|
Copyright (C) 1997-2001 Id Software, Inc.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License
|
|
|
|
as published by the Free Software Foundation; either version 2
|
|
|
|
of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
|
|
|
|
*/
|
|
|
|
// cl_parse.c -- parse a message received from the server
|
|
|
|
|
2008-06-09 22:00:00 +02:00
|
|
|
#include "common.h"
|
2007-06-21 22:00:00 +02:00
|
|
|
#include "client.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
===============
|
|
|
|
CL_CheckOrDownloadFile
|
|
|
|
|
|
|
|
Returns true if the file exists, otherwise it attempts
|
|
|
|
to start a download from the server.
|
|
|
|
===============
|
|
|
|
*/
|
2008-08-02 22:00:00 +02:00
|
|
|
bool CL_CheckOrDownloadFile( const char *filename )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-08-02 22:00:00 +02:00
|
|
|
string name;
|
|
|
|
file_t *f;
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
if( FS_FileExists( filename ))
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
|
|
|
// it exists, no need to download
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
com.strncpy( cls.downloadname, filename, MAX_STRING );
|
|
|
|
com.strncpy( cls.downloadtempname, filename, MAX_STRING );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
// download to a temp name, and only rename to the real name when done,
|
|
|
|
// so if interrupted a runt file won't be left
|
|
|
|
FS_StripExtension( cls.downloadtempname );
|
|
|
|
FS_DefaultExtension( cls.downloadtempname, ".tmp" );
|
|
|
|
com.strncpy( name, cls.downloadtempname, MAX_STRING );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
f = FS_Open( name, "a+b" );
|
|
|
|
if( f )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
|
|
|
// it exists
|
2008-11-27 22:00:00 +01:00
|
|
|
size_t len = FS_Tell( f );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
cls.download = f;
|
2007-06-21 22:00:00 +02:00
|
|
|
// give the server an offset to start the download
|
2008-08-02 22:00:00 +02:00
|
|
|
MsgDev( D_INFO, "Resume download %s at %i\n", cls.downloadname, len );
|
2008-07-15 22:00:00 +02:00
|
|
|
MSG_WriteByte( &cls.netchan.message, clc_stringcmd );
|
2008-08-02 22:00:00 +02:00
|
|
|
MSG_Print( &cls.netchan.message, va("download %s %i", cls.downloadname, len ));
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2008-08-02 22:00:00 +02:00
|
|
|
MsgDev( D_INFO, "Start download %s\n", cls.downloadname );
|
2008-07-15 22:00:00 +02:00
|
|
|
MSG_WriteByte( &cls.netchan.message, clc_stringcmd );
|
2008-08-02 22:00:00 +02:00
|
|
|
MSG_Print( &cls.netchan.message, va("download %s", cls.downloadname ));
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
cls.downloadnumber++;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
=====================
|
|
|
|
CL_ParseDownload
|
|
|
|
|
|
|
|
A download message has been received from the server
|
|
|
|
=====================
|
|
|
|
*/
|
2008-05-20 22:00:00 +02:00
|
|
|
void CL_ParseDownload( sizebuf_t *msg )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
|
|
|
int size, percent;
|
2008-05-20 22:00:00 +02:00
|
|
|
string name;
|
2007-06-21 22:00:00 +02:00
|
|
|
int r;
|
|
|
|
|
|
|
|
// read the data
|
2008-05-20 22:00:00 +02:00
|
|
|
size = MSG_ReadShort( msg );
|
|
|
|
percent = MSG_ReadByte( msg );
|
2008-08-02 22:00:00 +02:00
|
|
|
|
|
|
|
if( size == -1 )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-08-02 22:00:00 +02:00
|
|
|
Msg( "Server does not have this file.\n" );
|
|
|
|
if( cls.download )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
|
|
|
// if here, we tried to resume a file but the server said no
|
2008-08-02 22:00:00 +02:00
|
|
|
FS_Close( cls.download );
|
2007-06-21 22:00:00 +02:00
|
|
|
cls.download = NULL;
|
|
|
|
}
|
2008-08-02 22:00:00 +02:00
|
|
|
CL_RequestNextDownload();
|
2007-06-21 22:00:00 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// open the file if not opened yet
|
2008-08-02 22:00:00 +02:00
|
|
|
if( !cls.download )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-08-02 22:00:00 +02:00
|
|
|
com.strncpy( name, cls.downloadtempname, MAX_STRING );
|
|
|
|
cls.download = FS_Open ( name, "wb" );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
if( !cls.download )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-05-20 22:00:00 +02:00
|
|
|
msg->readcount += size;
|
2008-08-02 22:00:00 +02:00
|
|
|
Msg( "Failed to open %s\n", cls.downloadtempname );
|
|
|
|
CL_RequestNextDownload();
|
2007-06-21 22:00:00 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
FS_Write( cls.download, msg->data + msg->readcount, size );
|
2008-05-20 22:00:00 +02:00
|
|
|
msg->readcount += size;
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
if( percent != 100 )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
|
|
|
// request next block
|
2008-08-03 22:00:00 +02:00
|
|
|
Cvar_SetValue("scr_download", percent );
|
2008-07-15 22:00:00 +02:00
|
|
|
MSG_WriteByte( &cls.netchan.message, clc_stringcmd );
|
|
|
|
MSG_Print( &cls.netchan.message, "nextdl" );
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2008-07-23 22:00:00 +02:00
|
|
|
string oldn, newn;
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
FS_Close( cls.download );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
|
|
|
// rename the temp file to it's final name
|
2008-08-02 22:00:00 +02:00
|
|
|
com.strncpy( oldn, cls.downloadtempname, MAX_STRING );
|
|
|
|
com.strncpy( newn, cls.downloadname, MAX_STRING );
|
|
|
|
r = rename( oldn, newn );
|
|
|
|
if( r ) MsgDev( D_ERROR, "failed to rename.\n" );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
|
|
|
cls.download = NULL;
|
2008-11-27 22:00:00 +01:00
|
|
|
Cvar_SetValue( "scr_download", 0.0f );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
|
|
|
// get another file if needed
|
2008-08-02 22:00:00 +02:00
|
|
|
CL_RequestNextDownload();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-12-03 22:00:00 +01:00
|
|
|
void CL_RunBackgroundTrack( void )
|
|
|
|
{
|
|
|
|
string intro, main, track;
|
|
|
|
|
|
|
|
// run background track
|
|
|
|
com.strncpy( track, cl.configstrings[CS_BACKGROUND_TRACK], MAX_STRING );
|
|
|
|
com.snprintf( intro, MAX_STRING, "%s_intro", cl.configstrings[CS_BACKGROUND_TRACK] );
|
|
|
|
com.snprintf( main, MAX_STRING, "%s_main", cl.configstrings[CS_BACKGROUND_TRACK] );
|
|
|
|
|
|
|
|
if( FS_FileExists( va( "media/%s.ogg", intro )) && FS_FileExists( va( "media/%s.ogg", main )))
|
|
|
|
{
|
|
|
|
// combined track with introduction and main loop theme
|
|
|
|
S_StartBackgroundTrack( intro, main );
|
|
|
|
}
|
|
|
|
else if( FS_FileExists( va( "media/%s.ogg", track )))
|
|
|
|
{
|
|
|
|
// single looped theme
|
|
|
|
S_StartBackgroundTrack( track, track );
|
|
|
|
}
|
|
|
|
else if( !com.strcmp( track, "" ))
|
|
|
|
{
|
|
|
|
// blank name stopped last track
|
|
|
|
S_StopBackgroundTrack();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-12-21 22:00:00 +01:00
|
|
|
/*
|
|
|
|
==================
|
|
|
|
CL_ParseSoundPacket
|
|
|
|
|
|
|
|
==================
|
|
|
|
*/
|
|
|
|
void CL_ParseSoundPacket( sizebuf_t *msg )
|
|
|
|
{
|
|
|
|
vec3_t pos;
|
|
|
|
int channel, sound_num;
|
|
|
|
float volume, attenuation;
|
|
|
|
int flags, pitch, entnum;
|
|
|
|
|
|
|
|
flags = MSG_ReadByte( msg );
|
|
|
|
sound_num = MSG_ReadWord( msg );
|
|
|
|
channel = MSG_ReadByte( msg );
|
|
|
|
|
|
|
|
if( flags & SND_VOL )
|
|
|
|
volume = MSG_ReadByte( msg ) / 255.0f;
|
|
|
|
else volume = 1.0f;
|
|
|
|
if( flags & SND_ATTN )
|
|
|
|
attenuation = MSG_ReadByte( msg ) / 255.0f;
|
|
|
|
else attenuation = ATTN_NORM;
|
|
|
|
if( flags & SND_PITCH )
|
|
|
|
pitch = MSG_ReadByte( msg );
|
|
|
|
else pitch = PITCH_NORM;
|
|
|
|
|
|
|
|
// entity reletive
|
|
|
|
if( flags & SND_ENT )
|
|
|
|
entnum = MSG_ReadBits( msg, NET_WORD );
|
|
|
|
|
|
|
|
if( flags & SND_POS )
|
|
|
|
{
|
|
|
|
// positioned in space
|
|
|
|
MSG_ReadPos( msg, pos );
|
|
|
|
}
|
|
|
|
else VectorClear( pos );
|
|
|
|
|
|
|
|
S_StartSound( pos, entnum, channel, cl.sound_precache[sound_num], volume, attenuation, pitch );
|
|
|
|
}
|
|
|
|
|
2007-06-21 22:00:00 +02:00
|
|
|
/*
|
|
|
|
=====================================================================
|
|
|
|
|
|
|
|
SERVER CONNECTING MESSAGES
|
|
|
|
|
|
|
|
=====================================================================
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
==================
|
|
|
|
CL_ParseServerData
|
|
|
|
==================
|
|
|
|
*/
|
2008-05-20 22:00:00 +02:00
|
|
|
void CL_ParseServerData( sizebuf_t *msg )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2007-11-17 22:00:00 +01:00
|
|
|
char *str;
|
2007-06-21 22:00:00 +02:00
|
|
|
int i;
|
2007-10-19 22:00:00 +02:00
|
|
|
|
2008-07-11 22:00:00 +02:00
|
|
|
MsgDev(D_INFO, "Serverdata packet received.\n");
|
|
|
|
|
2007-11-04 22:00:00 +01:00
|
|
|
// wipe the client_t struct
|
2008-07-12 22:00:00 +02:00
|
|
|
CL_ClearState();
|
2007-06-21 22:00:00 +02:00
|
|
|
cls.state = ca_connected;
|
|
|
|
|
2007-09-10 22:00:00 +02:00
|
|
|
// parse protocol version number
|
2008-05-20 22:00:00 +02:00
|
|
|
i = MSG_ReadLong( msg );
|
2007-06-21 22:00:00 +02:00
|
|
|
cls.serverProtocol = i;
|
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
if( i != PROTOCOL_VERSION )
|
|
|
|
Host_Error("Server use invalid protocol (%i should be %i)\n", i, PROTOCOL_VERSION );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-05-20 22:00:00 +02:00
|
|
|
cl.servercount = MSG_ReadLong( msg );
|
|
|
|
cl.playernum = MSG_ReadShort( msg );
|
|
|
|
str = MSG_ReadString( msg );
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
// get splash name
|
2008-12-06 22:00:00 +01:00
|
|
|
Cvar_Set( "cl_levelshot_name", va( "media/background/%s.png", str ));
|
|
|
|
Cvar_SetValue( "scr_loading", 0.0f ); // reset progress bar
|
|
|
|
if(!FS_FileExists( Cvar_VariableString( "cl_levelshot_name" )))
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-12-06 22:00:00 +01:00
|
|
|
Cvar_Set( "cl_levelshot_name", "" );
|
2008-12-26 22:00:00 +01:00
|
|
|
cl.need_levelshot = true; // make levelshot
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
2008-08-02 22:00:00 +02:00
|
|
|
// seperate the printfs so the server message can have a color
|
|
|
|
Msg("\35\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\36\37\n");
|
2008-08-03 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
// need to prep refresh at next oportunity
|
2008-08-03 22:00:00 +02:00
|
|
|
cl.video_prepped = false;
|
|
|
|
cl.audio_prepped = false;
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
==================
|
|
|
|
CL_ParseBaseline
|
|
|
|
==================
|
|
|
|
*/
|
2008-05-20 22:00:00 +02:00
|
|
|
void CL_ParseBaseline( sizebuf_t *msg )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2007-10-29 22:00:00 +01:00
|
|
|
int newnum;
|
2007-06-21 22:00:00 +02:00
|
|
|
entity_state_t nullstate;
|
2008-12-25 22:00:00 +01:00
|
|
|
edict_t *ent;
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-12-25 22:00:00 +01:00
|
|
|
Mem_Set( &nullstate, 0, sizeof( nullstate ));
|
2008-07-15 22:00:00 +02:00
|
|
|
newnum = MSG_ReadBits( msg, NET_WORD );
|
2008-07-01 22:00:00 +02:00
|
|
|
|
2008-08-02 22:00:00 +02:00
|
|
|
// increase edicts
|
2008-12-26 22:00:00 +01:00
|
|
|
while( newnum >= clgame.numEntities ) CL_AllocEdict();
|
2008-12-25 22:00:00 +01:00
|
|
|
ent = EDICT_NUM( newnum );
|
2008-07-01 22:00:00 +02:00
|
|
|
|
2009-01-04 22:00:00 +01:00
|
|
|
Com_Assert( ent->pvClientData == NULL );
|
2008-12-26 22:00:00 +01:00
|
|
|
MSG_ReadDeltaEntity( msg, &nullstate, &ent->pvClientData->baseline, newnum );
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
================
|
|
|
|
CL_ParseConfigString
|
|
|
|
================
|
|
|
|
*/
|
2008-05-20 22:00:00 +02:00
|
|
|
void CL_ParseConfigString( sizebuf_t *msg )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-08-04 22:00:00 +02:00
|
|
|
int i;
|
2009-01-11 22:00:00 +01:00
|
|
|
float value;
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2008-05-20 22:00:00 +02:00
|
|
|
i = MSG_ReadShort( msg );
|
2008-08-02 22:00:00 +02:00
|
|
|
if( i < 0 || i >= MAX_CONFIGSTRINGS )
|
2009-01-04 22:00:00 +01:00
|
|
|
Host_Error( "configstring > MAX_CONFIGSTRINGS\n" );
|
2008-08-02 22:00:00 +02:00
|
|
|
com.strcpy( cl.configstrings[i], MSG_ReadString( msg ));
|
2009-01-04 22:00:00 +01:00
|
|
|
|
2007-06-21 22:00:00 +02:00
|
|
|
// do something apropriate
|
2008-11-28 22:00:00 +01:00
|
|
|
if( i == CS_SKYNAME && cl.video_prepped )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-11-09 22:00:00 +01:00
|
|
|
re->RegisterShader( cl.configstrings[CS_SKYNAME], SHADER_SKY );
|
2008-08-04 22:00:00 +02:00
|
|
|
}
|
2009-01-11 22:00:00 +01:00
|
|
|
else if( i == CS_MAXVELOCITY )
|
|
|
|
{
|
|
|
|
value = com.atof( cl.configstrings[CS_MAXVELOCITY] );
|
|
|
|
if( value > 0 ) clgame.maxVelocity = value;
|
|
|
|
else clgame.maxVelocity = com.atof( DEFAULT_MAXVELOCITY );
|
|
|
|
}
|
|
|
|
else if( i == CS_GRAVITY )
|
|
|
|
{
|
|
|
|
value = com.atof( cl.configstrings[CS_GRAVITY] );
|
|
|
|
if( value > 0 ) clgame.gravity = value;
|
|
|
|
else clgame.gravity = com.atof( DEFAULT_GRAVITY );
|
|
|
|
}
|
2008-11-28 22:00:00 +01:00
|
|
|
else if( i == CS_BACKGROUND_TRACK && cl.audio_prepped )
|
|
|
|
{
|
2008-12-03 22:00:00 +01:00
|
|
|
CL_RunBackgroundTrack();
|
2008-11-28 22:00:00 +01:00
|
|
|
}
|
2008-08-04 22:00:00 +02:00
|
|
|
else if( i >= CS_MODELS && i < CS_MODELS+MAX_MODELS && cl.video_prepped )
|
|
|
|
{
|
|
|
|
re->RegisterModel( cl.configstrings[i], i-CS_MODELS );
|
|
|
|
cl.models[i-CS_MODELS] = pe->RegisterModel( cl.configstrings[i] );
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
2008-08-04 22:00:00 +02:00
|
|
|
else if( i >= CS_SOUNDS && i < CS_SOUNDS+MAX_SOUNDS && cl.audio_prepped )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-08-04 22:00:00 +02:00
|
|
|
cl.sound_precache[i-CS_SOUNDS] = S_RegisterSound( cl.configstrings[i] );
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
2008-12-15 22:00:00 +01:00
|
|
|
else if( i >= CS_DECALS && i < CS_DECALS+MAX_DECALS && cl.video_prepped )
|
|
|
|
{
|
2009-01-16 22:00:00 +01:00
|
|
|
cl.decal_shaders[i-CS_DECALS] = re->RegisterShader( cl.configstrings[i], SHADER_GENERIC );
|
2008-12-15 22:00:00 +01:00
|
|
|
}
|
|
|
|
else if( i >= CS_USER_MESSAGES && i < CS_USER_MESSAGES+MAX_USER_MESSAGES )
|
|
|
|
{
|
2008-12-26 22:00:00 +01:00
|
|
|
CL_LinkUserMessage( cl.configstrings[i], i - CS_USER_MESSAGES );
|
2008-12-15 22:00:00 +01:00
|
|
|
}
|
2008-08-02 22:00:00 +02:00
|
|
|
else if( i >= CS_CLASSNAMES && i < CS_CLASSNAMES+MAX_CLASSNAMES )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-12-25 22:00:00 +01:00
|
|
|
// edicts classnames for search by classname on client
|
|
|
|
cl.edict_classnames[i-CS_CLASSNAMES] = MAKE_STRING( cl.configstrings[i] );
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
2008-08-02 22:00:00 +02:00
|
|
|
else if( i >= CS_LIGHTSTYLES && i < CS_LIGHTSTYLES+MAX_LIGHTSTYLES )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-08-02 22:00:00 +02:00
|
|
|
CL_SetLightstyle( i - CS_LIGHTSTYLES );
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-11-27 22:00:00 +01:00
|
|
|
/*
|
|
|
|
================
|
|
|
|
CL_ParseSetAngle
|
|
|
|
|
|
|
|
set the view angle to this absolute value
|
|
|
|
================
|
|
|
|
*/
|
|
|
|
void CL_ParseSetAngle( sizebuf_t *msg )
|
|
|
|
{
|
|
|
|
cl.viewangles[0] = MSG_ReadAngle16( msg );
|
|
|
|
cl.viewangles[1] = MSG_ReadAngle16( msg );
|
|
|
|
cl.viewangles[2] = MSG_ReadAngle16( msg );
|
|
|
|
}
|
2007-06-21 22:00:00 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
=====================================================================
|
|
|
|
|
|
|
|
ACTION MESSAGES
|
|
|
|
|
|
|
|
=====================================================================
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
=====================
|
|
|
|
CL_ParseServerMessage
|
|
|
|
=====================
|
|
|
|
*/
|
2008-05-20 22:00:00 +02:00
|
|
|
void CL_ParseServerMessage( sizebuf_t *msg )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-06-30 22:00:00 +02:00
|
|
|
char *s;
|
|
|
|
int cmd;
|
2007-06-21 22:00:00 +02:00
|
|
|
|
2007-08-17 22:00:00 +02:00
|
|
|
// parse the message
|
2008-05-20 22:00:00 +02:00
|
|
|
while( 1 )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-07-12 22:00:00 +02:00
|
|
|
if( msg->readcount > msg->cursize )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2007-09-10 22:00:00 +02:00
|
|
|
Host_Error("CL_ParseServerMessage: Bad server message\n");
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2008-05-20 22:00:00 +02:00
|
|
|
cmd = MSG_ReadByte( msg );
|
2008-07-12 22:00:00 +02:00
|
|
|
if( cmd == -1 ) break;
|
2008-07-15 22:00:00 +02:00
|
|
|
|
2007-08-17 22:00:00 +02:00
|
|
|
// other commands
|
2008-06-30 22:00:00 +02:00
|
|
|
switch( cmd )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
|
|
|
case svc_nop:
|
2008-06-30 22:00:00 +02:00
|
|
|
MsgDev( D_ERROR, "CL_ParseServerMessage: user message out of bounds\n" );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_disconnect:
|
2007-09-10 22:00:00 +02:00
|
|
|
CL_Drop ();
|
|
|
|
Host_AbortCurrentFrame();
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_reconnect:
|
2008-06-30 22:00:00 +02:00
|
|
|
Msg( "Server disconnected, reconnecting\n" );
|
|
|
|
if( cls.download )
|
2007-06-21 22:00:00 +02:00
|
|
|
{
|
2008-06-30 22:00:00 +02:00
|
|
|
FS_Close( cls.download );
|
2007-06-21 22:00:00 +02:00
|
|
|
cls.download = NULL;
|
|
|
|
}
|
|
|
|
cls.state = ca_connecting;
|
2008-06-30 22:00:00 +02:00
|
|
|
cls.connect_time = MAX_HEARTBEAT; // CL_CheckForResend() will fire immediately
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_stufftext:
|
2008-05-20 22:00:00 +02:00
|
|
|
s = MSG_ReadString( msg );
|
2008-06-30 22:00:00 +02:00
|
|
|
Cbuf_AddText( s );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_serverdata:
|
2008-08-02 22:00:00 +02:00
|
|
|
Cbuf_Execute(); // make sure any stuffed commands are done
|
2008-05-20 22:00:00 +02:00
|
|
|
CL_ParseServerData( msg );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_configstring:
|
2008-05-20 22:00:00 +02:00
|
|
|
CL_ParseConfigString( msg );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_spawnbaseline:
|
2008-05-20 22:00:00 +02:00
|
|
|
CL_ParseBaseline( msg );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_download:
|
2008-05-20 22:00:00 +02:00
|
|
|
CL_ParseDownload( msg );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
2008-12-21 22:00:00 +01:00
|
|
|
case svc_sound:
|
|
|
|
CL_ParseSoundPacket( msg );
|
|
|
|
break;
|
2008-11-27 22:00:00 +01:00
|
|
|
case svc_setangle:
|
|
|
|
CL_ParseSetAngle( msg );
|
|
|
|
break;
|
2008-12-26 22:00:00 +01:00
|
|
|
case svc_print:
|
|
|
|
Con_Print( va( "^6%s\n", MSG_ReadString( msg )));
|
|
|
|
break;
|
2007-06-21 22:00:00 +02:00
|
|
|
case svc_frame:
|
2008-05-20 22:00:00 +02:00
|
|
|
CL_ParseFrame( msg );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
2008-08-11 22:00:00 +02:00
|
|
|
case svc_playerinfo:
|
2007-06-21 22:00:00 +02:00
|
|
|
case svc_packetentities:
|
|
|
|
case svc_deltapacketentities:
|
2008-08-02 22:00:00 +02:00
|
|
|
Host_Error( "CL_ParseServerMessage: out of place frame data\n" );
|
2008-06-30 22:00:00 +02:00
|
|
|
break;
|
|
|
|
case svc_bad:
|
2008-08-02 22:00:00 +02:00
|
|
|
Host_Error( "CL_ParseServerMessage: svc_bad\n" );
|
2007-06-21 22:00:00 +02:00
|
|
|
break;
|
2007-11-17 22:00:00 +01:00
|
|
|
default:
|
2008-12-25 22:00:00 +01:00
|
|
|
CL_ParseUserMessage( msg, cmd );
|
2007-11-17 22:00:00 +01:00
|
|
|
break;
|
2007-06-21 22:00:00 +02:00
|
|
|
}
|
|
|
|
}
|
2008-06-30 22:00:00 +02:00
|
|
|
}
|