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 Lethal Plushies v1.0.5
LethalPlushies.dll
Decompiled a year agousing System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using BepInEx; using BepInEx.Logging; using HarmonyLib; using Microsoft.CodeAnalysis; using Photon.Pun; using REPOLib.Modules; 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(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: AssemblyCompany("LethalPlushies")] [assembly: AssemblyConfiguration("Debug")] [assembly: AssemblyCopyright("Copyright © 2025 Spoopylocal")] [assembly: AssemblyFileVersion("1.0.5.0")] [assembly: AssemblyInformationalVersion("1.0.5")] [assembly: AssemblyProduct("LethalPlushies")] [assembly: AssemblyTitle("LethalPlushies")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.5.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; } } } [RequireComponent(typeof(PhysGrabObject), typeof(PhotonView))] public class CarryScare : MonoBehaviourPun { public float carryThreshold = 10f; public Vector2 playInterval = new Vector2(5f, 15f); public Sound[] scarySounds; private PhysGrabObject physGrab; private float carryTimer; private float nextPlayTime = float.PositiveInfinity; private void Start() { physGrab = ((Component)this).GetComponent<PhysGrabObject>(); ResetTimers(); } private void Update() { if (physGrab.grabbed) { carryTimer += Time.deltaTime; if (carryTimer >= carryThreshold) { if (nextPlayTime == float.PositiveInfinity) { ScheduleNextSound(); } if (Time.time >= nextPlayTime) { PlayRandomScarySound(); ScheduleNextSound(); } } } else { ResetTimers(); } } private void PlayRandomScarySound() { if (scarySounds.Length != 0) { int num = Random.Range(0, scarySounds.Length); Debug.Log((object)$"[CarryScare] Triggering scary sound index={num}"); if (PhotonNetwork.IsConnected && PhotonNetwork.IsMasterClient) { ((MonoBehaviourPun)this).photonView.RPC("RPC_PlaySound", (RpcTarget)0, new object[1] { num }); } else { RPC_PlaySound(num); } } } private void ScheduleNextSound() { nextPlayTime = Time.time + Random.Range(playInterval.x, playInterval.y); } private void ResetTimers() { carryTimer = 0f; nextPlayTime = float.PositiveInfinity; } [PunRPC] private void RPC_PlaySound(int index) { //IL_0058: Unknown result type (might be due to invalid IL or missing references) Debug.Log((object)$"[CarryScare] RPC_PlaySound received index={index}"); if (index >= 0 && index < scarySounds.Length) { Sound val = scarySounds[index]; if (val == null) { Debug.LogWarning((object)"[CarryScare] Sound at index is null!"); return; } val.Play(((Component)this).transform.position, 1f, 1f, 1f, 1f); Debug.Log((object)"[CarryScare] Sound played!"); } } } namespace LethalPlushies { [BepInPlugin("LethalPlushies", "LethalPlushies", "1.0.5")] [BepInDependency(/*Could not decode attribute arguments.*/)] public class Plugin : BaseUnityPlugin { private readonly Harmony _harmony = new Harmony("LethalPlushies"); internal static Plugin Instance { get; private set; } internal static ManualLogSource Logger { get; private set; } private void Awake() { //IL_002d: Unknown result type (might be due to invalid IL or missing references) //IL_0033: Expected O, but got Unknown Instance = this; Logger = Logger.CreateLogSource("LethalPlushies"); Logger.LogInfo((object)"LethalPlushies has awoken!"); Harmony val = new Harmony("LethalPlushies"); val.PatchAll(); string directoryName = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location); string text = Path.Combine(directoryName, "lethalplushieassets"); AssetBundle val2 = AssetBundle.LoadFromFile(text); GameObject val3 = val2.LoadAsset<GameObject>("Valuable Hoarding Bug"); GameObject val4 = val2.LoadAsset<GameObject>("Valuable Ghost Girl"); GameObject val5 = val2.LoadAsset<GameObject>("Valuable Baboon Hawk"); List<string> list = new List<string> { "Valuables - Generic" }; Valuables.RegisterValuable(val3, list); Valuables.RegisterValuable(val4, list); Valuables.RegisterValuable(val5, list); } } public static class MyPluginInfo { public const string PLUGIN_GUID = "LethalPlushies"; public const string PLUGIN_NAME = "LethalPlushies"; public const string PLUGIN_VERSION = "1.0.5"; } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { public IgnoresAccessChecksToAttribute(string assemblyName) { } } }