From: FruitieX Date: Sun, 24 Oct 2010 19:41:33 +0000 (+0300) Subject: did this INITPRIO_FINDTARGET fix ever improve the situation of two players passing... X-Git-Tag: xonotic-v0.1.0preview~202^2~39 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=91e9707bfeb222105cc01f576bef9901b28493a1;p=xonotic%2Fxonotic-data.pk3dir.git did this INITPRIO_FINDTARGET fix ever improve the situation of two players passing through an item trigger at once? needs testing, if it wasn't fixed, needs to be done in another way (CAN'T have players "leaking" through an item remove trigger, eg. suppose there's a map where you spawn with the rocketlauncher and it is removed shortly after, a leaked player would get a HUGE advantage) --- diff --git a/qcsrc/server/t_quake3.qc b/qcsrc/server/t_quake3.qc index cffe88bd7f..5f484acc73 100644 --- a/qcsrc/server/t_quake3.qc +++ b/qcsrc/server/t_quake3.qc @@ -39,12 +39,28 @@ void spawnfunc_item_armor_combat() { spawnfunc_item_armor_big(); } void spawnfunc_item_armor_shard() { spawnfunc_item_armor_small(); } void spawnfunc_item_enviro() { spawnfunc_item_invincible(); } -// weapon remove ent from defrag +// weapon remove ent from df +// +void target_init_verify() +{ + entity trigger, targ; + for(trigger = world; (trigger = find(trigger, classname, "trigger_multiple")); ) + for(targ = world; (targ = find(targ, targetname, trigger.target)); ) + if (targ.classname == "target_init" || targ.classname == "target_give" || targ.classname == "target_items") { + targ.wait = -2; + targ.delay = 0; + + setsize(targ, trigger.mins, trigger.maxs); + setorigin(targ, trigger.origin); + //remove(trigger); + } +} + void spawnfunc_target_init() { self.spawnflags = 0; // remove all weapons except the ones listed below self.netname = "laser uzi"; // keep these weapons through the remove trigger spawnfunc_target_items(); + InitializeEntity(self, target_init_verify, INITPRIO_FINDTARGET); } // weapon give ent from defrag @@ -85,6 +101,7 @@ void target_give_init() } self.spawnflags = 2; spawnfunc_target_items(); + InitializeEntity(self, target_init_verify, INITPRIO_FINDTARGET); } void spawnfunc_target_give()