From 8bbb74559d1f6ae21ec780acf91c740bfea8a2a8 Mon Sep 17 00:00:00 2001 From: Christopher Schwarz Date: Mon, 18 Apr 2011 22:41:53 +0000 Subject: * Fix delay/animation of human buildables suiciding from no power (/dev/humancontroller, thanks UniqPhoeniX) --- src/game/g_buildable.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/src/game/g_buildable.c b/src/game/g_buildable.c index 2c3d0250..6db80081 100644 --- a/src/game/g_buildable.c +++ b/src/game/g_buildable.c @@ -1540,10 +1540,10 @@ G_SuicideIfNoPower Destroy human structures that have been unpowered too long ================ */ -static void G_SuicideIfNoPower( gentity_t *self ) +static qboolean G_SuicideIfNoPower( gentity_t *self ) { if( self->buildableTeam != TEAM_HUMANS ) - return; + return qfalse; if( !self->powered ) { @@ -1557,10 +1557,13 @@ static void G_SuicideIfNoPower( gentity_t *self ) NULL, NULL, self->health, 0, MOD_NOCREEP ); else G_Damage( self, NULL, NULL, NULL, NULL, self->health, 0, MOD_NOCREEP ); + return qtrue; } } else self->count = 0; + + return qfalse; } /* @@ -1688,7 +1691,8 @@ void HSpawn_Think( gentity_t *self ) // set parentNode self->powered = G_FindPower( self, qfalse ); - G_SuicideIfNoPower( self ); + if( G_SuicideIfNoPower( self ) ) + return; if( self->spawned ) { @@ -2028,7 +2032,8 @@ void HMedistat_Think( gentity_t *self ) self->nextthink = level.time + BG_Buildable( self->s.modelindex )->nextthink; self->powered = G_FindPower( self, qfalse ); - G_SuicideIfNoPower( self ); + if( G_SuicideIfNoPower( self ) ) + return; G_IdlePowerState( self ); //clear target's healing flag @@ -2365,7 +2370,8 @@ void HMGTurret_Think( gentity_t *self ) self->s.eFlags &= ~EF_FIRING; self->powered = G_FindPower( self, qfalse ); - G_SuicideIfNoPower( self ); + if( G_SuicideIfNoPower( self ) ) + return; G_IdlePowerState( self ); // If not powered or spawned don't do anything @@ -2446,7 +2452,8 @@ void HTeslaGen_Think( gentity_t *self ) self->nextthink = level.time + BG_Buildable( self->s.modelindex )->nextthink; self->powered = G_FindPower( self, qfalse ); - G_SuicideIfNoPower( self ); + if( G_SuicideIfNoPower( self ) ) + return; G_IdlePowerState( self ); //if not powered don't do anything and check again for power next think -- cgit