Decompiled source of GlobalScreamCooldownTimer v1.1.1

plugins/GlobalScreamCooldownTimer.dll

Decompiled 2 months ago
using System;
using System.CodeDom.Compiler;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.Versioning;
using System.Security;
using System.Security.Permissions;
using BepInEx;
using BepInEx.Core.Logging.Interpolation;
using BepInEx.Logging;
using BepInEx.Unity.IL2CPP;
using Enemies;
using GTFO.API;
using GlobalScreamCooldownTimer.Patches;
using HarmonyLib;
using Il2CppInterop.Runtime.Injection;
using Il2CppInterop.Runtime.InteropTypes;
using Microsoft.CodeAnalysis;
using StateMachines;
using TMPro;
using UnityEngine;

[assembly: CompilationRelaxations(8)]
[assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)]
[assembly: Debuggable(DebuggableAttribute.DebuggingModes.Default | DebuggableAttribute.DebuggingModes.DisableOptimizations | DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints | DebuggableAttribute.DebuggingModes.EnableEditAndContinue)]
[assembly: TargetFramework(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")]
[assembly: AssemblyCompany("GlobalScreamCooldownTimer")]
[assembly: AssemblyConfiguration("Debug")]
[assembly: AssemblyFileVersion("1.0.0")]
[assembly: AssemblyInformationalVersion("1.0.0")]
[assembly: AssemblyProduct("GlobalScreamCooldownTimer")]
[assembly: AssemblyTitle("GlobalScreamCooldownTimer")]
[assembly: TargetPlatform("Windows7.0")]
[assembly: SupportedOSPlatform("Windows7.0")]
[assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)]
[assembly: AssemblyVersion("1.0.0.0")]
[module: UnverifiableCode]
[module: RefSafetyRules(11)]
namespace Microsoft.CodeAnalysis
{
	[CompilerGenerated]
	[Microsoft.CodeAnalysis.Embedded]
	internal sealed class EmbeddedAttribute : Attribute
	{
	}
}
namespace System.Runtime.CompilerServices
{
	[CompilerGenerated]
	[Microsoft.CodeAnalysis.Embedded]
	[AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)]
	internal sealed class RefSafetyRulesAttribute : Attribute
	{
		public readonly int Version;

		public RefSafetyRulesAttribute(int P_0)
		{
			Version = P_0;
		}
	}
}
namespace GlobalScreamCooldownTimer
{
	[BepInPlugin("JarheadHME.GlobalScreamCooldownTimer", "GlobalScreamCooldownTimer", "1.0.0")]
	[BepInDependency(/*Could not decode attribute arguments.*/)]
	[BepInDependency(/*Could not decode attribute arguments.*/)]
	internal class EntryPoint : BasePlugin
	{
		private Harmony _Harmony = null;

		public override void Load()
		{
			//IL_0007: Unknown result type (might be due to invalid IL or missing references)
			//IL_0011: Expected O, but got Unknown
			//IL_0022: Unknown result type (might be due to invalid IL or missing references)
			//IL_0028: Expected O, but got Unknown
			_Harmony = new Harmony("GlobalScreamCooldownTimer.Harmony");
			_Harmony.PatchAll();
			bool flag = default(bool);
			BepInExInfoLogInterpolatedStringHandler val = new BepInExInfoLogInterpolatedStringHandler(32, 1, ref flag);
			if (flag)
			{
				((BepInExLogInterpolatedStringHandler)val).AppendLiteral("Plugin has loaded with ");
				((BepInExLogInterpolatedStringHandler)val).AppendFormatted<int>(_Harmony.GetPatchedMethods().Count());
				((BepInExLogInterpolatedStringHandler)val).AppendLiteral(" patches!");
			}
			Logger.Info(val);
			ClassInjector.RegisterTypeInIl2Cpp<TimerUpdater>();
			LevelAPI.OnLevelCleanup += TimerUpdater.OnLevelCleanup;
		}

		public override bool Unload()
		{
			_Harmony.UnpatchSelf();
			return ((BasePlugin)this).Unload();
		}
	}
	internal static class Logger
	{
		private static readonly ManualLogSource _Logger;

		static Logger()
		{
			//IL_0006: Unknown result type (might be due to invalid IL or missing references)
			//IL_0010: Expected O, but got Unknown
			_Logger = new ManualLogSource("GlobalScreamCooldownTimer");
			Logger.Sources.Add((ILogSource)(object)_Logger);
		}

		private static string Format(object msg)
		{
			return msg.ToString();
		}

		public static void Info(BepInExInfoLogInterpolatedStringHandler handler)
		{
			_Logger.LogInfo(handler);
		}

		public static void Info(string str)
		{
			_Logger.LogMessage((object)str);
		}

		public static void Info(object data)
		{
			_Logger.LogMessage((object)Format(data));
		}

		public static void Debug(BepInExDebugLogInterpolatedStringHandler handler)
		{
			_Logger.LogDebug(handler);
		}

		public static void Debug(string str)
		{
			_Logger.LogDebug((object)str);
		}

		public static void Debug(object data)
		{
			_Logger.LogDebug((object)Format(data));
		}

		public static void Error(BepInExErrorLogInterpolatedStringHandler handler)
		{
			_Logger.LogError(handler);
		}

		public static void Error(string str)
		{
			_Logger.LogError((object)str);
		}

		public static void Error(object data)
		{
			_Logger.LogError((object)Format(data));
		}

		public static void Fatal(BepInExFatalLogInterpolatedStringHandler handler)
		{
			_Logger.LogFatal(handler);
		}

		public static void Fatal(string str)
		{
			_Logger.LogFatal((object)str);
		}

		public static void Fatal(object data)
		{
			_Logger.LogFatal((object)Format(data));
		}

		public static void Warn(BepInExWarningLogInterpolatedStringHandler handler)
		{
			_Logger.LogWarning(handler);
		}

		public static void Warn(string str)
		{
			_Logger.LogWarning((object)str);
		}

		public static void Warn(object data)
		{
			_Logger.LogWarning((object)Format(data));
		}

		[Conditional("DEBUG")]
		public static void DebugOnly(object data)
		{
			_Logger.LogDebug((object)Format(data));
		}
	}
	[GeneratedCode("VersionInfoGenerator", "2.1.3+git35c0c2a-master")]
	[CompilerGenerated]
	internal static class VersionInfo
	{
		public const string RootNamespace = "GlobalScreamCooldownTimer";

		public const string Version = "1.0.0";

		public const string VersionPrerelease = null;

		public const string VersionMetadata = null;

		public const string SemVer = "1.0.0";

		public const string GitRevShort = null;

		public const string GitRevLong = null;

		public const string GitBranch = null;

		public const string GitTag = null;

		public const int GitCommitsSinceTag = 0;

		public const bool GitIsDirty = false;
	}
}
namespace GlobalScreamCooldownTimer.Patches
{
	[HarmonyPatch]
	internal class Patches
	{
		[HarmonyPatch(typeof(PlayerGuiLayer), "Setup")]
		[HarmonyPostfix]
		public static void SetupTimer(PlayerGuiLayer __instance, Transform root, string name)
		{
			//IL_0012: Unknown result type (might be due to invalid IL or missing references)
			PUI_SkipText val = ((Il2CppObjectBase)((GuiLayer)__instance).AddRectComp("gui/player/PUI_SkipText", (GuiAnchor)6, new Vector2(-104f, 0f), ((GuiLayer)__instance).CustomComponentRoot)).TryCast<PUI_SkipText>();
			val.SetProgress(0f);
			TimerUpdater timerUpdater = ((Component)val).gameObject.AddComponent<TimerUpdater>();
			timerUpdater.m_textComp = val;
		}

		[HarmonyPatch(typeof(EnemyAgent), "Setup")]
		[HarmonyPostfix]
		public static void AddIndividualTimer(EnemyAgent __instance)
		{
			GameObject trackingObjFromEnemyAgent = GetTrackingObjFromEnemyAgent(__instance);
			NavMarker val = GuiManager.NavMarkerLayer.PlaceTitleMarker(trackingObjFromEnemyAgent);
			val.SetVisible(false);
			TimerUpdater.TrackedEnemyTimers.TryAdd(((Object)__instance).GetInstanceID(), (__instance, val));
		}

		public static GameObject GetTrackingObjFromEnemyAgent(EnemyAgent __instance)
		{
			EnemyModelRefs modelRef = __instance.ModelRef;
			if ((Object)(object)modelRef.m_headBone != (Object)null)
			{
				return ((Component)modelRef.m_headBone).gameObject;
			}
			return ((Component)modelRef).gameObject;
		}
	}
	public class TimerUpdater : MonoBehaviour
	{
		internal PUI_SkipText m_textComp;

		public static Dictionary<int, (EnemyAgent, NavMarker)> TrackedEnemyTimers = new Dictionary<int, (EnemyAgent, NavMarker)>();

		public void Update()
		{
			((TMP_Text)m_textComp.m_intelText).SetText(Math.Max(EB_InCombat.s_globalScreamTimer - Clock.Time, 0f).ToString("0.0"), true);
			UpdateEnemyTimers();
		}

		public void UpdateEnemyTimers()
		{
			//IL_003d: Unknown result type (might be due to invalid IL or missing references)
			//IL_0044: Invalid comparison between Unknown and I4
			foreach (var value in TrackedEnemyTimers.Values)
			{
				EnemyAgent item = value.Item1;
				NavMarker item2 = value.Item2;
				EnemyBehaviour behaviour = item.AI.m_behaviour;
				if ((int)behaviour.m_currentStateName == 19)
				{
					Logger.Debug("Removing dead enemy");
					TrackedEnemyTimers.Remove(((Object)item).GetInstanceID());
					GuiManager.NavMarkerLayer.RemoveMarker(item2);
					continue;
				}
				EB_InCombat val = ((Il2CppObjectBase)((StateMachine<EB_StateBase>)(object)behaviour).m_currentState).TryCast<EB_InCombat>();
				if (val == null)
				{
					continue;
				}
				val = ((Il2CppObjectBase)((StateMachine<EB_StateBase>)(object)behaviour).m_states[5]).TryCast<EB_InCombat>();
				if (val == null)
				{
					Logger.Error("What the fuck why is the combat state null >:(");
					continue;
				}
				float time = Clock.Time;
				float num = Math.Max(((EB_InCombat_Base)val).m_firstScreamAllowedTime, val.m_localScreamTimer);
				if (item2.IsVisible && num < time)
				{
					item2.SetVisible(false);
					continue;
				}
				if (!item2.IsVisible && num > time)
				{
					item2.SetVisible(true);
					item2.m_pin.SetEnabled(false);
				}
				item2.SetTitle((num - time).ToString("0.0"));
			}
		}

		public static void OnLevelCleanup()
		{
			TrackedEnemyTimers.Clear();
		}
	}
}