2023-05-14 04:41:54 +03:00
|
|
|
class Mut extends KFMutator;
|
|
|
|
|
|
|
|
const SML = class'SafeMutLoader';
|
|
|
|
|
|
|
|
const OptAC = "AccessControl";
|
|
|
|
const OptMut = "Mutator";
|
|
|
|
|
|
|
|
var private E_LogLevel LogLevel;
|
|
|
|
|
|
|
|
public function PreBeginPlay()
|
|
|
|
{
|
|
|
|
Super.PreBeginPlay();
|
|
|
|
|
|
|
|
LogLevel = SML.static.GetLogLevel();
|
|
|
|
|
|
|
|
`Log_Trace();
|
|
|
|
|
|
|
|
if (CorrectLoadOrder())
|
|
|
|
{
|
|
|
|
ModifyLoad();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
`Log_Fatal(SML.static.GetName(Self) @ "must be loaded first.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function AddMutator(Mutator Mut)
|
|
|
|
{
|
|
|
|
`Log_Trace();
|
|
|
|
|
|
|
|
if (CorrectLoadOrder() || Mut == Self) return;
|
|
|
|
|
|
|
|
if (Mut.Class == Class)
|
|
|
|
{
|
|
|
|
Mut.Destroy();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Super.AddMutator(Mut);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function bool CorrectLoadOrder()
|
|
|
|
{
|
|
|
|
`Log_Trace();
|
|
|
|
|
|
|
|
return (
|
|
|
|
WorldInfo.Game.BaseMutator == None ||
|
|
|
|
WorldInfo.Game.BaseMutator == Self);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function ModifyLoad()
|
|
|
|
{
|
|
|
|
local String LoadURL;
|
|
|
|
local String LoadParams;
|
|
|
|
local String MutatorsRaw;
|
|
|
|
local String AccessControlRaw;
|
|
|
|
local Array<String> Mutators;
|
|
|
|
local int PrevServerActorsCount;
|
|
|
|
local int Index;
|
|
|
|
local GameEngine GameEngine;
|
|
|
|
|
|
|
|
`Log_Trace();
|
|
|
|
|
|
|
|
LoadURL = WorldInfo.GetLocalURL();
|
|
|
|
LoadParams = Mid(LoadURL, InStr(LoadURL, "?"));
|
|
|
|
MutatorsRaw = WorldInfo.Game.ParseOption(LoadParams, OptMut);
|
|
|
|
AccessControlRaw = WorldInfo.Game.ParseOption(LoadParams, OptAC);
|
|
|
|
|
|
|
|
LoadURL = Repl(LoadURL, Subst(OptMut) $ MutatorsRaw, "");
|
|
|
|
LoadURL = Repl(LoadURL, Subst(OptAC) $ AccessControlRaw, "");
|
|
|
|
|
|
|
|
SML.static.ClearMutators();
|
|
|
|
SML.static.ClearServerActors();
|
|
|
|
ParseStringIntoArray(MutatorsRaw, Mutators, ",", true);
|
|
|
|
|
|
|
|
Index = 0;
|
|
|
|
while (Index < Mutators.Length)
|
|
|
|
{
|
|
|
|
if (SML.static.AddMutator(Mutators[Index]) ||
|
|
|
|
Mutators[Index] ~= SML.static.GetName(Self))
|
|
|
|
{
|
|
|
|
Mutators.Remove(Index, 1);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
++Index;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
GameEngine = GameEngine(Class'Engine'.static.GetEngine());
|
|
|
|
if (GameEngine == None)
|
|
|
|
{
|
|
|
|
`Log_Error("GameEngine is None, skip loading server actors");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
PrevServerActorsCount = GameEngine.ServerActors.Length;
|
|
|
|
|
|
|
|
Index = 0;
|
|
|
|
while (Index < GameEngine.ServerActors.Length)
|
|
|
|
{
|
|
|
|
if (SML.static.AddServerActor(GameEngine.ServerActors[Index]))
|
|
|
|
{
|
|
|
|
GameEngine.ServerActors.Remove(Index, 1);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
++Index;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GameEngine.ServerActors.Length != PrevServerActorsCount)
|
|
|
|
{
|
|
|
|
GameEngine.SaveConfig();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SML.static.StaticSaveConfig();
|
|
|
|
|
|
|
|
JoinArray(Mutators, MutatorsRaw);
|
|
|
|
LoadURL $= (Subst(OptMut) $ MutatorsRaw);
|
|
|
|
if (SML.static.WantsToSpawn())
|
|
|
|
{
|
|
|
|
LoadURL $= (Subst(OptAC) $ SML.static.GetName());
|
|
|
|
}
|
|
|
|
|
|
|
|
`Log_Info("Loader modified, do server travel...");
|
|
|
|
|
|
|
|
WorldInfo.ServerTravel(LoadURL, true);
|
2023-06-28 01:06:21 +03:00
|
|
|
WorldInfo.ForceGarbageCollection(true);
|
2023-05-14 04:41:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
private static function String Subst(String Option)
|
|
|
|
{
|
|
|
|
return ("?" $ Option $ "=");
|
|
|
|
}
|
|
|
|
|
|
|
|
defaultproperties
|
|
|
|
{
|
2023-05-14 05:12:21 +03:00
|
|
|
GroupNames.Add("AccessControl")
|
2022-09-02 15:54:10 +03:00
|
|
|
}
|