summaryrefslogtreecommitdiff
path: root/src/cgame
diff options
context:
space:
mode:
Diffstat (limited to 'src/cgame')
-rw-r--r--src/cgame/cg_ents.c16
-rw-r--r--src/cgame/cg_local.h3
-rw-r--r--src/cgame/cg_predict.c20
-rw-r--r--src/cgame/cg_weapons.c15
4 files changed, 31 insertions, 23 deletions
diff --git a/src/cgame/cg_ents.c b/src/cgame/cg_ents.c
index b56a1a40..682d8aad 100644
--- a/src/cgame/cg_ents.c
+++ b/src/cgame/cg_ents.c
@@ -549,9 +549,15 @@ static void CG_LightFlare( centity_t *cent )
float maxAngle;
vec3_t mins, maxs, start, end;
float srcRadius, srLocal, ratio = 1.0f;
+ int entityNum;
es = &cent->currentState;
+ if( cg.renderingThirdPerson )
+ entityNum = MAGIC_TRACE_HACK;
+ else
+ entityNum = cg.predictedPlayerState.clientNum;
+
//don't draw light flares
if( cg_lightFlare.integer == FLARE_OFF )
return;
@@ -561,7 +567,7 @@ static void CG_LightFlare( centity_t *cent )
return;
CG_Trace( &tr, cg.refdef.vieworg, NULL, NULL, es->angles2,
- cg.predictedPlayerState.clientNum, MASK_SHOT );
+ entityNum, MASK_SHOT );
//if there is no los between the view and the flare source
//it definately cannot be seen
@@ -636,7 +642,7 @@ static void CG_LightFlare( centity_t *cent )
srLocal += RADIUSSTEP;
SETBOUNDS( mins, maxs, srLocal );
CG_Trace( &tr, start, mins, maxs, end,
- cg.predictedPlayerState.clientNum, MASK_SHOT );
+ entityNum, MASK_SHOT );
} while( ( tr.fraction == 1.0f && !tr.startsolid ) && ( srLocal < srcRadius ) );
@@ -647,7 +653,7 @@ static void CG_LightFlare( centity_t *cent )
{
SETBOUNDS( mins, maxs, srLocal );
CG_Trace( &tr, start, mins, maxs, end,
- cg.predictedPlayerState.clientNum, MASK_SHOT );
+ entityNum, MASK_SHOT );
srLocal -= RADIUSSTEP;
} while( ( tr.fraction < 1.0f || tr.startsolid ) && ( srLocal > 0.0f ) );
@@ -661,7 +667,7 @@ static void CG_LightFlare( centity_t *cent )
//draw timed flares
SETBOUNDS( mins, maxs, srcRadius );
CG_Trace( &tr, start, mins, maxs, end,
- cg.predictedPlayerState.clientNum, MASK_SHOT );
+ entityNum, MASK_SHOT );
if( ( tr.fraction < 1.0f || tr.startsolid ) && cent->lfs.status )
{
@@ -698,7 +704,7 @@ static void CG_LightFlare( centity_t *cent )
//draw nofade flares
SETBOUNDS( mins, maxs, srcRadius );
CG_Trace( &tr, start, mins, maxs, end,
- cg.predictedPlayerState.clientNum, MASK_SHOT );
+ entityNum, MASK_SHOT );
//flare source occluded
if( ( tr.fraction < 1.0f || tr.startsolid ) )
diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h
index 14527607..ccd8789e 100644
--- a/src/cgame/cg_local.h
+++ b/src/cgame/cg_local.h
@@ -1562,6 +1562,9 @@ void CG_ModelDoor( centity_t *cent );
//
// cg_predict.c
//
+
+#define MAGIC_TRACE_HACK -2
+
void CG_BuildSolidList( void );
int CG_PointContents( const vec3_t point, int passEntityNum );
void CG_Trace( trace_t *result, const vec3_t start, const vec3_t mins, const vec3_t maxs, const vec3_t end,
diff --git a/src/cgame/cg_predict.c b/src/cgame/cg_predict.c
index a8285306..a68d58f6 100644
--- a/src/cgame/cg_predict.c
+++ b/src/cgame/cg_predict.c
@@ -81,7 +81,7 @@ CG_ClipMoveToEntities
static void CG_ClipMoveToEntities ( const vec3_t start, const vec3_t mins, const vec3_t maxs, const vec3_t end,
int skipNumber, int mask, trace_t *tr, qboolean capsule )
{
- int i, x, zd, zu;
+ int i, j, x, zd, zu;
trace_t trace;
entityState_t *ent;
clipHandle_t cmodel;
@@ -89,9 +89,20 @@ static void CG_ClipMoveToEntities ( const vec3_t start, const vec3_t mins, const
vec3_t origin, angles;
centity_t *cent;
- for( i = 0; i < cg_numSolidEntities; i++ )
+ //SUPAR HACK
+ //this causes a trace to collide with the local player
+ if( skipNumber == MAGIC_TRACE_HACK )
+ j = cg_numSolidEntities + 1;
+ else
+ j = cg_numSolidEntities;
+
+ for( i = 0; i < j; i++ )
{
- cent = cg_solidEntities[ i ];
+ if( i < cg_numSolidEntities )
+ cent = cg_solidEntities[ i ];
+ else
+ cent = &cg.predictedPlayerEntity;
+
ent = &cent->currentState;
if( ent->number == skipNumber )
@@ -116,6 +127,9 @@ static void CG_ClipMoveToEntities ( const vec3_t start, const vec3_t mins, const
bmins[ 2 ] = -zd;
bmaxs[ 2 ] = zu;
+ if( i == cg_numSolidEntities )
+ BG_FindBBoxForClass( ( ent->powerups >> 8 ) & 0xFF, bmins, bmaxs, NULL, NULL, NULL );
+
cmodel = trap_CM_TempBoxModel( bmins, bmaxs );
VectorCopy( vec3_origin, angles );
VectorCopy( cent->lerpOrigin, origin );
diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c
index 9af1a76b..cdd77d47 100644
--- a/src/cgame/cg_weapons.c
+++ b/src/cgame/cg_weapons.c
@@ -445,9 +445,6 @@ static qboolean CG_ParseWeaponModeSection( weaponInfoMode_t *wim, char **text_p
wim->impactSound[ index ] = trap_S_RegisterSound( token, qfalse );
- if( !wim->impactSound[ index ] )
- CG_Printf( S_COLOR_RED "ERROR: impact sound %d not found %s\n", index, token );
-
continue;
}
else if( !Q_stricmp( token, "impactDlightColor" ) )
@@ -543,9 +540,6 @@ static qboolean CG_ParseWeaponModeSection( weaponInfoMode_t *wim, char **text_p
wim->firingSound = trap_S_RegisterSound( token, qfalse );
- if( !wim->firingSound )
- CG_Printf( S_COLOR_RED "ERROR: firing sound not found %s\n", token );
-
continue;
}
else if( !Q_stricmp( token, "missileSound" ) )
@@ -556,9 +550,6 @@ static qboolean CG_ParseWeaponModeSection( weaponInfoMode_t *wim, char **text_p
wim->missileSound = trap_S_RegisterSound( token, qfalse );
- if( !wim->missileSound )
- CG_Printf( S_COLOR_RED "ERROR: missile sound not found %s\n", token );
-
continue;
}
else if( !Q_stricmp( token, "flashSound" ) )
@@ -582,9 +573,6 @@ static qboolean CG_ParseWeaponModeSection( weaponInfoMode_t *wim, char **text_p
wim->flashSound[ index ] = trap_S_RegisterSound( token, qfalse );
- if( !wim->flashSound[ index ] )
- CG_Printf( S_COLOR_RED "ERROR: flash sound %d not found %s\n", index, token );
-
continue;
}
else if( !Q_stricmp( token, "}" ) )
@@ -720,9 +708,6 @@ static qboolean CG_ParseWeaponFile( const char *filename, weaponInfo_t *wi )
wi->readySound = trap_S_RegisterSound( token, qfalse );
- if( !wi->readySound )
- CG_Printf( S_COLOR_RED "ERROR: weapon idle sound not found %s\n", token );
-
continue;
}
else if( !Q_stricmp( token, "icon" ) )