2022-05-11 15:43:39 +03:00
|
|
|
class SpawnListBossWaves extends Object
|
|
|
|
dependson(ZedSpawner)
|
|
|
|
config(ZedSpawner);
|
|
|
|
|
|
|
|
struct S_SpawnEntryCfg
|
|
|
|
{
|
|
|
|
var String BossClass;
|
|
|
|
var String ZedClass;
|
|
|
|
var int Delay;
|
|
|
|
var int Probability;
|
2022-05-16 05:42:13 +03:00
|
|
|
var int SpawnCountBase;
|
|
|
|
var int SingleSpawnLimit;
|
2022-05-11 15:43:39 +03:00
|
|
|
};
|
|
|
|
|
2022-06-01 03:03:02 +03:00
|
|
|
var public config bool bStopRegularSpawn;
|
2022-05-21 00:31:35 +03:00
|
|
|
var private config Array<S_SpawnEntryCfg> Spawn;
|
2022-05-11 15:43:39 +03:00
|
|
|
|
2022-07-19 13:28:43 +03:00
|
|
|
public static function InitConfig(int Version, int LatestVersion, KFGI_Access KFGIA, E_LogLevel LogLevel)
|
2022-05-11 15:43:39 +03:00
|
|
|
{
|
2022-07-19 13:28:43 +03:00
|
|
|
`Log_TraceStatic();
|
|
|
|
|
2022-05-20 23:45:26 +03:00
|
|
|
switch (Version)
|
|
|
|
{
|
|
|
|
case `NO_CONFIG:
|
2022-07-19 13:28:43 +03:00
|
|
|
ApplyDefault(KFGIA, LogLevel);
|
2022-05-20 23:45:26 +03:00
|
|
|
|
|
|
|
default: break;
|
|
|
|
}
|
2022-05-11 15:43:39 +03:00
|
|
|
|
2022-05-20 23:45:26 +03:00
|
|
|
if (LatestVersion != Version)
|
|
|
|
{
|
|
|
|
StaticSaveConfig();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-19 13:28:43 +03:00
|
|
|
private static function ApplyDefault(KFGI_Access KFGIA, E_LogLevel LogLevel)
|
2022-05-20 23:45:26 +03:00
|
|
|
{
|
2022-06-01 03:03:02 +03:00
|
|
|
local S_SpawnEntryCfg SpawnEntry;
|
2022-05-20 23:45:26 +03:00
|
|
|
local Array<class<KFPawn_Monster> > KFPM_Bosses;
|
2022-06-01 03:03:02 +03:00
|
|
|
local class<KFPawn_Monster> KFPMC;
|
|
|
|
|
2022-07-19 13:28:43 +03:00
|
|
|
`Log_TraceStatic();
|
|
|
|
|
2022-06-01 03:03:02 +03:00
|
|
|
default.Spawn.Length = 0;
|
2022-05-11 15:43:39 +03:00
|
|
|
|
2022-05-20 23:45:26 +03:00
|
|
|
default.bStopRegularSpawn = true;
|
|
|
|
default.Spawn.Length = 0;
|
|
|
|
SpawnEntry.ZedClass = "SomePackage.SomeClass";
|
2022-05-16 05:42:13 +03:00
|
|
|
SpawnEntry.SpawnCountBase = 2;
|
|
|
|
SpawnEntry.SingleSpawnLimit = 1;
|
2022-05-20 23:45:26 +03:00
|
|
|
SpawnEntry.Delay = 30;
|
2022-05-16 05:42:13 +03:00
|
|
|
SpawnEntry.Probability = 100;
|
2022-07-19 13:28:43 +03:00
|
|
|
KFPM_Bosses = KFGIA.GetAIBossClassList(LogLevel);
|
2022-05-20 23:45:26 +03:00
|
|
|
foreach KFPM_Bosses(KFPMC)
|
|
|
|
{
|
|
|
|
SpawnEntry.BossClass = "KFGameContent." $ String(KFPMC);
|
|
|
|
default.Spawn.AddItem(SpawnEntry);
|
|
|
|
}
|
2022-05-11 15:43:39 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public static function Array<S_SpawnEntry> Load(E_LogLevel LogLevel)
|
|
|
|
{
|
|
|
|
local Array<S_SpawnEntry> SpawnList;
|
|
|
|
local S_SpawnEntryCfg SpawnEntryCfg;
|
|
|
|
local S_SpawnEntry SpawnEntry;
|
|
|
|
local int Line;
|
|
|
|
local bool Errors;
|
|
|
|
|
2022-07-19 13:28:43 +03:00
|
|
|
`Log_TraceStatic();
|
|
|
|
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Info("Load boss waves spawn list:");
|
2022-05-11 15:43:39 +03:00
|
|
|
foreach default.Spawn(SpawnEntryCfg, Line)
|
|
|
|
{
|
|
|
|
Errors = false;
|
|
|
|
|
|
|
|
SpawnEntry.BossClass = class<KFPawn_Monster>(DynamicLoadObject(SpawnEntryCfg.BossClass, class'Class'));
|
|
|
|
if (SpawnEntry.BossClass == None)
|
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Warn("[" $ Line + 1 $ "]" @ "Can't load boss class:" @ SpawnEntryCfg.BossClass);
|
2022-05-11 15:43:39 +03:00
|
|
|
Errors = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
SpawnEntry.ZedClass = class<KFPawn_Monster>(DynamicLoadObject(SpawnEntryCfg.ZedClass, class'Class'));
|
|
|
|
if (SpawnEntry.ZedClass == None)
|
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Warn("[" $ Line + 1 $ "]" @ "Can't load zed class:" @ SpawnEntryCfg.ZedClass);
|
2022-05-11 15:43:39 +03:00
|
|
|
Errors = true;
|
|
|
|
}
|
|
|
|
|
2022-05-16 05:42:13 +03:00
|
|
|
SpawnEntry.RelativeStartDefault = 0.f;
|
|
|
|
|
|
|
|
SpawnEntry.DelayDefault = SpawnEntryCfg.Delay;
|
|
|
|
if (SpawnEntryCfg.Delay <= 0)
|
2022-05-11 15:43:39 +03:00
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Warn("[" $ Line + 1 $ "]" @ "Delay" @ "(" $ SpawnEntryCfg.Delay $ ")" @ "must be greater than 0");
|
2022-05-11 15:43:39 +03:00
|
|
|
Errors = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
SpawnEntry.Probability = SpawnEntryCfg.Probability / 100.f;
|
|
|
|
if (SpawnEntryCfg.Probability <= 0 || SpawnEntryCfg.Probability > 100)
|
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Warn("[" $ Line + 1 $ "]" @ "Probability" @ "(" $ SpawnEntryCfg.Probability $ ")" @ "must be greater than 0 and less than or equal 100");
|
2022-05-11 15:43:39 +03:00
|
|
|
Errors = true;
|
|
|
|
}
|
2022-05-16 05:42:13 +03:00
|
|
|
|
|
|
|
SpawnEntry.SpawnCountBase = SpawnEntryCfg.SpawnCountBase;
|
|
|
|
if (SpawnEntry.SpawnCountBase <= 0)
|
2022-05-11 15:43:39 +03:00
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Warn("[" $ Line + 1 $ "]" @ "SpawnCountBase" @ "(" $ SpawnEntryCfg.SpawnCountBase $ ")" @ "must be greater than 0");
|
2022-05-11 15:43:39 +03:00
|
|
|
Errors = true;
|
|
|
|
}
|
|
|
|
|
2022-05-16 05:42:13 +03:00
|
|
|
SpawnEntry.SingleSpawnLimitDefault = SpawnEntryCfg.SingleSpawnLimit;
|
|
|
|
if (SpawnEntry.SingleSpawnLimit < 0)
|
2022-05-11 15:43:39 +03:00
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Warn("[" $ Line + 1 $ "]" @ "SingleSpawnLimit" @ "(" $ SpawnEntryCfg.SingleSpawnLimit $ ")" @ "must be equal or greater than 0");
|
2022-05-11 15:43:39 +03:00
|
|
|
Errors = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!Errors)
|
|
|
|
{
|
|
|
|
SpawnList.AddItem(SpawnEntry);
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Debug("[" $ Line + 1 $ "]" @ "Loaded successfully: (" $ SpawnEntryCfg.BossClass $ ")" @ SpawnEntryCfg.ZedClass);
|
2022-05-11 15:43:39 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-13 09:56:35 +03:00
|
|
|
if (SpawnList.Length == default.Spawn.Length)
|
2022-06-01 03:03:02 +03:00
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Info("Boss spawn list loaded successfully (" $ default.Spawn.Length @ "entries)");
|
2022-06-01 03:03:02 +03:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2022-07-13 10:00:06 +03:00
|
|
|
`Log_Info("Boss spawn list: loaded" @ SpawnList.Length @ "of" @ default.Spawn.Length @ "entries");
|
2022-06-01 03:03:02 +03:00
|
|
|
}
|
|
|
|
|
2022-05-11 15:43:39 +03:00
|
|
|
return SpawnList;
|
|
|
|
}
|
|
|
|
|
|
|
|
defaultproperties
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|