From edb643628eb187572514e1cc71214c73fcfb5635 Mon Sep 17 00:00:00 2001
From: Yamato <66829532+louis1706@users.noreply.github.com>
Date: Fri, 27 Dec 2024 16:22:30 +0100
Subject: [PATCH] Fix Room Logic for FlickerableLight API (#350)
---
EXILED/Exiled.API/Features/Room.cs | 78 +++++++++----------
.../Exiled.Events/Patches/Generic/RoomList.cs | 17 +++-
2 files changed, 54 insertions(+), 41 deletions(-)
diff --git a/EXILED/Exiled.API/Features/Room.cs b/EXILED/Exiled.API/Features/Room.cs
index 4efae3acd..1af977bbd 100644
--- a/EXILED/Exiled.API/Features/Room.cs
+++ b/EXILED/Exiled.API/Features/Room.cs
@@ -401,10 +401,46 @@ public void UnlockAll()
/// Factory method to create and add a component to a Transform.
/// We can add parameters to be set privately here.
///
- /// The Game Object to attach the Room component to.
- internal static void CreateComponent(GameObject roomGameObject)
+ /// The Game Object to attach the Room component to.
+ internal static void CreateComponent(RoomIdentifier roomIdentifier) => roomIdentifier.gameObject.AddComponent();
+
+ ///
+ /// Factory method to complete all element inside a Room.
+ ///
+ internal void InternalCreate()
{
- roomGameObject.AddComponent().InternalCreate();
+ Identifier = gameObject.GetComponent();
+ RoomIdentifierToRoom.Add(Identifier, this);
+
+ Zone = FindZone(gameObject);
+#if DEBUG
+ if (Zone is ZoneType.Unspecified)
+ Log.Error($"[ZONETYPE UNKNOWN] {this} Zone : {Identifier?.Zone}");
+#endif
+ Type = FindType(gameObject);
+#if DEBUG
+ if (Type is RoomType.Unknown)
+ Log.Error($"[ROOMTYPE UNKNOWN] {this} Name : {gameObject?.name} Shape : {Identifier?.Shape}");
+#endif
+
+ RoomLightControllers = RoomLightControllersValue.AsReadOnly();
+
+ GetComponentsInChildren().ForEach(component =>
+ {
+ Window window = new(component, this);
+ window.Room.WindowsValue.Add(window);
+ });
+
+ if (GetComponentInChildren() is global::TeslaGate tesla)
+ {
+ TeslaGate = new TeslaGate(tesla, this);
+ }
+
+ Windows = WindowsValue.AsReadOnly();
+ Doors = DoorsValue.AsReadOnly();
+ NearestRooms = NearestRoomsValue.AsReadOnly();
+ Speakers = SpeakersValue.AsReadOnly();
+ Cameras = CamerasValue.AsReadOnly();
}
private static RoomType FindType(GameObject gameObject)
@@ -500,41 +536,5 @@ private static ZoneType FindZone(GameObject gameObject)
_ => transform.position.y > 900 ? ZoneType.Surface : ZoneType.Unspecified,
};
}
-
- private void InternalCreate()
- {
- Identifier = gameObject.GetComponent();
- RoomIdentifierToRoom.Add(Identifier, this);
-
- Zone = FindZone(gameObject);
-#if DEBUG
- if (Zone is ZoneType.Unspecified)
- Log.Error($"[ZONETYPE UNKNOWN] {this} Zone : {Identifier?.Zone}");
-#endif
- Type = FindType(gameObject);
-#if DEBUG
- if (Type is RoomType.Unknown)
- Log.Error($"[ROOMTYPE UNKNOWN] {this} Name : {gameObject?.name} Shape : {Identifier?.Shape}");
-#endif
-
- RoomLightControllers = RoomLightControllersValue.AsReadOnly();
-
- GetComponentsInChildren().ForEach(component =>
- {
- Window window = new(component, this);
- window.Room.WindowsValue.Add(window);
- });
-
- if (GetComponentInChildren() is global::TeslaGate tesla)
- {
- TeslaGate = new TeslaGate(tesla, this);
- }
-
- Windows = WindowsValue.AsReadOnly();
- Doors = DoorsValue.AsReadOnly();
- NearestRooms = NearestRoomsValue.AsReadOnly();
- Speakers = SpeakersValue.AsReadOnly();
- Cameras = CamerasValue.AsReadOnly();
- }
}
}
diff --git a/EXILED/Exiled.Events/Patches/Generic/RoomList.cs b/EXILED/Exiled.Events/Patches/Generic/RoomList.cs
index 3686e2f1d..53f6ada70 100644
--- a/EXILED/Exiled.Events/Patches/Generic/RoomList.cs
+++ b/EXILED/Exiled.Events/Patches/Generic/RoomList.cs
@@ -37,14 +37,15 @@ private static IEnumerable Transpiler(IEnumerable i.Calls(Method(typeof(RoomIdUtils), nameof(RoomIdUtils.PositionToCoords)))) + offset;
- // Room.CreateComponent(gameObject);
+ // Room.Get(gameObject).InternalCreate();
newInstructions.InsertRange(
index,
new CodeInstruction[]
{
new CodeInstruction(OpCodes.Ldarg_0).MoveLabelsFrom(newInstructions[index]),
new(OpCodes.Callvirt, PropertyGetter(typeof(Component), nameof(Component.gameObject))),
- new(OpCodes.Call, Method(typeof(Room), nameof(Room.CreateComponent))),
+ new(OpCodes.Callvirt, Method(typeof(Room), nameof(Room.FindParentRoom), new System.Type[] { typeof(GameObject) })),
+ new(OpCodes.Callvirt, Method(typeof(Room), nameof(Room.InternalCreate))),
});
for (int z = 0; z < newInstructions.Count; z++)
@@ -54,6 +55,18 @@ private static IEnumerable Transpiler(IEnumerable
+ /// Patches .
+ ///
+ [HarmonyPatch(typeof(RoomIdentifier), nameof(RoomIdentifier.Awake))]
+ internal class RoomListAdd
+ {
+ private static void Postfix(RoomIdentifier __instance)
+ {
+ Room.CreateComponent(__instance);
+ }
+ }
+
///
/// Patches .
///