Please disclose if any significant portion of your mod was created using AI tools by adding the 'AI Generated' category. Failing to do so may result in the mod being removed from Thunderstore.
Decompiled source of NoACTimeStop v1.0.0
plugins/NoACTimeStop/NoACTimeStop.dll
Decompiled 5 months agousing System; using System.Diagnostics; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using BepInEx; using BepInEx.Configuration; using BepInEx.Logging; using HG.Reflection; using Microsoft.CodeAnalysis; using RoR2; using RoR2.ContentManagement; using RoR2BepInExPack.GameAssetPaths.Version_1_39_0; using UnityEngine.AddressableAssets; using UnityEngine.ResourceManagement.AsyncOperations; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: OptIn] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: AssemblyCompany("NoACTimeStop")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0+9234e4fbe4d22ef8f21877dcfe9275cd426e3eef")] [assembly: AssemblyProduct("NoACTimeStop")] [assembly: AssemblyTitle("NoACTimeStop")] [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 NoACTimeStop { internal static class Log { internal static ManualLogSource _logSource; internal static void Init(ManualLogSource logSource) { _logSource = logSource; } private static string getLogPrefix(string callerPath, string callerMemberName, int callerLineNumber) { int num = callerPath.LastIndexOf("NoACTimeStop"); if (num >= 0) { callerPath = callerPath.Substring(num + "NoACTimeStop".Length + 1); } return $"{callerPath}:{callerLineNumber} ({callerMemberName}) "; } internal static void Error(object data, [CallerFilePath] string callerPath = "", [CallerMemberName] string callerMemberName = "", [CallerLineNumber] int callerLineNumber = -1) { _logSource.LogError((object)(getLogPrefix(callerPath, callerMemberName, callerLineNumber) + data)); } internal static void Error_NoCallerPrefix(object data) { _logSource.LogError(data); } internal static void Fatal(object data, [CallerFilePath] string callerPath = "", [CallerMemberName] string callerMemberName = "", [CallerLineNumber] int callerLineNumber = -1) { _logSource.LogFatal((object)(getLogPrefix(callerPath, callerMemberName, callerLineNumber) + data)); } internal static void Fatal_NoCallerPrefix(object data) { _logSource.LogFatal(data); } internal static void Info(object data, [CallerFilePath] string callerPath = "", [CallerMemberName] string callerMemberName = "", [CallerLineNumber] int callerLineNumber = -1) { _logSource.LogInfo((object)(getLogPrefix(callerPath, callerMemberName, callerLineNumber) + data)); } internal static void Info_NoCallerPrefix(object data) { _logSource.LogInfo(data); } internal static void Message(object data, [CallerFilePath] string callerPath = "", [CallerMemberName] string callerMemberName = "", [CallerLineNumber] int callerLineNumber = -1) { _logSource.LogMessage((object)(getLogPrefix(callerPath, callerMemberName, callerLineNumber) + data)); } internal static void Message_NoCallerPrefix(object data) { _logSource.LogMessage(data); } internal static void Warning(object data, [CallerFilePath] string callerPath = "", [CallerMemberName] string callerMemberName = "", [CallerLineNumber] int callerLineNumber = -1) { _logSource.LogWarning((object)(getLogPrefix(callerPath, callerMemberName, callerLineNumber) + data)); } internal static void Warning_NoCallerPrefix(object data) { _logSource.LogWarning(data); } } [BepInPlugin("Nuxlar.NoACTimeStop", "NoACTimeStop", "1.0.0")] public class Main : BaseUnityPlugin { public const string PluginGUID = "Nuxlar.NoACTimeStop"; public const string PluginAuthor = "Nuxlar"; public const string PluginName = "NoACTimeStop"; public const string PluginVersion = "1.0.0"; public static ConfigEntry<bool> stopHauntTimer; public static ConfigEntry<bool> stopWebTimer; internal static Main Instance { get; private set; } public static string PluginDirectory { get; private set; } private static ConfigFile NTSConfig { get; set; } public void Awake() { //IL_0021: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Expected O, but got Unknown Instance = this; Log.Init(((BaseUnityPlugin)this).Logger); NTSConfig = new ConfigFile(Paths.ConfigPath + "\\com.Nuxlar.NoACTimeStop.cfg", true); stopHauntTimer = NTSConfig.Bind<bool>("General", "Stop Solutional Haunt Timer", true, "stop Solus Wing's stage timer"); stopWebTimer = NTSConfig.Bind<bool>("General", "Stop Solus Web Timer", true, "stop Solus Heart's stage timer"); LoadAssets(); } private static void LoadAssets() { //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0047: Unknown result type (might be due to invalid IL or missing references) AsyncOperationHandle<SceneDef> val = AssetAsyncReferenceManager<SceneDef>.LoadAsset(new AssetReferenceT<SceneDef>(RoR2_DLC3_solutionalhaunt.solutionalhaunt_asset), (AsyncReferenceHandleUnloadType)2); val.Completed += delegate(AsyncOperationHandle<SceneDef> x) { //IL_0016: Unknown result type (might be due to invalid IL or missing references) SceneDef result2 = x.Result; if (stopHauntTimer.Value) { result2.sceneType = (SceneType)1; } }; val = AssetAsyncReferenceManager<SceneDef>.LoadAsset(new AssetReferenceT<SceneDef>(RoR2_DLC3_solusweb.solusweb_asset), (AsyncReferenceHandleUnloadType)2); val.Completed += delegate(AsyncOperationHandle<SceneDef> x) { //IL_0016: Unknown result type (might be due to invalid IL or missing references) SceneDef result = x.Result; if (stopWebTimer.Value) { result.sceneType = (SceneType)1; } }; } } }