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();
}
}
}