Allow ally human grunts have no weapons. Fix #401 (#403)

This commit is contained in:
Roman Chistokhodov 2023-11-07 21:44:05 +03:00 committed by GitHub
parent 7b8f05c29b
commit 5914b5779f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1361,7 +1361,7 @@ int CHFGrunt :: ISoundMask ( void)
//========================================================= //=========================================================
void CHFGrunt :: CheckAmmo ( void ) void CHFGrunt :: CheckAmmo ( void )
{ {
if ( m_cAmmoLoaded <= 0 ) if ( pev->weapons != 0 && m_cAmmoLoaded <= 0 )
{ {
SetConditions(bits_COND_NO_AMMO_LOADED); SetConditions(bits_COND_NO_AMMO_LOADED);
} }
@ -1530,7 +1530,7 @@ BOOL CHFGrunt :: CheckMeleeAttack1 ( float flDot, float flDist )
//========================================================= //=========================================================
BOOL CHFGrunt :: CheckRangeAttack1 ( float flDot, float flDist ) BOOL CHFGrunt :: CheckRangeAttack1 ( float flDot, float flDist )
{ {
if ( !HasConditions( bits_COND_ENEMY_OCCLUDED ) && flDist <= 2048 && flDot >= 0.5 && NoFriendlyFire() && ( GetBodygroup( 3 ) != 3 ) ) if ( !HasConditions( bits_COND_ENEMY_OCCLUDED ) && flDist <= 2048 && flDot >= 0.5 && NoFriendlyFire() && GetBodygroup( FG_GUN_GROUP ) != FG_GUN_NONE )
{ {
TraceResult tr; TraceResult tr;
@ -1991,33 +1991,38 @@ void CHFGrunt :: Spawn()
{ {
m_iHead = RANDOM_LONG(FG_HEAD_SAW, FG_HEAD_SAW_BLACK); m_iHead = RANDOM_LONG(FG_HEAD_SAW, FG_HEAD_SAW_BLACK);
} }
else if (pev->weapons == 0)
{
m_iHead = FG_HEAD_MP;
}
else else
m_iHead = FG_HEAD_MASK; m_iHead = FG_HEAD_MASK;
} }
else if ( m_iHead >= FG_HEAD_COUNT ) else if ( m_iHead >= FG_HEAD_COUNT )
m_iHead = FG_HEAD_MASK; m_iHead = FG_HEAD_MASK;
if ( pev->weapons <= 0 )
{
pev->weapons = FGRUNT_9MMAR;
}
if (FBitSet( pev->weapons, FGRUNT_SHOTGUN ))
{
SetBodygroup( FG_GUN_GROUP, FG_GUN_SHOTGUN );
SetBodygroup( FG_TORSO_GROUP, FG_TORSO_SHOTGUN );
m_cClipSize = 8;
}
if (FBitSet( pev->weapons, FGRUNT_9MMAR )) if (FBitSet( pev->weapons, FGRUNT_9MMAR ))
{ {
SetBodygroup( FG_GUN_GROUP, FG_GUN_MP5 ); SetBodygroup( FG_GUN_GROUP, FG_GUN_MP5 );
m_cClipSize = FGRUNT_CLIP_SIZE; m_cClipSize = FGRUNT_CLIP_SIZE;
} }
if (FBitSet( pev->weapons, FGRUNT_M249 )) else if (FBitSet( pev->weapons, FGRUNT_SHOTGUN ))
{
SetBodygroup( FG_GUN_GROUP, FG_GUN_SHOTGUN );
SetBodygroup( FG_TORSO_GROUP, FG_TORSO_SHOTGUN );
m_cClipSize = 8;
}
else if (FBitSet( pev->weapons, FGRUNT_M249 ))
{ {
SetBodygroup( FG_GUN_GROUP, FG_GUN_SAW ); SetBodygroup( FG_GUN_GROUP, FG_GUN_SAW );
SetBodygroup( FG_TORSO_GROUP, FG_TORSO_M249 ); SetBodygroup( FG_TORSO_GROUP, FG_TORSO_M249 );
m_cClipSize = FGRUNT_CLIP_SIZE; m_cClipSize = FGRUNT_CLIP_SIZE;
} }
else
{
SetBodygroup( FG_GUN_GROUP, FG_GUN_NONE );
m_cClipSize = 0;
}
SetBodygroup( FG_HEAD_GROUP, m_iHead ); SetBodygroup( FG_HEAD_GROUP, m_iHead );
@ -2372,7 +2377,7 @@ Schedule_t* CHFGrunt :: GetScheduleOfType ( int Type )
break; break;
case SCHED_HGRUNT_ALLY_ELOF_FAIL: case SCHED_HGRUNT_ALLY_ELOF_FAIL:
{ {
return GetScheduleOfType( SCHED_RANGE_ATTACK1 ); return GetScheduleOfType( SCHED_TAKE_COVER_FROM_ENEMY );
} }
break; break;
case SCHED_HGRUNT_ALLY_ESTABLISH_LINE_OF_FIRE: case SCHED_HGRUNT_ALLY_ESTABLISH_LINE_OF_FIRE: