From d51dbd36f5e2d8a0d3236563acd597f29617777c Mon Sep 17 00:00:00 2001 From: Mario Date: Thu, 11 Apr 2013 11:16:31 +1000 Subject: [PATCH] Fix monsters not targeting vehicles --- qcsrc/server/command/cmd.qc | 3 ++- qcsrc/server/monsters/lib/monsters.qc | 10 +++++----- qcsrc/server/monsters/lib/spawn.qc | 3 --- qcsrc/server/vehicles/vehicles.qc | 1 + 4 files changed, 8 insertions(+), 9 deletions(-) diff --git a/qcsrc/server/command/cmd.qc b/qcsrc/server/command/cmd.qc index fb447f0563..6f22c50830 100644 --- a/qcsrc/server/command/cmd.qc +++ b/qcsrc/server/command/cmd.qc @@ -276,8 +276,9 @@ void ClientCommand_mobspawn(float request, float argc) return; } - if(self.classname != STR_PLAYER) { sprint(self, "You can't spawn monsters while spectating.\n"); } + if(!IS_PLAYER(self)) { sprint(self, "You can't spawn monsters while spectating.\n"); } else if not(autocvar_g_monsters) { sprint(self, "Monsters aren't enabled.\n"); } + else if(self.vehicle) { sprint(self, "You can't spawn monsters while driving a vehicle.\n"); } else if(g_td) { sprint(self, "You can't spawn monsters in Tower Defense mode.\n"); } else if(self.deadflag) { sprint(self, "You can't spawn monsters while dead.\n"); } else if(self.monstercount >= autocvar_g_monsters_max_perplayer) { sprint(self, "You have spawned too many monsters, kill some before trying to spawn any more.\n"); } diff --git a/qcsrc/server/monsters/lib/monsters.qc b/qcsrc/server/monsters/lib/monsters.qc index f7d01af626..889aeb4fc8 100644 --- a/qcsrc/server/monsters/lib/monsters.qc +++ b/qcsrc/server/monsters/lib/monsters.qc @@ -84,17 +84,15 @@ float monster_isvalidtarget (entity targ, entity ent) if(!targ || !ent) return FALSE; // this check should fix a crash - if(targ.vehicle_flags & VHF_ISVEHICLE) - targ = targ.vehicle; - if(time < game_starttime) return FALSE; // monsters do nothing before the match has started - traceline(ent.origin, targ.origin, FALSE, ent); + WarpZone_TraceLine(ent.origin, targ.origin, MOVE_NORMAL, ent); if(vlen(targ.origin - ent.origin) >= ent.target_range) return FALSE; // enemy is too far away - + + if not(targ.vehicle_flags & VHF_ISVEHICLE) if(trace_ent != targ) return FALSE; // we can't see the enemy @@ -107,12 +105,14 @@ float monster_isvalidtarget (entity targ, entity ent) if(IS_SPEC(targ) || IS_OBSERVER(targ)) return FALSE; // enemy is a spectator + if not(targ.vehicle_flags & VHF_ISVEHICLE) // vehicles dont count as alive? if(targ.deadflag != DEAD_NO || ent.deadflag != DEAD_NO || targ.health <= 0 || ent.health <= 0) return FALSE; // enemy/self is dead if(targ.monster_owner == ent || ent.monster_owner == targ) return FALSE; // enemy owns us, or we own them + if not(targ.vehicle_flags & VHF_ISVEHICLE) if(targ.flags & FL_NOTARGET) return FALSE; // enemy can't be targetted diff --git a/qcsrc/server/monsters/lib/spawn.qc b/qcsrc/server/monsters/lib/spawn.qc index 2b5fed4810..87704d80f2 100644 --- a/qcsrc/server/monsters/lib/spawn.qc +++ b/qcsrc/server/monsters/lib/spawn.qc @@ -18,9 +18,6 @@ entity spawnmonster (string monster, entity spawnedby, entity own, vector orig, return world; } - if(spawnedby.vehicle) // no vehicle player spawning... - return world; - if(!spawncode_first_load) { initialize_field_db(); diff --git a/qcsrc/server/vehicles/vehicles.qc b/qcsrc/server/vehicles/vehicles.qc index dd1ed6523c..bad37d30f4 100644 --- a/qcsrc/server/vehicles/vehicles.qc +++ b/qcsrc/server/vehicles/vehicles.qc @@ -1258,6 +1258,7 @@ float vehicle_initialize(string net_name, self.tur_head.owner = self; self.takedamage = DAMAGE_AIM; self.bot_attack = TRUE; + self.monster_attack = TRUE; self.iscreature = TRUE; self.teleportable = FALSE; // no teleporting for vehicles, too buggy self.damagedbycontents = TRUE; -- 2.39.5