mirror of
https://github.com/ZDoom/gzdoom.git
synced 2025-01-18 15:42:34 +00:00
- Fixed: Adding multiple bots at the same time could cause the game to crash if there were too few bots defined.
- The 'loaded_bots' variable no longer needs to be stored.
This commit is contained in:
parent
9446edc068
commit
aebf0e7526
2 changed files with 36 additions and 31 deletions
|
@ -130,7 +130,6 @@ private:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool ctf;
|
bool ctf;
|
||||||
int loaded_bots;
|
|
||||||
int t_join;
|
int t_join;
|
||||||
bool observer; //Consoleplayer is observer.
|
bool observer; //Consoleplayer is observer.
|
||||||
};
|
};
|
||||||
|
@ -188,12 +187,12 @@ public:
|
||||||
fixed_t oldy;
|
fixed_t oldy;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
//(B_think.cpp)
|
//(b_think.cpp)
|
||||||
void Think ();
|
void Think ();
|
||||||
void ThinkForMove (ticcmd_t *cmd);
|
void ThinkForMove (ticcmd_t *cmd);
|
||||||
void Set_enemy ();
|
void Set_enemy ();
|
||||||
|
|
||||||
//(B_func.cpp)
|
//(b_func.cpp)
|
||||||
bool Reachable (AActor *target);
|
bool Reachable (AActor *target);
|
||||||
void Dofire (ticcmd_t *cmd);
|
void Dofire (ticcmd_t *cmd);
|
||||||
AActor *Choose_Mate ();
|
AActor *Choose_Mate ();
|
||||||
|
|
|
@ -216,19 +216,16 @@ bool FCajunMaster::SpawnBot (const char *name, int color)
|
||||||
"\\color\\cf df 90" //10 = Bleached Bone
|
"\\color\\cf df 90" //10 = Bleached Bone
|
||||||
};
|
};
|
||||||
|
|
||||||
botinfo_t *thebot;
|
botinfo_t *thebot = botinfo;
|
||||||
int botshift;
|
int botshift = 0;
|
||||||
|
|
||||||
if (name)
|
if (name)
|
||||||
{
|
{
|
||||||
thebot = botinfo;
|
|
||||||
|
|
||||||
// Check if exist or already in the game.
|
// Check if exist or already in the game.
|
||||||
botshift = 0;
|
|
||||||
while (thebot && stricmp (name, thebot->name))
|
while (thebot && stricmp (name, thebot->name))
|
||||||
{
|
{
|
||||||
thebot = thebot->next;
|
|
||||||
botshift++;
|
botshift++;
|
||||||
|
thebot = thebot->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (thebot == NULL)
|
if (thebot == NULL)
|
||||||
|
@ -246,29 +243,38 @@ bool FCajunMaster::SpawnBot (const char *name, int color)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (botnum < loaded_bots)
|
|
||||||
{
|
|
||||||
bool vacant = false; //Spawn a random bot from bots.cfg if no name given.
|
|
||||||
while (!vacant)
|
|
||||||
{
|
|
||||||
int rnum = (pr_botspawn() % loaded_bots);
|
|
||||||
thebot = botinfo;
|
|
||||||
botshift = 0;
|
|
||||||
while (rnum)
|
|
||||||
{
|
|
||||||
--rnum, thebot = thebot->next;
|
|
||||||
botshift++;
|
|
||||||
}
|
|
||||||
if (thebot->inuse == BOTINUSE_No)
|
|
||||||
vacant = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
//Spawn a random bot from bots.cfg if no name given.
|
||||||
|
TArray<botinfo_t *> BotInfoAvailable;
|
||||||
|
|
||||||
|
while (thebot)
|
||||||
|
{
|
||||||
|
if (thebot->inuse == BOTINUSE_No)
|
||||||
|
BotInfoAvailable.Push (thebot);
|
||||||
|
|
||||||
|
thebot = thebot->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (BotInfoAvailable.Size () == 0)
|
||||||
{
|
{
|
||||||
Printf ("Couldn't spawn bot; no bot left in %s\n", BOTFILENAME);
|
Printf ("Couldn't spawn bot; no bot left in %s\n", BOTFILENAME);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
thebot = BotInfoAvailable[pr_botspawn() % BotInfoAvailable.Size ()];
|
||||||
|
|
||||||
|
botinfo_t *thebot2 = botinfo;
|
||||||
|
while (thebot2)
|
||||||
|
{
|
||||||
|
if (thebot == thebot2)
|
||||||
|
break;
|
||||||
|
|
||||||
|
botshift++;
|
||||||
|
thebot2 = thebot2->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
thebot->inuse = BOTINUSE_Waiting;
|
thebot->inuse = BOTINUSE_Waiting;
|
||||||
|
|
||||||
Net_WriteByte (DEM_ADDBOT);
|
Net_WriteByte (DEM_ADDBOT);
|
||||||
|
@ -478,7 +484,6 @@ void FCajunMaster::ForgetBots ()
|
||||||
}
|
}
|
||||||
|
|
||||||
botinfo = NULL;
|
botinfo = NULL;
|
||||||
loaded_bots = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FCajunMaster::LoadBots ()
|
bool FCajunMaster::LoadBots ()
|
||||||
|
@ -486,6 +491,7 @@ bool FCajunMaster::LoadBots ()
|
||||||
FScanner sc;
|
FScanner sc;
|
||||||
FString tmp;
|
FString tmp;
|
||||||
bool gotteam = false;
|
bool gotteam = false;
|
||||||
|
int loaded_bots = 0;
|
||||||
|
|
||||||
bglobal.ForgetBots ();
|
bglobal.ForgetBots ();
|
||||||
tmp = M_GetCajunPath(BOTFILENAME);
|
tmp = M_GetCajunPath(BOTFILENAME);
|
||||||
|
@ -602,9 +608,9 @@ bool FCajunMaster::LoadBots ()
|
||||||
newinfo->next = bglobal.botinfo;
|
newinfo->next = bglobal.botinfo;
|
||||||
newinfo->lastteam = TEAM_NONE;
|
newinfo->lastteam = TEAM_NONE;
|
||||||
bglobal.botinfo = newinfo;
|
bglobal.botinfo = newinfo;
|
||||||
bglobal.loaded_bots++;
|
loaded_bots++;
|
||||||
}
|
}
|
||||||
Printf ("%d bots read from %s\n", bglobal.loaded_bots, BOTFILENAME);
|
Printf ("%d bots read from %s\n", loaded_bots, BOTFILENAME);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue