]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blob - qcsrc/common/mutators/mutator/vampirehook/vampirehook.qc
Merge branch 'terencehill/menu_optimization' into 'master'
[xonotic/xonotic-data.pk3dir.git] / qcsrc / common / mutators / mutator / vampirehook / vampirehook.qc
1 #ifdef IMPLEMENTATION
2 REGISTER_MUTATOR(vh, cvar("g_vampirehook"));
3
4 bool autocvar_g_vampirehook_teamheal;
5 float autocvar_g_vampirehook_damage;
6 float autocvar_g_vampirehook_damagerate;
7 float autocvar_g_vampirehook_health_steal;
8
9 .float last_dmg;
10
11 MUTATOR_HOOKFUNCTION(vh, GrappleHookThink)
12 {SELFPARAM();
13         entity dmgent = ((SAME_TEAM(self.owner, self.aiment) && autocvar_g_vampirehook_teamheal) ? self.owner : self.aiment);
14
15         if(IS_PLAYER(self.aiment))
16         if(self.last_dmg < time)
17         if(!STAT(FROZEN, self.aiment))
18         if(time >= game_starttime)
19         if(DIFF_TEAM(self.owner, self.aiment) || autocvar_g_vampirehook_teamheal)
20         if(self.aiment.health > 0)
21         if(autocvar_g_vampirehook_damage)
22         {
23                 self.last_dmg = time + autocvar_g_vampirehook_damagerate;
24                 self.owner.damage_dealt += autocvar_g_vampirehook_damage;
25                 Damage(dmgent, self, self.owner, autocvar_g_vampirehook_damage, WEP_HOOK.m_id, self.origin, '0 0 0');
26                 if(SAME_TEAM(self.owner, self.aiment))
27                         self.aiment.health = min(self.aiment.health + autocvar_g_vampirehook_health_steal, g_pickup_healthsmall_max);
28                 else
29                         self.owner.health = min(self.owner.health + autocvar_g_vampirehook_health_steal, g_pickup_healthsmall_max);
30
31                 if(dmgent == self.owner)
32                         dmgent.health -= autocvar_g_vampirehook_damage; // FIXME: friendly fire?!
33         }
34
35         return false;
36 }
37
38 #endif