using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Reflection; using System.Reflection.Emit; 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 NoRevivePenalty.Patches; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: TargetFramework(".NETStandard,Version=v2.1", FrameworkDisplayName = ".NET Standard 2.1")] [assembly: AssemblyCompany("NoRevivePenalty")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0")] [assembly: AssemblyProduct("NoRevivePenalty")] [assembly: AssemblyTitle("NoRevivePenalty")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [module: UnverifiableCode] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } } namespace NoRevivePenalty { [BepInPlugin("Int.NoRevivePenalty", "No Revive Penalty", "1.0.0")] public class NoRevivePenalty : BaseUnityPlugin { public const string GUID = "Int.NoRevivePenalty"; public const string NAME = "No Revive Penalty"; public const string VERSION = "1.0.0"; internal static ManualLogSource Logger { get; private set; } internal static Harmony? Harmony { get; set; } public static NoRevivePenalty Instance { get; private set; } private void Awake() { Logger = ((BaseUnityPlugin)this).Logger; Instance = this; Patch(); Logger.LogInfo((object)"Int.NoRevivePenalty v1.0.0 has loaded!"); } internal static void Patch() { //IL_000c: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Expected O, but got Unknown if (Harmony == null) { Harmony = new Harmony("Int.NoRevivePenalty"); } Logger.LogDebug((object)"Patching..."); Harmony.PatchAll(typeof(RespawnChestPatches)); Logger.LogDebug((object)"Finished patching!"); } } } namespace NoRevivePenalty.Patches { public static class RespawnChestPatches { [HarmonyPatch(typeof(RespawnChest), "RespawnAllPlayersHere")] [HarmonyTranspiler] public static IEnumerable RespawnAllPlayersHereTranspiler(IEnumerable instructions) { List list = new List(instructions); for (int i = 0; i < list.Count; i++) { if (i > 0 && list[i].opcode == OpCodes.Ldc_I4_1 && list[i - 1].opcode == OpCodes.Ldc_I4_1 && list[i + 1].opcode == OpCodes.Box && list[i + 1].operand.ToString().Contains("Boolean")) { list[i].opcode = OpCodes.Ldc_I4_0; break; } } return list.AsEnumerable(); } } }