mirror of
https://github.com/mapbase-source/source-sdk-2013.git
synced 2025-01-13 23:37:58 +03:00
Fixed zombie serverside ragdoll gibs crashing when one of the models isn't valid
This commit is contained in:
parent
ad4adf90ca
commit
39ec4ee704
@ -2354,6 +2354,8 @@ void CNPC_BaseZombie::BecomeTorso( const Vector &vecTorsoForce, const Vector &ve
|
|||||||
if ( m_bForceServerRagdoll )
|
if ( m_bForceServerRagdoll )
|
||||||
{
|
{
|
||||||
pGib = CreateServerRagdollSubmodel( this, GetLegsModel(), GetAbsOrigin() - Vector(0, 0, 40), GetAbsAngles(), COLLISION_GROUP_INTERACTIVE_DEBRIS );
|
pGib = CreateServerRagdollSubmodel( this, GetLegsModel(), GetAbsOrigin() - Vector(0, 0, 40), GetAbsAngles(), COLLISION_GROUP_INTERACTIVE_DEBRIS );
|
||||||
|
if (pGib && pGib->VPhysicsGetObject())
|
||||||
|
{
|
||||||
pGib->VPhysicsGetObject()->AddVelocity( &vecLegsForce, NULL );
|
pGib->VPhysicsGetObject()->AddVelocity( &vecLegsForce, NULL );
|
||||||
|
|
||||||
if (flFadeTime > 0.0)
|
if (flFadeTime > 0.0)
|
||||||
@ -2361,6 +2363,7 @@ void CNPC_BaseZombie::BecomeTorso( const Vector &vecTorsoForce, const Vector &ve
|
|||||||
pGib->SUB_StartFadeOut( flFadeTime, false );
|
pGib->SUB_StartFadeOut( flFadeTime, false );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
pGib = CreateRagGib( GetLegsModel(), GetAbsOrigin() - Vector(0, 0, 40), GetAbsAngles(), vecLegsForce, flFadeTime );
|
pGib = CreateRagGib( GetLegsModel(), GetAbsOrigin() - Vector(0, 0, 40), GetAbsAngles(), vecLegsForce, flFadeTime );
|
||||||
#else
|
#else
|
||||||
@ -2506,12 +2509,15 @@ void CNPC_BaseZombie::ReleaseHeadcrab( const Vector &vecOrigin, const Vector &ve
|
|||||||
if ( m_bForceServerRagdoll )
|
if ( m_bForceServerRagdoll )
|
||||||
{
|
{
|
||||||
pGib = CreateServerRagdollSubmodel( this, GetHeadcrabModel(), vecOrigin, GetLocalAngles(), COLLISION_GROUP_INTERACTIVE_DEBRIS );
|
pGib = CreateServerRagdollSubmodel( this, GetHeadcrabModel(), vecOrigin, GetLocalAngles(), COLLISION_GROUP_INTERACTIVE_DEBRIS );
|
||||||
|
if (pGib && pGib->VPhysicsGetObject())
|
||||||
|
{
|
||||||
pGib->VPhysicsGetObject()->AddVelocity(&vecVelocity, NULL);
|
pGib->VPhysicsGetObject()->AddVelocity(&vecVelocity, NULL);
|
||||||
if (ShouldIgniteZombieGib())
|
if (ShouldIgniteZombieGib())
|
||||||
static_cast<CBaseAnimating*>(pGib)->Ignite( random->RandomFloat( 8.0, 12.0 ), false );
|
static_cast<CBaseAnimating*>(pGib)->Ignite( random->RandomFloat( 8.0, 12.0 ), false );
|
||||||
|
|
||||||
pGib->SUB_StartFadeOut( 15, false );
|
pGib->SUB_StartFadeOut( 15, false );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
pGib = CreateRagGib( GetHeadcrabModel(), vecOrigin, GetLocalAngles(), vecVelocity, 15, ShouldIgniteZombieGib() );
|
pGib = CreateRagGib( GetHeadcrabModel(), vecOrigin, GetLocalAngles(), vecVelocity, 15, ShouldIgniteZombieGib() );
|
||||||
#else
|
#else
|
||||||
|
Loading…
x
Reference in New Issue
Block a user