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 LethalCompletionist v1.0.0
LethalCompletionist.dll
Decompiled 3 hours agousing System; using System.Diagnostics; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using System.Text; using System.Text.RegularExpressions; using BepInEx; using BepInEx.Bootstrap; using BepInEx.Logging; using HarmonyLib; using LobbyCompatibility.Enums; using LobbyCompatibility.Features; using Microsoft.CodeAnalysis; using UnityEngine; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: IgnoresAccessChecksTo("Assembly-CSharp")] [assembly: AssemblyCompany("LethalCompletionist")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyDescription("Display slots for Sigurd logs and new enemies, in order")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0+3eb8524378586b1fd38b3a907d4b69366beb25e6")] [assembly: AssemblyProduct("LethalCompletionist")] [assembly: AssemblyTitle("LethalCompletionist")] [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 LethalCompletionist { internal static class LobbyCompatibility { internal static void Init() { PluginHelper.RegisterPlugin("butterystancakes.lethalcompany.lethalcompletionist", Version.Parse("1.0.0"), (CompatibilityLevel)0, (VersionStrictness)0); } } [BepInPlugin("butterystancakes.lethalcompany.lethalcompletionist", "Lethal Completionist", "1.0.0")] [BepInDependency(/*Could not decode attribute arguments.*/)] public class Plugin : BaseUnityPlugin { internal const string PLUGIN_GUID = "butterystancakes.lethalcompany.lethalcompletionist"; internal const string PLUGIN_NAME = "Lethal Completionist"; internal const string PLUGIN_VERSION = "1.0.0"; internal static ManualLogSource Logger; private const string GUID_LOBBY_COMPATIBILITY = "BMX.LobbyCompatibility"; private void Awake() { //IL_0035: Unknown result type (might be due to invalid IL or missing references) Logger = ((BaseUnityPlugin)this).Logger; if (Chainloader.PluginInfos.ContainsKey("BMX.LobbyCompatibility")) { Logger.LogInfo((object)"CROSS-COMPATIBILITY - Lobby Compatibility detected"); LobbyCompatibility.Init(); } new Harmony("butterystancakes.lethalcompany.lethalcompletionist").PatchAll(); Logger.LogInfo((object)"Lethal Completionist v1.0.0 loaded"); } } [HarmonyPatch] internal static class Patches { [HarmonyPatch(typeof(Terminal), "TextPostProcess")] [HarmonyPrefix] [HarmonyPriority(500)] private static void Terminal_Pre_TextPostProcess(Terminal __instance, ref string modifiedDisplayText) { if (modifiedDisplayText.Contains("[currentScannedEnemiesList]")) { StringBuilder stringBuilder = new StringBuilder(); for (int i = 0; i < __instance.enemyFiles.Count; i++) { if (((Object)__instance.enemyFiles[i]).name == "LassoManFile") { continue; } stringBuilder.Append(Environment.NewLine); if (__instance.scannedEnemyIDs.Contains(i)) { stringBuilder.Append(__instance.enemyFiles[i].creatureName ?? ""); if (__instance.newlyScannedEnemyIDs.Contains(i)) { stringBuilder.Append(" (NEW)"); } } else { stringBuilder.Append(Regex.Replace(__instance.enemyFiles[i].creatureName, "\\B[a-z]", "_")); } } modifiedDisplayText = modifiedDisplayText.Replace("[currentScannedEnemiesList]", stringBuilder.ToString()); } else { if (!modifiedDisplayText.Contains("[currentUnlockedLogsList]")) { return; } StringBuilder stringBuilder2 = new StringBuilder(); for (int j = 0; j < __instance.logEntryFiles.Count; j++) { stringBuilder2.Append(Environment.NewLine); if (__instance.unlockedStoryLogs.Contains(j)) { stringBuilder2.Append(__instance.logEntryFiles[j].creatureName ?? ""); if (__instance.newlyUnlockedStoryLogs.Contains(j)) { stringBuilder2.Append(" (NEW)"); } } else { stringBuilder2.Append("[DATA CORRUPTED OR OVERWRITTEN]"); } } modifiedDisplayText = modifiedDisplayText.Replace("[currentUnlockedLogsList]", stringBuilder2.ToString()); } } } public static class PluginInfo { public const string PLUGIN_GUID = "LethalCompletionist"; public const string PLUGIN_NAME = "LethalCompletionist"; public const string PLUGIN_VERSION = "1.0.0"; } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { public IgnoresAccessChecksToAttribute(string assemblyName) { } } }