Please disclose if your mod was created primarily 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 Silly Big Mod v1.0.2
ElevatorSymphony.dll
Decompiled 4 months agousing System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using System.Threading.Tasks; using BepInEx; using BepInEx.Configuration; using BepInEx.Logging; using ElevatorSymphony.Patches; using HarmonyLib; using Microsoft.CodeAnalysis; using UnityEngine; using UnityEngine.Networking; [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("ElevatorSymphony")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyDescription("My first plugin")] [assembly: AssemblyFileVersion("1.1.2.0")] [assembly: AssemblyInformationalVersion("1.1.2")] [assembly: AssemblyProduct("ElevatorSymphony")] [assembly: AssemblyTitle("ElevatorSymphony")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.1.2.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 ElevatorSymphony { [BepInPlugin("com.sk737.elevatorsymphony", "ElevatorSymphony", "1.1.2")] public class Plugin : BaseUnityPlugin { internal const string GUID = "com.sk737.elevatorsymphony"; internal const string NAME = "ElevatorSymphony"; internal const string VERSION = "1.1.2"; private string[] mClipFiles; private Harmony mHarmony = new Harmony("com.sk737.elevatorsymphony"); private int mTotalWeight; internal static ManualLogSource LoggerInstance { get; private set; } internal static Plugin Instance { get; private set; } internal string ExecutingPath => Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location); internal List<AudioClip> Clips { get; set; } = new List<AudioClip>(); internal Random Random { get; set; } public static Config Config { get; private set; } private void Awake() { Instance = this; LoggerInstance = ((BaseUnityPlugin)this).Logger; if (Directory.Exists(ExecutingPath + "/Music")) { List<string> list = new List<string>(); list.AddRange(from f in Directory.GetFiles(ExecutingPath + "/Music") orderby f select f); mClipFiles = list.ToArray(); } Config = new Config(((BaseUnityPlugin)this).Config, mClipFiles); foreach (ConfigEntry<int> songWeight in Config.SongWeights) { mTotalWeight += songWeight.Value; } string[] array = mClipFiles; foreach (string path in array) { LoadClip(path, delegate(AudioClip c) { lock (Clips) { Clips.Add(c); } }); } mHarmony.PatchAll(typeof(RoundManagerPatch)); mHarmony.PatchAll(typeof(StartStartOfRoundPatch)); mHarmony.PatchAll(typeof(Plugin)); ((BaseUnityPlugin)this).Logger.LogInfo((object)"Plugin ElevatorSymphony is loaded!"); } public AudioType GetAudioType(string extension) { return (AudioType)(extension switch { ".mp3" => 13, ".wav" => 20, _ => 14, }); } public async Task LoadClip(string path, Action<AudioClip> callback) { AudioType audioType = GetAudioType(Path.GetExtension(path)); UnityWebRequest request = UnityWebRequestMultimedia.GetAudioClip(path, audioType); try { request.SendWebRequest(); while (!request.isDone) { await Task.Delay(50); } if ((int)request.result != 1) { ((BaseUnityPlugin)this).Logger.LogError((object)("Failed to load file:" + path + ", + " + request.error)); return; } AudioClip content = DownloadHandlerAudioClip.GetContent(request); ((BaseUnityPlugin)this).Logger.LogMessage((object)("Loaded file: " + path)); callback(content); } finally { if (request != null) { request.Dispose(); } } } public void LoadNewAudioFile() { int num = Random.Next(0, mTotalWeight); int num2 = -1; int num3 = 0; for (int i = 0; i < Config.SongWeights.Count; i++) { int num4 = num3; num3 += Config.SongWeights[i].Value; if (num > num4 && num < num3) { num2 = i - 1; break; } } if (num2 >= 0 && mClipFiles.Length != 0) { LoadClip(mClipFiles[num2], SetElevator); } } public void SetElevator(AudioClip clip) { MineshaftElevatorController val = Object.FindObjectOfType<MineshaftElevatorController>(); if ((Object)(object)val != (Object)null) { val.elevatorJingleMusic.clip = clip; } } } public class Config { public static List<ConfigEntry<int>> SongWeights = new List<ConfigEntry<int>>(); public Config(ConfigFile config, string[] clipFiles) { SongWeights.Add(config.Bind<int>("General", "Default chance", 100, "Chance of the base games song being picked by the randomizer. The higher the value the greater the chance it is picked.")); for (int i = 0; i < clipFiles.Length; i++) { string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(clipFiles[i]); SongWeights.Add(config.Bind<int>("General", fileNameWithoutExtension + " chance", 100, "Chance of " + fileNameWithoutExtension + " being picked by the randomizer. The higher the value the greater the chance it is picked.")); } } } public static class PluginInfo { public const string PLUGIN_GUID = "ElevatorSymphony"; public const string PLUGIN_NAME = "ElevatorSymphony"; public const string PLUGIN_VERSION = "1.1.2"; } } namespace ElevatorSymphony.Patches { [HarmonyPatch(typeof(RoundManager))] internal class RoundManagerPatch { [HarmonyPatch("InitializeRandomNumberGenerators")] [HarmonyPrefix] public static void SeedPatch(ref RoundManager __instance) { Plugin.LoggerInstance.LogInfo((object)$"Initializing random with seed {__instance.playersManager.randomMapSeed}"); Plugin.Instance.Random = new Random(__instance.playersManager.randomMapSeed); } } [HarmonyPatch(typeof(StartOfRound))] internal class StartStartOfRoundPatch { [HarmonyPatch("openingDoorsSequence")] [HarmonyPostfix] public static void openingDoorsSequencePatch() { Plugin.Instance.LoadNewAudioFile(); MineshaftElevatorController val = Object.FindObjectOfType<MineshaftElevatorController>(); if ((Object)(object)val != (Object)null) { List<AudioClip> list = new List<AudioClip>(); list.AddRange(val.elevatorHalloweenClips.Concat(Plugin.Instance.Clips)); val.elevatorHalloweenClips = list.ToArray(); List<AudioClip> list2 = new List<AudioClip>(); list2.AddRange(val.elevatorHalloweenClipsLoop.Concat(Plugin.Instance.Clips)); val.elevatorHalloweenClipsLoop = list2.ToArray(); } } } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { public IgnoresAccessChecksToAttribute(string assemblyName) { } } }