Xonotic QuakeC
The free, fast arena FPS with crisp movement and a wide array of weapons
sv_buffs.qc
Go to the documentation of this file.
1#include "sv_buffs.qh"
2
7
8#include "buff/_mod.qh"
9
11{
12 entity player = WaypointSprite_getviewentity(client);
13 entity myowner = this.owner;
14 entity heldbuff = buff_FirstFromFlags(myowner);
15
16 if (!heldbuff)
17 return false;
18
19 if (myowner.alpha <= 0.5 && myowner.alpha != 0 && DIFF_TEAM(player, myowner))
20 return false;
21
22 if (MUTATOR_CALLHOOK(BuffModel_Customize, this, player))
23 return false;
24
25 if (player == myowner)
26 {
27 // somewhat hide the model, but keep the glow
28 this.effects = 0;
29 this.alpha = -1;
30 }
31 else
32 {
34 this.alpha = myowner.alpha;
35 }
36 return true;
37}
38
40{
41 this.nextthink = time;
42 entity player = this.owner;
43 if (player.alpha < 0 || player.buff_model != this)
44 {
45 if (player) // remnant from ChatBubbleThink, same question... WHY?!
46 player.buff_model = NULL;
47 delete(this);
48 return;
49 }
50
51 entity heldbuff = buff_FirstFromFlags(player);
52
53 if (!heldbuff)
54 {
55 this.effects = EF_NODRAW;
56 return;
57 }
58
59 this.color = heldbuff.m_color;
60 this.glowmod = heldbuff.m_color;
61 this.skin = heldbuff.m_skin;
62
63 this.effects = player.effects;
65 this.effects = this.effects & EFMASK_CHEAP; // eat performance
66
67 this.alpha = player.alpha;
68}
69
71{
72 if (player.buff_model)
73 delete(player.buff_model);
74 player.buff_model = NULL;
75}
76
78{
79 player.buff_model = new(buff_model);
80 setmodel(player.buff_model, MDL_BUFF);
81 setsize(player.buff_model, '0 0 -40', '0 0 40');
82 setattachment(player.buff_model, player, "");
83 setorigin(player.buff_model, '0 0 1' * (player.buff_model.maxs.z * 1));
84 player.buff_model.owner = player;
85 player.buff_model.exteriormodeltoclient = player;
86 player.buff_model.scale = 0.7;
87 player.buff_model.pflags = PFLAGS_FULLDYNAMIC;
88 player.buff_model.light_lev = 200;
89 setthink(player.buff_model, buffs_BuffModel_Think);
90 player.buff_model.nextthink = time;
91 setcefc(player.buff_model, buffs_BuffModel_Customize);
92}
93
95{
96 if (this.alpha < 0)
97 return;
98 // spawn a buff model entity if needed
99 if (!this.buff_model)
101}
102
103void buff_Effect(entity player, string eff)
104{
106 return;
107
108 if (time >= player.buff_effect_delay)
109 {
110 Send_Effect_(eff, player.origin + (player.mins + player.maxs) * 0.5, '0 0 0', 1);
111 player.buff_effect_delay = time + 0.05; // prevent spam
112 }
113}
114
115// buff item
117{
118 if (!this.owner.buff_active && !this.owner.buff_activetime || !this.owner.buffdef)
119 return false;
120
121 entity heldbuff = buff_FirstFromFlags(view); // TODO: cache this information so it isn't performing a loop every frame
122 if (heldbuff)
123 return CS_CVAR(view).cvar_cl_buffs_autoreplace == false || heldbuff != this.owner.buffdef;
124
125 return WaypointSprite_visible_for_player(this, player, view);
126}
127
129{
131 return;
132
133 entity buff = e.buffdef;
134 entity wp = WaypointSprite_Spawn(WP_Buff, 0, autocvar_g_buffs_waypoint_distance, e, '0 0 1' * e.maxs.z, NULL, e.team_forced, e, buff_waypoint, true, RADARICON_Buff);
135 wp.wp_extra = buff.m_id;
136 WaypointSprite_UpdateTeamRadar(e.buff_waypoint, RADARICON_Buff, e.glowmod);
137 e.buff_waypoint.waypointsprite_visible_for_player = buff_Waypoint_visible_for_player;
138}
139
140void buff_SetCooldown(entity this, float cd)
141{
142 cd = max(0, cd);
143
144 if (!this.buff_waypoint)
146 if (this.buff_waypoint)
148
149 this.buff_activetime = cd;
150 this.buff_active = !cd;
151}
152
154{
155 if (game_stopped)
156 return;
157
158 vector oldbufforigin = this.origin;
159 this.velocity = '0 0 200';
160
163 {
164 entity spot = SelectSpawnPoint(this, true);
165 setorigin(this, spot.origin);
166 this.velocity = (randomvec() * 100) + '0 0 200';
167 this.angles = spot.angles;
168 }
169
170 tracebox(this.origin, this.mins * 1.5, this.maxs * 1.5, this.origin, MOVE_NOMONSTERS, this);
171
172 setorigin(this, trace_endpos); // attempt to unstick
173
175
176 makevectors(this.angles);
177 this.angles = '0 0 0';
180
181 Send_Effect(EFFECT_ELECTRO_COMBO, oldbufforigin + ((this.mins + this.maxs) * 0.5), '0 0 0', 1);
182 Send_Effect(EFFECT_ELECTRO_COMBO, CENTER_OR_VIEWOFS(this), '0 0 0', 1);
183
185
186 sound(this, CH_TRIGGER, SND_KA_RESPAWN, VOL_BASE, ATTEN_NONE); // ATTEN_NONE (it's a sound intended to be heard anywhere)
187}
188
190{
191 if (game_stopped)
192 return;
193
195 {
196 buff_Respawn(this);
197 return;
198 }
199
200 if (!this.buff_active)
201 return;
202
203 if (MUTATOR_CALLHOOK(BuffTouch, this, toucher))
204 return;
205 toucher = M_ARGV(1, entity);
206
207 if (!IS_PLAYER(toucher))
208 return; // incase mutator changed toucher
209
210 if ((this.team_forced && toucher.team != this.team_forced)
211 || toucher.vehicle
212 || !this.buffdef // TODO: error out or maybe reset type if this occurs?
213 || time < toucher.buff_shield)
214 {
215 // can't touch this
216 return;
217 }
218
220 entity thebuff = this.buffdef;
221
222 if (heldbuff)
223 {
224 if (CS_CVAR(toucher).cvar_cl_buffs_autoreplace && heldbuff != thebuff)
225 {
226 // TODO: lost-gained notification for this case
227 int buffid = heldbuff.m_id;
228 Send_Notification(NOTIF_ONE, toucher, MSG_INFO, INFO_ITEM_BUFF_LOST, toucher.netname, buffid);
230 Send_Notification(NOTIF_ALL_EXCEPT, toucher, MSG_INFO, INFO_ITEM_BUFF_LOST, toucher.netname, buffid);
231 //sound(toucher, CH_TRIGGER, SND_BUFF_LOST, VOL_BASE, ATTN_NORM);
232 }
233 else
234 return; // do nothing
235 }
236
237 this.owner = toucher;
238 this.buff_active = false;
239 this.lifetime = 0;
240 Send_Notification(NOTIF_ONE, toucher, MSG_MULTI, ITEM_BUFF_GOT, thebuff.m_id);
242 Send_Notification(NOTIF_ALL_EXCEPT, toucher, MSG_INFO, INFO_ITEM_BUFF, toucher.netname, thebuff.m_id);
243
244 Send_Effect(EFFECT_ITEM_PICKUP, CENTER_OR_VIEWOFS(this), '0 0 0', 1);
245 sound(toucher, CH_TRIGGER, SND_SHIELD_RESPAWN, VOL_BASE, ATTN_NORM);
246 float bufftime = (this.buffs_finished) ? this.buffs_finished : thebuff.m_time(thebuff);
247
248 buff_RemoveAll(toucher, STATUSEFFECT_REMOVE_NORMAL); // remove previous buffs so that a new one may be added
249 if (!bufftime)
250 bufftime = 999;
251 StatusEffects_apply(thebuff, toucher, time + bufftime, 0);
252
253 STAT(LAST_PICKUP, toucher) = time;
254}
255
257{
258 if (!buff)
259 return false;
260 if (buff == BUFF_AMMO && ((start_items & IT_UNLIMITED_AMMO) || cvar("g_melee_only")))
261 return false;
262 if (buff == BUFF_VAMPIRE && cvar("g_vampire"))
263 return false;
264 return cvar(strcat("g_buffs_", buff.netname));
265}
266
268
270{
272 FOREACH(StatusEffects, it.instanceOfBuff && buff_Available(it), {
273 // if it's already been chosen, give it a lower priority
274 float myseencount = (it.buff_seencount > 0) ? it.buff_seencount : 1; // no division by zero please!
275 RandomSelection_AddEnt(it, max(0.2, 1 / myseencount), 1);
276 });
278 if (!newbuff)
279 return;
280 ++newbuff.buff_seencount; // lower chances of seeing this buff again soon
281 ent.buffdef = newbuff;
282}
283
284void buff_RemoveAll(entity actor, int removal_type)
285{
286 if (!actor.statuseffects)
287 return;
288 FOREACH(StatusEffects, it.instanceOfBuff, {
289 it.m_remove(it, actor, removal_type);
290 });
291}
292
294{
295 if (!actor.statuseffects)
296 return NULL;
297 FOREACH(StatusEffects, it.instanceOfBuff && it.m_active(it, actor), {
298 return it;
299 });
300 return NULL;
301}
302
304{
307
308 if (this.buffdef != this.oldbuffs)
309 {
310 entity buff = this.buffdef;
311 this.color = buff.m_color;
312 this.glowmod = buff.m_color;
313 this.skin = buff.m_skin;
314
315 setmodel(this, MDL_BUFF);
316 setsize(this, ITEM_D_MINS, ITEM_L_MAXS);
317
318 if (this.buff_waypoint)
319 {
320 //WaypointSprite_Disown(this.buff_waypoint, 1);
323 if (this.buff_activetime)
325 }
326
327 this.oldbuffs = this.buffdef;
328 }
329
330 if (!game_stopped)
332 if (!this.buff_activetime_updated)
333 {
335 this.buff_activetime_updated = true;
336 }
337
338 if (!this.buff_active && !this.buff_activetime)
339 if (!this.owner || STAT(FROZEN, this.owner) || IS_DEAD(this.owner) || !this.owner.iscreature || this.owner.vehicle
340 || this.pickup_anyway > 0 || (this.pickup_anyway >= 0 && autocvar_g_buffs_pickup_anyway)
341 || this.buffdef != buff_FirstFromFlags(this.owner))
342 {
344 this.owner = NULL;
346 buff_NewType(this);
347
349 buff_Respawn(this);
350 }
351
352 if (this.buff_activetime)
353 if (!game_stopped)
355 {
357
358 if (!this.buff_activetime)
359 {
360 this.buff_active = true;
361 sound(this, CH_TRIGGER, SND_STRENGTH_RESPAWN, VOL_BASE, ATTN_NORM);
362 Send_Effect(EFFECT_ITEM_RESPAWN, CENTER_OR_VIEWOFS(this), '0 0 0', 1);
363 }
364 }
365
366 if (this.buff_active)
367 {
368 if (this.team_forced && !this.buff_waypoint)
370
371 if (this.lifetime && time >= this.lifetime)
372 buff_Respawn(this);
373 }
374
375 this.nextthink = time;
376 //this.angles_y = time * 110.1;
377}
378
380{
382
383 if (this.buff_activetime)
385}
386
399
400bool buff_Customize(entity this, entity client)
401{
402 entity player = WaypointSprite_getviewentity(client);
403 if ((!this.buff_active || !this.buffdef) || (this.team_forced && player.team != this.team_forced))
404 {
405 this.alpha = 0.3;
406 if (this.effects & EF_FULLBRIGHT)
407 this.effects &= ~EF_FULLBRIGHT;
408 this.pflags = 0;
409 }
410 else
411 {
412 this.alpha = 1;
413 if (!(this.effects & EF_FULLBRIGHT))
414 this.effects |= EF_FULLBRIGHT;
415 this.light_lev = 220 + 36 * sin(time);
417 }
418 return true;
419}
420
422{
424 delete_fn(this);
425}
426
428{
429 if (!autocvar_g_buffs)
430 {
431 delete(this);
432 return;
433 }
434
435 entity buff = this.buffdef;
436
437 // item_buff_random provides a null type so force randomization in that case
438 // otherwise replace the buff type if it's unavailable and the option is enabled
439 if (!buff || (autocvar_g_buffs_replace_available && !buff_Available(buff)))
440 {
441 buff_NewType(this);
442 buff = this.buffdef;
443 }
444
445 // the buff type is still invalid or unavailable, simply delete the item
446 if (!buff || !buff_Available(buff))
447 {
448 delete(this);
449 return;
450 }
451
452 this.classname = "item_buff";
453 this.solid = SOLID_TRIGGER;
454 this.flags = FL_ITEM;
455 this.bot_pickup = true;
456 this.bot_pickupevalfunc = generic_pickupevalfunc;
457 this.bot_pickupbasevalue = 1000;
458 IL_PUSH(g_items, this);
459 setthink(this, buff_Think);
460 settouch(this, buff_Touch);
461 setmodel(this, MDL_BUFF);
462 setsize(this, ITEM_D_MINS, ITEM_L_MAXS);
463 this.reset = buff_Reset;
464 this.nextthink = time + 0.1;
465 this.gravity = 1;
467 this.scale = 1;
468 this.skin = buff.m_skin;
471 setcefc(this, buff_Customize);
472 //this.gravity = 100;
473 this.color = buff.m_color;
474 this.glowmod = buff.m_color;
476 this.buff_active = !this.buff_activetime;
478 this.dtor = buff_Delete;
479
480 if (!this.buffs_finished)
481 this.buffs_finished = this.count; // legacy support
482
483 if (this.spawnflags & 1)
484 this.noalign = true;
485 if (this.noalign)
486 set_movetype(this, MOVETYPE_NONE); // reset by random location
487
489 buff_Respawn(this);
490}
491
492void buff_Init_Compat(entity ent, entity replacement)
493{
494 if (teamplay)
495 {
496 if (ent.spawnflags & 2)
497 ent.team_forced = NUM_TEAM_1;
498 else if (ent.spawnflags & 4)
499 ent.team_forced = NUM_TEAM_2;
500 }
501
502 ent.buffdef = replacement;
503
504 buff_Init(ent);
505}
506
508{
509 setorigin(ent, old.origin);
510 ent.angles = old.angles;
511 ent.noalign = ITEM_SHOULD_KEEP_POSITION(old);
512
513 buff_Init(ent);
514}
515
516METHOD(Buff, m_apply, void(StatusEffect this, entity actor, float eff_time, float eff_flags))
517{
518 if (IS_PLAYER(actor))
519 actor.effects |= EF_NOSHADOW; // does not play well with buff icon
520 SUPER(Buff).m_apply(this, actor, eff_time, eff_flags);
521}
522METHOD(Buff, m_remove, void(StatusEffect this, entity actor, int removal_type))
523{
524 bool was_active = actor.statuseffects && (actor.statuseffects.statuseffect_flags[this.m_id] & STATUSEFFECT_FLAG_ACTIVE);
525 if (was_active)
526 {
527 int buffid = this.m_id;
528 if (removal_type == STATUSEFFECT_REMOVE_TIMEOUT)
529 {
530 Send_Notification(NOTIF_ONE, actor, MSG_MULTI, ITEM_BUFF_DROP, buffid); // TODO: special timeout message?
531 sound(actor, CH_TRIGGER, SND_BUFF_LOST, VOL_BASE, ATTN_NORM);
532 }
533 else if (removal_type == STATUSEFFECT_REMOVE_NORMAL && !IS_INDEPENDENT_PLAYER(actor))
534 Send_Notification(NOTIF_ALL_EXCEPT, actor, MSG_INFO, INFO_ITEM_BUFF_LOST, actor.netname, buffid);
535 actor.buff_shield = time + max(0, autocvar_g_buffs_pickup_delay); // always put in a delay, even if small
536 }
537 if (IS_PLAYER(actor))
538 actor.effects &= ~EF_NOSHADOW;
539 SUPER(Buff).m_remove(this, actor, removal_type);
540}
541
542
543// mutator hooks
544MUTATOR_HOOKFUNCTION(buffs, Damage_Calculate)
545{
546 entity frag_attacker = M_ARGV(1, entity);
548 float frag_deathtype = M_ARGV(3, float);
549 float frag_damage = M_ARGV(4, float);
551
552 if (frag_deathtype == DEATH_BUFF.m_id)
553 return;
554
555 if (StatusEffects_active(BUFF_RESISTANCE, frag_target))
557
558 if (StatusEffects_active(BUFF_MEDIC, frag_target))
559 if (GetResource(frag_target, RES_HEALTH) - frag_damage <= 0)
560 if (!ITEM_DAMAGE_NEEDKILL(frag_deathtype))
561 if (frag_attacker)
563
564 if (StatusEffects_active(BUFF_JUMP, frag_target))
566
567 if (StatusEffects_active(BUFF_VENGEANCE, frag_target))
568 if (frag_attacker && frag_attacker != frag_target)
569 if (!ITEM_DAMAGE_NEEDKILL(frag_deathtype))
570 {
571 entity dmgent = new_pure(dmgent);
572
574 dmgent.enemy = frag_attacker;
575 dmgent.owner = frag_target;
577 dmgent.nextthink = time + 0.1;
578 }
579
580 if (StatusEffects_active(BUFF_BASH, frag_target))
582
583 if (StatusEffects_active(BUFF_BASH, frag_attacker))
585
586 if (StatusEffects_active(BUFF_DISABILITY, frag_attacker))
588
589 if (StatusEffects_active(BUFF_INFERNO, frag_target))
590 {
591 if (frag_deathtype == DEATH_FIRE.m_id)
592 frag_damage = 0;
593 if (frag_deathtype == DEATH_LAVA.m_id)
594 frag_damage *= 0.5; // TODO: cvarize?
595 }
596
597 if (frag_attacker != frag_target)
598 {
599 if (StatusEffects_active(BUFF_LUCK, frag_attacker))
601
602 if (StatusEffects_active(BUFF_INFERNO, frag_attacker))
603 {
605 Fire_AddDamage(frag_target, frag_attacker, buff_Inferno_CalculateDamage(frag_damage), btime, DEATH_BUFF.m_id);
606 }
607 }
608
609 M_ARGV(4, float) = frag_damage;
611}
612
614{
616 return;
617
618 entity player = M_ARGV(0, entity);
619
620 entity heldbuff = buff_FirstFromFlags(player);
621 if (heldbuff)
622 {
623 int buffid = heldbuff.m_id;
624 Send_Notification(NOTIF_ONE, player, MSG_MULTI, ITEM_BUFF_DROP, buffid);
625 if (!IS_INDEPENDENT_PLAYER(player))
626 Send_Notification(NOTIF_ALL_EXCEPT, player, MSG_INFO, INFO_ITEM_BUFF_LOST, player.netname, buffid);
627
629 player.buff_shield = time + max(0, autocvar_g_buffs_pickup_delay);
630 sound(player, CH_TRIGGER, SND_BUFF_LOST, VOL_BASE, ATTN_NORM);
631 return true;
632 }
633}
634
636{
638 return false;
639}
640MUTATOR_HOOKFUNCTION(buffs, MakePlayerObserver)
641{
642 entity player = M_ARGV(0, entity);
643 return buffs_RemovePlayer(player);
644}
646{
647 entity player = M_ARGV(0, entity);
648 return buffs_RemovePlayer(player);
649}
650
651MUTATOR_HOOKFUNCTION(buffs, FilterItem)
652{
653 if (autocvar_g_buffs < 0)
654 return false; // no auto replacing of entities in this mode
655
656 entity item = M_ARGV(0, entity);
657
658 if (autocvar_g_buffs_replace_powerups && item.itemdef.instanceOfPowerup)
659 {
660 entity e = spawn();
661 buff_SpawnReplacement(e, item);
662 return true;
663 }
664
665 return false;
666}
667
669{
670 entity player = M_ARGV(0, entity);
671
672 if (game_stopped || IS_DEAD(player) || !IS_PLAYER(player))
673 return;
674
675 // NOTE: this is kept here to ensure crouches are picked up each player movement frame
676 if (StatusEffects_active(BUFF_FLIGHT, player))
677 {
678 if (!PHYS_INPUT_BUTTON_CROUCH(player))
679 player.buff_flight_crouchheld = false;
680 else if (!player.buff_flight_crouchheld)
681 {
682 player.buff_flight_crouchheld = true;
683 player.gravity *= -1;
684 }
685 }
686
687 if (IS_PLAYER(player))
689}
690
691MUTATOR_HOOKFUNCTION(buffs, BuildMutatorsString)
692{
693 if (autocvar_g_buffs > 0) // only report as a mutator if they're enabled
694 M_ARGV(0, string) = strcat(M_ARGV(0, string), ":Buffs");
695}
696
697MUTATOR_HOOKFUNCTION(buffs, BuildMutatorsPrettyString)
698{
699 if (autocvar_g_buffs > 0)
700 M_ARGV(0, string) = strcat(M_ARGV(0, string), ", Buffs");
701}
702
704{
706 if (find(NULL, classname, "item_buff") == NULL)
707 for (int i = 0; i < autocvar_g_buffs_spawn_count; ++i)
708 {
709 entity e = spawn();
710 e.spawnflags |= 64; // always randomize
711 e.velocity = randomvec() * 250; // this gets reset anyway if random location works
712 buff_Init(e);
713 }
714}
715
717{
718 // if buffs are above 0, allow random spawning
719 if (autocvar_g_buffs > 0 && autocvar_g_buffs_spawn_count > 0)
721}
float bot_pickup
Definition api.qh:43
const int CBC_ORDER_FIRST
Definition base.qh:10
#define MUTATOR_CALLHOOK(id,...)
Definition base.qh:143
#define MUTATOR_HOOKFUNCTION(...)
Definition base.qh:335
#define MUTATOR_RETURNVALUE
Definition base.qh:328
vector buff_Bash_AttackerCalculateForce(vector frag_force, entity frag_target, entity frag_attacker)
Definition bash.qc:10
vector buff_Bash_TargetCalculateForce(vector frag_force, entity frag_target, entity frag_attacker)
Definition bash.qc:4
float bot_pickupbasevalue
Definition bot.qh:68
int team_forced
Definition buffs.qh:61
entity buffdef
Definition buffs.qh:60
var entity(vector mins, vector maxs,.entity tofield) findbox_tofield_OrFallback
float GetResource(entity e, Resource res_type)
Returns the current amount of resource the given entity has.
Definition buffs.qh:17
float lifetime
Definition powerups.qc:23
float count
Definition powerups.qc:22
float alpha
Definition items.qc:13
float gravity
Definition items.qh:17
entity owner
Definition main.qh:87
int spawnflags
Definition ammo.qh:15
float buffs_finished
Definition item.qh:95
const int IT_UNLIMITED_AMMO
Definition item.qh:23
const vector ITEM_L_MAXS
Definition item.qh:84
const vector ITEM_D_MINS
Definition item.qh:82
#define setmodel(this, m)
Definition model.qh:26
#define M_ARGV(x, type)
Definition events.qh:17
#define PHYS_INPUT_BUTTON_CROUCH(s)
Definition player.qh:154
#define IS_DEAD(s)
Definition player.qh:245
#define IS_PLAYER(s)
Definition player.qh:243
float game_starttime
Definition stats.qh:82
float game_stopped
Definition stats.qh:81
const int INITPRIO_FINDTARGET
Definition constants.qh:96
#define EFMASK_CHEAP
Definition constants.qh:107
const int FL_ITEM
Definition constants.qh:77
string classname
float Q3SURFACEFLAG_SKY
float flags
float DPCONTENTS_SKY
const float MOVE_NOMONSTERS
const float EF_STARDUST
const float SOLID_TRIGGER
float DPCONTENTS_DONOTENTER
float DPCONTENTS_SOLID
float frametime
float DPCONTENTS_CORPSE
vector mins
vector velocity
float DPCONTENTS_BODY
const float EF_FULLBRIGHT
float effects
float DPCONTENTS_PLAYERCLIP
float DPCONTENTS_SLIME
float skin
float time
vector trace_endpos
vector maxs
float nextthink
vector origin
float DPCONTENTS_LAVA
const float ATTN_NORM
const float EF_NOSHADOW
const float EF_NODRAW
float dphitcontentsmask
const float PFLAGS_FULLDYNAMIC
#define spawn
vector glowmod
float Fire_AddDamage(entity e, entity o, float d, float t, float dt)
Definition damage.qc:1002
void buff_Disability_ApplyStunned(entity frag_target, entity frag_attacker)
Definition disability.qc:4
float pflags
float EF_LOWPRECISION
float light_lev
Definition dynlight.qc:13
vector color
Definition dynlight.qc:15
int m_id
Definition effect.qh:19
void Send_Effect_(string eff_name, vector eff_loc, vector eff_vel, int eff_cnt)
Definition all.qc:129
void Send_Effect(entity eff, vector eff_loc, vector eff_vel, int eff_cnt)
Definition all.qc:124
ent angles
Definition ent_cs.qc:121
solid
Definition ent_cs.qc:165
float buff_Inferno_CalculateTime(float dmg)
Definition inferno.qc:4
float buff_Inferno_CalculateDamage(float frag_damage)
Definition inferno.qc:13
ERASEABLE entity IL_PUSH(IntrusiveList this, entity it)
Push to tail.
#define ITEM_SHOULD_KEEP_POSITION(item)
Returns whether item should keep its position or be dropped to the ground.
Definition spawning.qh:52
#define FOREACH(list, cond, body)
Definition iter.qh:19
float buff_Jump_ChangeDamage(float frag_damage, float frag_deathtype)
Definition jump.qc:4
#define PlayerPreThink
Definition _all.inc:254
#define ClientDisconnect
Definition _all.inc:242
#define STAT(...)
Definition stats.qh:82
float buff_Luck_CalculateDamage(float frag_damage)
Definition luck.qc:4
float buff_Medic_CalculateSurviveDamage(float frag_damage, float health)
Definition medic.qc:16
float cvar(string name)
entity find(entity start,.string field, string match)
vector randomvec(void)
float sin(float f)
float max(float f,...)
void set_movetype(entity this, int mt)
Definition movetypes.qc:4
const int MOVETYPE_NONE
Definition movetypes.qh:129
const int MOVETYPE_TOSS
Definition movetypes.qh:135
@ STATUSEFFECT_REMOVE_NORMAL
Effect is being removed by a function, calls regular removal mechanics.
Definition all.qh:28
@ STATUSEFFECT_REMOVE_TIMEOUT
Definition all.qh:29
@ STATUSEFFECT_FLAG_ACTIVE
Definition all.qh:22
strcat(_("^F4Countdown stopped!"), "\n^BG", _("Teams are too unbalanced."))
void Send_Notification(NOTIF broadcast, entity client, MSG net_type, Notification net_name,...count)
Definition all.qc:1573
#define SUPER(cname)
Definition oo.qh:231
#define new_pure(class)
purely logical entities (not linked to the area grid)
Definition oo.qh:67
#define METHOD(cname, name, prototype)
Definition oo.qh:269
#define NULL
Definition post.qh:14
#define makevectors
Definition post.qh:21
float scale
Definition projectile.qc:14
ERASEABLE void RandomSelection_Init()
Definition random.qc:4
#define RandomSelection_AddEnt(e, weight, priority)
Definition random.qh:14
entity RandomSelection_chosen_ent
Definition random.qh:5
float buff_Resistance_CalculateDamage(float frag_damage)
Definition resistance.qc:4
#define round_handler_IsActive()
#define round_handler_IsRoundStarted()
#define setthink(e, f)
vector
Definition self.qh:92
#define setcefc(e, f)
entity entity toucher
Definition self.qh:72
#define settouch(e, f)
Definition self.qh:73
void PlayerUseKey(entity this)
Definition client.qc:2584
#define IS_INDEPENDENT_PLAYER(e)
Definition client.qh:312
float generic_pickupevalfunc(entity player, entity item)
Definition items.qc:884
IntrusiveList g_items
Definition items.qh:125
#define ITEM_TOUCH_NEEDKILL()
Definition items.qh:128
#define ITEM_DAMAGE_NEEDKILL(dt)
Definition items.qh:129
bool noalign
Definition items.qh:36
entity SelectSpawnPoint(entity this, bool anypoint)
const int CH_TRIGGER
Definition sound.qh:12
const float VOL_BASE
Definition sound.qh:36
const float ATTEN_NONE
Definition sound.qh:27
#define sound(e, c, s, v, a)
Definition sound.qh:52
#define CS_CVAR(this)
Definition state.qh:51
bool StatusEffects_active(StatusEffect this, entity actor)
void StatusEffects_apply(StatusEffect this, entity actor, float eff_time, int eff_flags)
void buff_Think(entity this)
Definition sv_buffs.qc:303
void buffs_BuffModel_Think(entity this)
Definition sv_buffs.qc:39
void buff_Delete(entity this)
Definition sv_buffs.qc:421
void buff_NewType(entity ent)
Definition sv_buffs.qc:269
void buff_Waypoint_Reset(entity this)
Definition sv_buffs.qc:379
void buffs_Initialize()
Definition sv_buffs.qc:716
void buff_Init(entity this)
Definition sv_buffs.qc:427
void buff_SpawnReplacement(entity ent, entity old)
Definition sv_buffs.qc:507
void buff_Effect(entity player, string eff)
Definition sv_buffs.qc:103
bool buffs_RemovePlayer(entity player)
Definition sv_buffs.qc:635
bool buffs_BuffModel_Customize(entity this, entity client)
Definition sv_buffs.qc:10
entity buff_FirstFromFlags(entity actor)
Definition sv_buffs.qc:293
int buff_seencount
Definition sv_buffs.qc:267
bool buff_Waypoint_visible_for_player(entity this, entity player, entity view)
Definition sv_buffs.qc:116
float buff_Available(entity buff)
Definition sv_buffs.qc:256
void buffs_DelayedInit(entity this)
Definition sv_buffs.qc:703
void buff_SetCooldown(entity this, float cd)
Definition sv_buffs.qc:140
void buff_RemoveAll(entity actor, int removal_type)
Definition sv_buffs.qc:284
void buff_Init_Compat(entity ent, entity replacement)
Definition sv_buffs.qc:492
void buff_Reset(entity this)
Definition sv_buffs.qc:387
bool buff_Customize(entity this, entity client)
Definition sv_buffs.qc:400
void buffs_BuffModel_Spawn(entity player)
Definition sv_buffs.qc:77
void buff_Respawn(entity this)
Definition sv_buffs.qc:153
void buff_Touch(entity this, entity toucher)
Definition sv_buffs.qc:189
void buffs_BuffModel_Remove(entity player)
Definition sv_buffs.qc:70
void buff_Waypoint_Spawn(entity e)
Definition sv_buffs.qc:128
void buffs_BuffModel_Update(entity this)
Definition sv_buffs.qc:94
float autocvar_g_buffs_cooldown_activate
Definition sv_buffs.qh:32
float buff_activetime
Definition sv_buffs.qh:40
entity buff_model
Definition sv_buffs.qh:45
entity oldbuffs
Definition sv_buffs.qh:43
bool buff_activetime_updated
Definition sv_buffs.qh:41
int autocvar_g_buffs_random_location_attempts
Definition sv_buffs.qh:27
bool autocvar_g_buffs_pickup_anyway
Definition sv_buffs.qh:21
entity buff_waypoint
Definition sv_buffs.qh:42
bool autocvar_g_buffs_replace_available
Definition sv_buffs.qh:30
bool autocvar_g_buffs_effects
Definition sv_buffs.qh:19
bool autocvar_g_buffs_randomize
Definition sv_buffs.qh:23
int autocvar_g_buffs_spawn_count
Definition sv_buffs.qh:28
float autocvar_g_buffs_cooldown_respawn
Definition sv_buffs.qh:33
bool autocvar_g_buffs_random_location
Definition sv_buffs.qh:26
float autocvar_g_buffs_pickup_delay
Definition sv_buffs.qh:22
bool autocvar_g_buffs_randomize_teamplay
Definition sv_buffs.qh:24
bool buff_active
Definition sv_buffs.qh:39
bool autocvar_g_buffs_replace_powerups
Definition sv_buffs.qh:29
float autocvar_g_buffs_waypoint_distance
Definition sv_buffs.qh:20
bool autocvar_g_buffs_drop
Definition sv_buffs.qh:31
float autocvar_g_buffs_random_lifetime
Definition sv_buffs.qh:25
float frag_damage
Definition sv_ctf.qc:2322
vector frag_force
Definition sv_ctf.qc:2323
entity frag_target
Definition sv_ctf.qc:2321
var void delete_fn(entity e)
const int NUM_TEAM_2
Definition teams.qh:14
bool teamplay
Definition teams.qh:59
#define DIFF_TEAM(a, b)
Definition teams.qh:242
const int NUM_TEAM_1
Definition teams.qh:13
#define CENTER_OR_VIEWOFS(ent)
Definition utils.qh:29
void buff_Vengeance_DelayedDamage(entity this)
Definition vengeance.qc:4
float buff_Vengeance_CalculateDamage(float frag_damage)
Definition vengeance.qc:12
void WaypointSprite_Kill(entity wp)
void WaypointSprite_UpdateTeamRadar(entity e, entity icon, vector col)
void WaypointSprite_Ping(entity e)
entity WaypointSprite_Spawn(entity spr, float _lifetime, float maxdistance, entity ref, vector ofs, entity showto, float t, entity own,.entity ownfield, float hideable, entity icon)
bool WaypointSprite_visible_for_player(entity this, entity player, entity view)
entity WaypointSprite_getviewentity(entity e)
void WaypointSprite_UpdateBuildFinished(entity e, float f)
float MoveToRandomMapLocation(entity e, float goodcontents, float badcontents, float badsurfaceflags, float attempts, float maxaboveground, float minviewdistance)
Definition world.qc:1231
void InitializeEntity(entity e, void(entity this) func, int order)
Definition world.qc:2209
int start_items
Definition world.qh:83