Decompiled source of Lethal Plushies v1.0.5

LethalPlushies.dll

Decompiled 2 months ago
using 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)
		{
		}
	}
}