From af4aff37a98285afe8dd8f71b406774bfb787c99 Mon Sep 17 00:00:00 2001 From: Mario Date: Tue, 26 Feb 2013 06:38:15 +1100 Subject: [PATCH] Print a message if the monster drop item was invalid --- qcsrc/server/monsters/lib/monsters.qc | 30 +++++++++--------------- qcsrc/server/monsters/monster/hknight.qc | 2 +- 2 files changed, 12 insertions(+), 20 deletions(-) diff --git a/qcsrc/server/monsters/lib/monsters.qc b/qcsrc/server/monsters/lib/monsters.qc index baeb3016b1..43fb4fdd70 100644 --- a/qcsrc/server/monsters/lib/monsters.qc +++ b/qcsrc/server/monsters/lib/monsters.qc @@ -12,8 +12,6 @@ void M_Item_Touch () void Monster_DropItem (string itype, string itemsize) { - if(itype == "0") - return; // someone didnt want an item... vector backuporigin = self.origin + ((self.mins + self.maxs) * 0.5); entity oldself; @@ -43,6 +41,12 @@ void Monster_DropItem (string itype, string itemsize) else if (itemsize == "rockets") spawnfunc_item_rockets(); else print("Invalid monster drop item selected.\n"); } + else + { + print("Invalid monster drop item selected.\n"); + self = oldself; + return; + } self.velocity = randomvec() * 175 + '0 0 325'; @@ -190,19 +194,12 @@ void Monster_CheckMinibossFlag () self.effects |= (EF_FULLBRIGHT | EF_RED); } self.health += healthboost; - self.cnt += 20; ScaleMonster(1.5); self.flags |= MONSTERFLAG_MINIBOSS; if(teamplay && autocvar_g_monsters_teams) return; - do - { - self.colormod_x = random(); - self.colormod_y = random(); - self.colormod_z = random(); - self.colormod = normalize(self.colormod); - } - while (self.colormod_x > 0.6 && self.colormod_y > 0.6 && self.colormod_z > 0.6); + + self.colormod = randomvec(); } } @@ -398,9 +395,9 @@ void monster_move(float runspeed, float walkspeed, float stopspeed, float manim_ self.health = max(1, self.revive_progress * self.max_health); if(self.sprite) - { WaypointSprite_UpdateHealth(self.sprite, self.health); - } + + movelib_beak_simple(stopspeed); self.velocity = '0 0 0'; self.enemy = world; @@ -582,19 +579,14 @@ void monsters_damage (entity inflictor, entity attacker, float damage, float dea self.health -= damage; if(self.sprite) - { WaypointSprite_UpdateHealth(self.sprite, self.health); - } self.dmg_time = time; if(sound_allowed(MSG_BROADCAST, attacker) && deathtype != DEATH_DROWN) spamsound (self, CH_PAIN, "misc/bodyimpact1.wav", VOL_BASE, ATTN_NORM); // FIXME: PLACEHOLDER - if(self.damageforcescale < 1 && self.damageforcescale > 0) - self.velocity += force * self.damageforcescale; - else - self.velocity += force; + self.velocity += force * self.damageforcescale; if(deathtype != DEATH_DROWN) { diff --git a/qcsrc/server/monsters/monster/hknight.qc b/qcsrc/server/monsters/monster/hknight.qc index ad4bfab44f..97494358fb 100644 --- a/qcsrc/server/monsters/monster/hknight.qc +++ b/qcsrc/server/monsters/monster/hknight.qc @@ -407,7 +407,7 @@ void hellknight_die () if(chance < 0.10 || self.flags & MONSTERFLAG_MINIBOSS) { - self.superweapons_finished = time + autocvar_g_balance_superweapons_time; + self.superweapons_finished = time + autocvar_g_balance_superweapons_time + 5; // give the player a few seconds to find the weapon W_ThrowNewWeapon(self, WEP_FIREBALL, 0, self.origin, self.velocity); } -- 2.39.5