Decompiled source of LethalCompletionist v1.0.0

LethalCompletionist.dll

Decompiled 3 hours ago
using 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)
		{
		}
	}
}