mirror of
https://github.com/nzp-team/quakec.git
synced 2024-12-01 16:32:37 +00:00
SERVER/FTE: Update all AI all at once
This commit is contained in:
parent
cb72f35aa5
commit
6c769b4e36
2 changed files with 45 additions and 7 deletions
|
@ -847,9 +847,19 @@ void() Hellhound_AI =
|
||||||
Inside_Walk(0);
|
Inside_Walk(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
//This function ensures that only one zombie's ai is done at a time, brings down lag significantly
|
//
|
||||||
void() Do_Zombie_AI = {
|
// Do_Zombie_AI()
|
||||||
local entity z;
|
// Behaves differently based on platform -- in FTE,
|
||||||
|
// all AI can afford to be executed at once. However,
|
||||||
|
// on every other platform there is a timed delay in
|
||||||
|
// place and only one zombie AI can be updated at a time.
|
||||||
|
//
|
||||||
|
void() Do_Zombie_AI =
|
||||||
|
{
|
||||||
|
entity z;
|
||||||
|
entity old_self;
|
||||||
|
|
||||||
|
#ifndef FTE
|
||||||
|
|
||||||
z = find(lastzombie,aistatus,"1");
|
z = find(lastzombie,aistatus,"1");
|
||||||
if(z == world) {
|
if(z == world) {
|
||||||
|
@ -858,15 +868,38 @@ void() Do_Zombie_AI = {
|
||||||
return;//no zombies alive.
|
return;//no zombies alive.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
local entity oself;
|
|
||||||
oself = self;
|
old_self = self;
|
||||||
self = z;
|
self = z;
|
||||||
|
|
||||||
if(z.classname == "ai_zombie")
|
if(z.classname == "ai_zombie")
|
||||||
Zombie_AI();
|
Zombie_AI();
|
||||||
else if (z.classname == "ai_dog")
|
else if (z.classname == "ai_dog")
|
||||||
Hellhound_AI();
|
Hellhound_AI();
|
||||||
self = oself;
|
|
||||||
|
self = old_self;
|
||||||
lastzombie = z;
|
lastzombie = z;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
z = find(world, aistatus, "1");
|
||||||
|
|
||||||
|
while(z != world) {
|
||||||
|
old_self = self;
|
||||||
|
self = z;
|
||||||
|
|
||||||
|
// Execute AI
|
||||||
|
if (z.classname == "ai_zombie")
|
||||||
|
Zombie_AI();
|
||||||
|
else if (z.classname == "ai_dog")
|
||||||
|
Hellhound_AI();
|
||||||
|
|
||||||
|
self = old_self;
|
||||||
|
z = find(z, aistatus, "1");
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // FTE
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef FTE
|
#ifdef FTE
|
||||||
|
|
|
@ -269,8 +269,13 @@ void Z_ElectroShock();
|
||||||
.float death_timer; // A timer that will kill a Zombie when it expires.
|
.float death_timer; // A timer that will kill a Zombie when it expires.
|
||||||
.float death_timer_activated; // To prevent Zombies just dying because of this..
|
.float death_timer_activated; // To prevent Zombies just dying because of this..
|
||||||
|
|
||||||
|
#ifndef FTE
|
||||||
|
|
||||||
|
entity lastzombie; // Used by non-FTE to update zombie AI one ent at a time.
|
||||||
|
|
||||||
|
#endif // FTE
|
||||||
|
|
||||||
.string aistatus;
|
.string aistatus;
|
||||||
entity lastzombie;
|
|
||||||
float zombie_spawn_delay; // time before spawning, in seconds.
|
float zombie_spawn_delay; // time before spawning, in seconds.
|
||||||
float zombie_spawn_timer; // the actual timer for spawn delay
|
float zombie_spawn_timer; // the actual timer for spawn delay
|
||||||
//Other AI definitions
|
//Other AI definitions
|
||||||
|
|
Loading…
Reference in a new issue