diff --git a/dlls/hgrunt.cpp b/dlls/hgrunt.cpp index 7f7e39e5..2f1dffbd 100644 --- a/dlls/hgrunt.cpp +++ b/dlls/hgrunt.cpp @@ -849,27 +849,30 @@ void CHGrunt::HandleAnimEvent( MonsterEvent_t *pEvent ) { case HGRUNT_AE_DROP_GUN: { - Vector vecGunPos; - Vector vecGunAngles; + if ( GetBodygroup( GUN_GROUP ) != GUN_NONE ) + { + Vector vecGunPos; + Vector vecGunAngles; - GetAttachment( 0, vecGunPos, vecGunAngles ); + GetAttachment( 0, vecGunPos, vecGunAngles ); - // switch to body group with no gun. - SetBodygroup( GUN_GROUP, GUN_NONE ); + // switch to body group with no gun. + SetBodygroup( GUN_GROUP, GUN_NONE ); - // now spawn a gun. - if( FBitSet( pev->weapons, HGRUNT_SHOTGUN ) ) - { - DropItem( "weapon_shotgun", vecGunPos, vecGunAngles ); - } - else - { - DropItem( "weapon_9mmAR", vecGunPos, vecGunAngles ); - } + // now spawn a gun. + if( FBitSet( pev->weapons, HGRUNT_SHOTGUN ) ) + { + DropItem( "weapon_shotgun", vecGunPos, vecGunAngles ); + } + else + { + DropItem( "weapon_9mmAR", vecGunPos, vecGunAngles ); + } - if( FBitSet( pev->weapons, HGRUNT_GRENADELAUNCHER ) ) - { - DropItem( "ammo_ARgrenades", BodyTarget( pev->origin ), vecGunAngles ); + if( FBitSet( pev->weapons, HGRUNT_GRENADELAUNCHER ) ) + { + DropItem( "ammo_ARgrenades", BodyTarget( pev->origin ), vecGunAngles ); + } } } break;