3 float arena_roundbased;
5 .entity spawnqueue_next;
6 .entity spawnqueue_prev;
8 entity spawnqueue_first;
9 entity spawnqueue_last;
13 void PutObserverInServer();
14 void PutClientInServer();
15 void(entity e) DropFlag;
16 void(entity e) ReturnFlag;
17 void(entity e) removedecor;
18 void dom_controlpoint_setup();
23 if(cvar("g_arena_warmup"))
24 warmup = time + cvar("g_arena_warmup");
26 lms_lowest_lives = 999;
27 lms_next_place = player_count;
29 self = nextent(world);
32 if(self.flags & FL_CLIENT) // reset all players
34 if(time < restart_countdown)
36 self.frags = (g_lms)?LMS_NewPlayerLives():0;
39 self.classname = "player";
47 PutObserverInServer();
50 else if(self.classname == STR_ITEM_KH_KEY)
52 kh_Key_AssignTo(self, world);
54 // kh_Key_DropAll(self.owner, TRUE);
57 else if(self.classname == "droppedweapon" // cleanup
58 || self.classname == "gib"
59 || self.classname == "body")
63 else if(self.items & (IT_KEY1 | IT_KEY2))
68 else if(self.classname == "rune")
71 if(self.owner.classname != "runematch_spawn_point")
72 DropAllRunes(self.owner);
75 else if(self.classname == "sprite_waypoint")
77 if(self.health | g_keyhunt)
78 WaypointSprite_Kill(self);
80 else if(self.classname == "dom_controlpoint")
82 dom_controlpoint_setup();
84 else if(self.flags & FL_ITEM) // reset items
86 self.model = self.mdl;
87 self.solid = SOLID_TRIGGER;
88 setorigin (self, self.origin);
89 self.think = SUB_Null;
91 self.effects = self.effects - (self.effects & EF_STARDUST);
93 else if(self.flags & FL_PROJECTILE) // remove any projectiles left
95 sound(self, CHAN_BODY, "misc/null.wav", 1, ATTN_NORM);
102 self = nextent(self);
106 kh_Controller_SetThink(cvar("g_balance_keyhunt_delay_round")+RESTART_COUNTDOWN, "", kh_StartRound);
110 UpdateFrags(champion, +1);
113 void Spawnqueue_Insert(entity e)
117 dprint(strcat("Into queue: ", e.netname, "\n"));
118 e.spawnqueue_in = TRUE;
119 e.spawnqueue_prev = spawnqueue_last;
120 e.spawnqueue_next = world;
122 spawnqueue_last.spawnqueue_next = e;
124 if(!spawnqueue_first)
125 spawnqueue_first = e;
128 void Spawnqueue_Remove(entity e)
132 dprint(strcat("Out of queue: ", e.netname, "\n"));
133 e.spawnqueue_in = FALSE;
134 if(e == spawnqueue_first)
135 spawnqueue_first = e.spawnqueue_next;
136 if(e == spawnqueue_last)
137 spawnqueue_last = e.spawnqueue_prev;
138 if(e.spawnqueue_prev)
139 e.spawnqueue_prev.spawnqueue_next = e.spawnqueue_next;
140 if(e.spawnqueue_next)
141 e.spawnqueue_next.spawnqueue_prev = e.spawnqueue_prev;
142 e.spawnqueue_next = world;
143 e.spawnqueue_prev = world;
146 void Spawnqueue_Unmark(entity e)
151 numspawned = numspawned - 1;
154 void Spawnqueue_Mark(entity e)
159 numspawned = numspawned + 1;
167 if(!g_arena || !arena_roundbased || (time < restart_countdown))
170 f = rint(warmup - time);
173 if(time < warmup && self.spawned)
176 msg = strcat(msg, "The Champion is ", champion.netname, "^7\n\n\n");
179 msg = strcat(msg, "Round will start in ", ftos(f));
183 msg = strcat(msg, "^1Fight!");
186 centerprint(self, msg);
189 self.movetype = MOVETYPE_NONE;
191 self.velocity = '0 0 0';
192 self.avelocity = '0 0 0';
193 self.movement = '0 0 0';
194 //self.fixangle = TRUE;
196 else if(self.movetype == MOVETYPE_NONE)
198 self.movetype = MOVETYPE_WALK;
199 centerprint(self, "\n");
205 void Spawnqueue_Check()
207 if(time < warmup + 1)
212 next_round = time + 3;
214 if(!arena_roundbased || (next_round && next_round < time && player_count > 1))
220 champion = find(world, classname, "player");
221 while(champion && champion.deadflag)
222 champion = find(champion, classname, "player");
226 while(numspawned < maxspawned && spawnqueue_first)
228 self = spawnqueue_first;
230 bprint ("^4", self.netname, "^4 is the next challenger\n");
232 Spawnqueue_Remove(self);
233 Spawnqueue_Mark(self);
235 self.classname = "player";