X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fcommon%2Fmutators%2Fmutator%2Foverkill%2Fsv_overkill.qc;h=5eef8f2e37b4b49c96bce413c564cf2ebcbf9b28;hb=65493c17d47c0d5ece5e28a999a0162c5b070acb;hp=6b32ec35299f4b478e071272c30411718692ed2c;hpb=5e38af0dbb859633140b764cb44e4b9467fe189d;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/common/mutators/mutator/overkill/sv_overkill.qc b/qcsrc/common/mutators/mutator/overkill/sv_overkill.qc index 6b32ec352..5eef8f2e3 100644 --- a/qcsrc/common/mutators/mutator/overkill/sv_overkill.qc +++ b/qcsrc/common/mutators/mutator/overkill/sv_overkill.qc @@ -17,6 +17,23 @@ REGISTER_MUTATOR(ok, expr_evaluate(autocvar_g_overkill) && !cvar("g_instagib") & { precache_all_playermodels("models/ok_player/*.dpm"); + if (autocvar_g_overkill_filter_healthmega) + { + ITEM_HealthMega.spawnflags |= ITEM_FLAG_MUTATORBLOCKED; + } + if (autocvar_g_overkill_filter_armormedium) + { + ITEM_ArmorMedium.spawnflags |= ITEM_FLAG_MUTATORBLOCKED; + } + if (autocvar_g_overkill_filter_armorbig) + { + ITEM_ArmorBig.spawnflags |= ITEM_FLAG_MUTATORBLOCKED; + } + if (autocvar_g_overkill_filter_armormega) + { + ITEM_ArmorMega.spawnflags |= ITEM_FLAG_MUTATORBLOCKED; + } + WEP_RPC.spawnflags &= ~WEP_FLAG_MUTATORBLOCKED; WEP_HMG.spawnflags &= ~WEP_FLAG_MUTATORBLOCKED; @@ -27,6 +44,11 @@ REGISTER_MUTATOR(ok, expr_evaluate(autocvar_g_overkill) && !cvar("g_instagib") & MUTATOR_ONREMOVE { + ITEM_HealthMega.spawnflags &= ~ITEM_FLAG_MUTATORBLOCKED; + ITEM_ArmorMedium.spawnflags &= ~ITEM_FLAG_MUTATORBLOCKED; + ITEM_ArmorBig.spawnflags &= ~ITEM_FLAG_MUTATORBLOCKED; + ITEM_ArmorMega.spawnflags &= ~ITEM_FLAG_MUTATORBLOCKED; + WEP_RPC.spawnflags |= WEP_FLAG_MUTATORBLOCKED; WEP_HMG.spawnflags |= WEP_FLAG_MUTATORBLOCKED; } @@ -183,7 +205,7 @@ MUTATOR_HOOKFUNCTION(ok, OnEntityPreSpawn) setorigin(wep, ent.origin); setmodel(wep, MDL_OK_HMG); wep.ok_item = true; - wep.noalign = ent.noalign; + wep.noalign = Item_ShouldKeepPosition(ent); wep.cnt = ent.cnt; wep.team = ent.team; wep.respawntime = g_pickup_respawntime_superweapon; @@ -193,13 +215,13 @@ MUTATOR_HOOKFUNCTION(ok, OnEntityPreSpawn) wep.nextthink = time + 0.1; return true; } - else if(ent.classname == "item_invincible") + else if(ent.classname == "item_shield") { entity wep = new(weapon_rpc); setorigin(wep, ent.origin); setmodel(wep, MDL_OK_RPC); wep.ok_item = true; - wep.noalign = ent.noalign; + wep.noalign = Item_ShouldKeepPosition(ent); wep.cnt = ent.cnt; wep.team = ent.team; wep.respawntime = g_pickup_respawntime_superweapon; @@ -247,14 +269,6 @@ MUTATOR_HOOKFUNCTION(ok, FilterItem) if(item.ok_item) return false; - switch(item.itemdef) - { - case ITEM_HealthMega: return autocvar_g_overkill_filter_healthmega; - case ITEM_ArmorMedium: return autocvar_g_overkill_filter_armormedium; - case ITEM_ArmorBig: return autocvar_g_overkill_filter_armorbig; - case ITEM_ArmorMega: return autocvar_g_overkill_filter_armormega; - } - return true; }