diff options
author | Ben Millwood <thebenmachine@gmail.com> | 2011-02-25 17:46:55 +0000 |
---|---|---|
committer | Tim Angus <tim@ngus.net> | 2013-01-03 00:18:02 +0000 |
commit | f1085879e51d2fb79c06940fb9b218dc61726dc5 (patch) | |
tree | d8648d1dfb9977bc400fc6eba4ee1d3dfa758999 | |
parent | bb05f256529f7df15e21168fd8fe79f439f22ca9 (diff) |
* Make weapon registration error reporting less touchy and more informative
-rw-r--r-- | src/cgame/cg_draw.c | 12 | ||||
-rw-r--r-- | src/cgame/cg_weapons.c | 28 |
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++; } |