Skip to content

Commit

Permalink
add short alias for mutator
Browse files Browse the repository at this point in the history
  • Loading branch information
GenZmeY committed Dec 31, 2023
1 parent 4d60429 commit bf19cfa
Show file tree
Hide file tree
Showing 3 changed files with 63 additions and 62 deletions.
4 changes: 2 additions & 2 deletions PublicationContent/description.txt
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ https://forums.tripwireinteractive.com/index.php?threads/whitelisting-mods-and-m
[*]Subscribe to this mutator;
[*]Start KF2;
[*]Open console (`) and input:
[b]open KF-BioticsLab?Mutator=YAS.YASMut?[/b]
[b]open KF-BioticsLab?Mutator=YAS.Mut?[/b]
(replace the map and add the parameters you need)
[*]<Enter>.
[/olist]
Expand All @@ -30,7 +30,7 @@ https://forums.tripwireinteractive.com/index.php?threads/whitelisting-mods-and-m
[*]Add the following string to the [b][OnlineSubsystemSteamworks.KFWorkshopSteamworks][/b] section (create one if it doesn't exist):
[b]ServerSubscribedWorkshopItems=2521826524[/b]
[*]Start the server and wait until the mutator is downloading;
[*]Add mutator to server start parameters: [b]?Mutator=YAS.YASMut[/b] and restart the server.
[*]Add mutator to server start parameters: [b]?Mutator=YAS.Mut[/b] and restart the server.
[/olist]

[h1]Important setup information[/h1]
Expand Down
60 changes: 60 additions & 0 deletions YAS/Classes/Mut.uc
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
class Mut extends KFMutator;

var private YAS YAS;

public simulated function bool SafeDestroy()
{
return (bPendingDelete || bDeleteMe || Destroy());
}

public event PreBeginPlay()
{
Super.PreBeginPlay();

if (WorldInfo.NetMode == NM_Client) return;

foreach WorldInfo.DynamicActors(class'YAS', YAS)
{
break;
}

if (YAS == None)
{
YAS = WorldInfo.Spawn(class'YAS');
}

if (YAS == None)
{
`Log_Base("FATAL: Can't Spawn 'YAS'");
SafeDestroy();
}
}

public function AddMutator(Mutator M)
{
if (M == Self) return;

if (M.Class == Class)
Mut(M).SafeDestroy();
else
Super.AddMutator(M);
}

public function NotifyLogin(Controller C)
{
YAS.NotifyLogin(C);

Super.NotifyLogin(C);
}

public function NotifyLogout(Controller C)
{
YAS.NotifyLogout(C);

Super.NotifyLogout(C);
}

DefaultProperties
{
GroupNames.Add("Scoreboard")
}
61 changes: 1 addition & 60 deletions YAS/Classes/YASMut.uc
Original file line number Diff line number Diff line change
@@ -1,60 +1 @@
class YASMut extends KFMutator;

var private YAS YAS;

public simulated function bool SafeDestroy()
{
return (bPendingDelete || bDeleteMe || Destroy());
}

public event PreBeginPlay()
{
Super.PreBeginPlay();

if (WorldInfo.NetMode == NM_Client) return;

foreach WorldInfo.DynamicActors(class'YAS', YAS)
{
break;
}

if (YAS == None)
{
YAS = WorldInfo.Spawn(class'YAS');
}

if (YAS == None)
{
`Log_Base("FATAL: Can't Spawn 'YAS'");
SafeDestroy();
}
}

public function AddMutator(Mutator Mut)
{
if (Mut == Self) return;

if (Mut.Class == Class)
YASMut(Mut).SafeDestroy();
else
Super.AddMutator(Mut);
}

public function NotifyLogin(Controller C)
{
YAS.NotifyLogin(C);

Super.NotifyLogin(C);
}

public function NotifyLogout(Controller C)
{
YAS.NotifyLogout(C);

Super.NotifyLogout(C);
}

DefaultProperties
{
GroupNames.Add("Scoreboard")
}
class YASMut extends Mut; // backward compatibility

0 comments on commit bf19cfa

Please sign in to comment.