summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBen Millwood <thebenmachine@gmail.com>2011-02-25 17:46:55 +0000
committerTim Angus <tim@ngus.net>2013-01-03 00:18:02 +0000
commitf1085879e51d2fb79c06940fb9b218dc61726dc5 (patch)
treed8648d1dfb9977bc400fc6eba4ee1d3dfa758999
parentbb05f256529f7df15e21168fd8fe79f439f22ca9 (diff)
* Make weapon registration error reporting less touchy and more informative
-rw-r--r--src/cgame/cg_draw.c12
-rw-r--r--src/cgame/cg_weapons.c28
2 files changed, 34 insertions, 6 deletions
diff --git a/src/cgame/cg_draw.c b/src/cgame/cg_draw.c
index 9797e779..f6950cae 100644
--- a/src/cgame/cg_draw.c
+++ b/src/cgame/cg_draw.c
@@ -2469,10 +2469,18 @@ void CG_DrawWeaponIcon( rectDef_t *rect, vec4_t color )
if( cg.predictedPlayerState.stats[ STAT_HEALTH ] <= 0 )
return;
- if( weapon == 0 )
+ if( weapon <= WP_NONE || weapon >= WP_NUM_WEAPONS )
+ {
+ CG_Error( "CG_DrawWeaponIcon: weapon out of range: %d\n", weapon );
return;
+ }
- assert( cg_weapons[ weapon ].registered );
+ if( !cg_weapons[ weapon ].registered )
+ {
+ Com_Printf( S_COLOR_YELLOW "WARNING: CG_DrawWeaponIcon: weapon %d (%s) "
+ "is not registered\n", weapon, BG_Weapon( weapon )->name );
+ return;
+ }
if( ps->clips == 0 && !BG_Weapon( weapon )->infiniteAmmo )
{
diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c
index 49c9e284..9fd6f04e 100644
--- a/src/cgame/cg_weapons.c
+++ b/src/cgame/cg_weapons.c
@@ -1004,7 +1004,12 @@ void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent
firing = qfalse;
weapon = &cg_weapons[ weaponNum ];
- assert( weapon->registered );
+ if( !weapon->registered )
+ {
+ Com_Printf( S_COLOR_YELLOW "WARNING: CG_AddPlayerWeapon: weapon %d (%s) "
+ "is not registered\n", weaponNum, BG_Weapon( weaponNum )->name );
+ return;
+ }
// add the weapon
Com_Memset( &gun, 0, sizeof( gun ) );
@@ -1227,7 +1232,12 @@ void CG_AddViewWeapon( playerState_t *ps )
weaponMode = WPM_PRIMARY;
wi = &cg_weapons[ weapon ];
- assert( wi->registered );
+ if( !wi->registered )
+ {
+ Com_Printf( S_COLOR_YELLOW "WARNING: CG_AddViewWeapon: weapon %d (%s) "
+ "is not registered\n", weapon, BG_Weapon( weapon )->name );
+ return;
+ }
cent = &cg.predictedPlayerEntity; // &cg_entities[cg.snap->ps.clientNum];
if( ps->persistant[PERS_SPECSTATE] != SPECTATOR_NOT )
@@ -1427,7 +1437,12 @@ void CG_DrawItemSelect( rectDef_t *rect, vec4_t color )
if( i == cg.weaponSelect )
selectedItem = numItems;
- assert( cg_weapons[ i ].registered );
+ if( !cg_weapons[ i ].registered )
+ {
+ Com_Printf( S_COLOR_YELLOW "WARNING: CG_DrawItemSelect: weapon %d (%s) "
+ "is not registered\n", i, BG_Weapon( i )->name );
+ continue;
+ }
items[ numItems ] = i;
numItems++;
}
@@ -1444,7 +1459,12 @@ void CG_DrawItemSelect( rectDef_t *rect, vec4_t color )
if( i == cg.weaponSelect - 32 )
selectedItem = numItems;
- assert( cg_upgrades[ i ].registered );
+ if( !cg_upgrades[ i ].registered )
+ {
+ Com_Printf( S_COLOR_YELLOW "WARNING: CG_DrawItemSelect: upgrade %d (%s) "
+ "is not registered\n", i, BG_Upgrade( i )->name );
+ continue;
+ }
items[ numItems ] = i + 32;
numItems++;
}