using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Diagnostics;
using System.Diagnostics.CodeAnalysis;
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 HutongGames.PlayMaker;
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: AssemblyCompany("BetterReaper")]
[assembly: AssemblyConfiguration("Release")]
[assembly: AssemblyFileVersion("0.1.1.0")]
[assembly: AssemblyInformationalVersion("0.1.1+180e03c30602f04948a13c924545018deb3cb0fa")]
[assembly: AssemblyProduct("BetterReaper")]
[assembly: AssemblyTitle("BetterReaper")]
[assembly: AssemblyMetadata("RepositoryUrl", "https://github.com/Clazex/Silksong.BetterReaper")]
[assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)]
[assembly: AssemblyVersion("0.1.1.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.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;
}
}
[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 System.Runtime.Versioning
{
[AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface | AttributeTargets.Delegate, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class RequiresPreviewFeaturesAttribute : Attribute
{
public string? Message { get; }
public string? Url { get; set; }
public RequiresPreviewFeaturesAttribute()
{
}
public RequiresPreviewFeaturesAttribute(string? message)
{
Message = message;
}
}
}
namespace System.Runtime.CompilerServices
{
[AttributeUsage(AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class CallerArgumentExpressionAttribute : Attribute
{
public string ParameterName { get; }
public CallerArgumentExpressionAttribute(string parameterName)
{
ParameterName = parameterName;
}
}
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Interface, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class CollectionBuilderAttribute : Attribute
{
public Type BuilderType { get; }
public string MethodName { get; }
public CollectionBuilderAttribute(Type builderType, string methodName)
{
BuilderType = builderType;
MethodName = methodName;
}
}
[AttributeUsage(AttributeTargets.All, AllowMultiple = true, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class CompilerFeatureRequiredAttribute : Attribute
{
public const string RefStructs = "RefStructs";
public const string RequiredMembers = "RequiredMembers";
public string FeatureName { get; }
public bool IsOptional { get; set; }
public CompilerFeatureRequiredAttribute(string featureName)
{
FeatureName = featureName;
}
}
[AttributeUsage(AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class InterpolatedStringHandlerArgumentAttribute : Attribute
{
public string[] Arguments { get; }
public InterpolatedStringHandlerArgumentAttribute(string argument)
{
Arguments = new string[1] { argument };
}
public InterpolatedStringHandlerArgumentAttribute(params string[] arguments)
{
Arguments = arguments;
}
}
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class InterpolatedStringHandlerAttribute : Attribute
{
}
[EditorBrowsable(EditorBrowsableState.Never)]
[ExcludeFromCodeCoverage]
internal static class IsExternalInit
{
}
[AttributeUsage(AttributeTargets.Method, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class ModuleInitializerAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class OverloadResolutionPriorityAttribute : Attribute
{
public int Priority { get; }
public OverloadResolutionPriorityAttribute(int priority)
{
Priority = priority;
}
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = true, AllowMultiple = false)]
[ExcludeFromCodeCoverage]
internal sealed class ParamCollectionAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class RequiredMemberAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
[EditorBrowsable(EditorBrowsableState.Never)]
[ExcludeFromCodeCoverage]
internal sealed class RequiresLocationAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Event | AttributeTargets.Interface, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class SkipLocalsInitAttribute : Attribute
{
}
}
namespace System.Diagnostics.CodeAnalysis
{
[AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class ConstantExpectedAttribute : Attribute
{
public object? Min { get; set; }
public object? Max { get; set; }
}
[AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface | AttributeTargets.Delegate, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class ExperimentalAttribute : Attribute
{
public string DiagnosticId { get; }
public string? UrlFormat { get; set; }
public ExperimentalAttribute(string diagnosticId)
{
DiagnosticId = diagnosticId;
}
}
[AttributeUsage(AttributeTargets.Method | AttributeTargets.Property, Inherited = false, AllowMultiple = true)]
[ExcludeFromCodeCoverage]
internal sealed class MemberNotNullAttribute : Attribute
{
public string[] Members { get; }
public MemberNotNullAttribute(string member)
{
Members = new string[1] { member };
}
public MemberNotNullAttribute(params string[] members)
{
Members = members;
}
}
[AttributeUsage(AttributeTargets.Method | AttributeTargets.Property, Inherited = false, AllowMultiple = true)]
[ExcludeFromCodeCoverage]
internal sealed class MemberNotNullWhenAttribute : Attribute
{
public bool ReturnValue { get; }
public string[] Members { get; }
public MemberNotNullWhenAttribute(bool returnValue, string member)
{
ReturnValue = returnValue;
Members = new string[1] { member };
}
public MemberNotNullWhenAttribute(bool returnValue, params string[] members)
{
ReturnValue = returnValue;
Members = members;
}
}
[AttributeUsage(AttributeTargets.Constructor, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class SetsRequiredMembersAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class StringSyntaxAttribute : Attribute
{
public const string CompositeFormat = "CompositeFormat";
public const string DateOnlyFormat = "DateOnlyFormat";
public const string DateTimeFormat = "DateTimeFormat";
public const string EnumFormat = "EnumFormat";
public const string GuidFormat = "GuidFormat";
public const string Json = "Json";
public const string NumericFormat = "NumericFormat";
public const string Regex = "Regex";
public const string TimeOnlyFormat = "TimeOnlyFormat";
public const string TimeSpanFormat = "TimeSpanFormat";
public const string Uri = "Uri";
public const string Xml = "Xml";
public string Syntax { get; }
public object?[] Arguments { get; }
public StringSyntaxAttribute(string syntax)
{
Syntax = syntax;
Arguments = new object[0];
}
public StringSyntaxAttribute(string syntax, params object?[] arguments)
{
Syntax = syntax;
Arguments = arguments;
}
}
[AttributeUsage(AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class UnscopedRefAttribute : Attribute
{
}
}
namespace BepInEx
{
[AttributeUsage(AttributeTargets.Class, Inherited = false, AllowMultiple = false)]
[Conditional("CodeGeneration")]
internal sealed class BepInAutoPluginAttribute : Attribute
{
public BepInAutoPluginAttribute(string? id = null, string? name = null, string? version = null)
{
}
}
}
namespace BepInEx.Preloader.Core.Patching
{
[AttributeUsage(AttributeTargets.Class, Inherited = false, AllowMultiple = false)]
[Conditional("CodeGeneration")]
internal sealed class PatcherAutoPluginAttribute : Attribute
{
public PatcherAutoPluginAttribute(string? id = null, string? name = null, string? version = null)
{
}
}
}
namespace BetterReaper
{
[BepInPlugin("dev.clazex.betterreaper", "BetterReaper", "0.1.1")]
public sealed class BetterReaperPlugin : BaseUnityPlugin
{
public const string Id = "dev.clazex.betterreaper";
public static BetterReaperPlugin Instance { get; private set; } = null;
internal static ManualLogSource Logger { get; private set; } = null;
private static Harmony Harmony { get; } = new Harmony("dev.clazex.betterreaper");
public static string Name => "BetterReaper";
public static string Version => "0.1.1";
private void Awake()
{
Instance = this;
Logger = ((BaseUnityPlugin)this).Logger;
Harmony.PatchAll(typeof(Patches));
Logger.LogInfo((object)("Plugin " + Name + " (dev.clazex.betterreaper) v" + Version + " is loaded!"));
}
private void OnDestroy()
{
Logger.LogWarning((object)"Unload called in release build");
Harmony.UnpatchSelf();
Logger.LogInfo((object)("Plugin " + Name + " has unloaded!"));
}
internal static void ReaperReward(HeroController hc)
{
Logger.LogDebug((object)"Giving reaper mode finishing reward");
if (hc.playerData.health < hc.playerData.CurrentMaxHealth)
{
hc.AddHealth(1);
}
else
{
hc.AddSilk(3, true);
}
}
}
internal static class Constants
{
public const float STUN_DAMAGE_MULT = 1.5f;
public const float STUN_DAMAGE_MULT_HEAVY = 1.75f;
public const int SILK_PER_HEALTH = 3;
public const float GREAT_SLASH_SCALE = 1.45f;
public const float BUNDLE_PROB_1 = 0.25f;
public const float BUNDLE_PROB_2 = 0.5f;
public const float BUNDLE_PROB_3 = 0.25f;
public const float FLING_SPEED_MIN = 18.75f;
public const float FLING_SPEED_MAX = 37.5f;
}
internal sealed class ListenForBindComplete : FsmStateAction
{
private static readonly HashSet<ListenForBindComplete> instances = new HashSet<ListenForBindComplete>();
internal FsmEvent fsmEvent;
public ListenForBindComplete(FsmEvent fsmEvent)
{
this.fsmEvent = fsmEvent;
((FsmStateAction)this)..ctor();
}
public override void OnEnter()
{
((FsmStateAction)this).BlocksFinish = false;
instances.Add(this);
}
public override void OnExit()
{
instances.Remove(this);
}
private void OnNotify()
{
((FsmStateAction)this).Fsm.Event(fsmEvent);
((FsmStateAction)this).Finish();
}
internal static void NotifyAll()
{
BetterReaperPlugin.Logger.LogDebug((object)"Notifying bind complete");
ListenForBindComplete[] array = instances.ToArray();
for (int i = 0; i < array.Length; i++)
{
array[i].OnNotify();
}
}
}
internal static class Patches
{
[HarmonyPatch(typeof(HeroController), "Start")]
[HarmonyWrapSafe]
[HarmonyPostfix]
private static void Setup(HeroController __instance)
{
//IL_0151: Unknown result type (might be due to invalid IL or missing references)
//IL_015b: Unknown result type (might be due to invalid IL or missing references)
BetterReaperPlugin.Logger.LogDebug((object)"Setting up hero");
HeroControllerConfig config = ToolItemManager.GetCrestByName("Reaper").HeroConfig;
ConfigGroup val = __instance.configs.First((ConfigGroup i) => (Object)(object)i.Config == (Object)(object)config);
DamageEnemies normalSlashDamager = val.NormalSlashDamager;
normalSlashDamager.stunDamage *= 1.5f;
DamageEnemies alternateSlashDamager = val.AlternateSlashDamager;
alternateSlashDamager.stunDamage *= 1.5f;
DamageEnemies upSlashDamager = val.UpSlashDamager;
upSlashDamager.stunDamage *= 1.5f;
DamageEnemies wallSlashDamager = val.WallSlashDamager;
wallSlashDamager.stunDamage *= 1.5f;
Transform obj = __instance.transform.Find("Attacks/Scythe");
((Component)obj.Find("DownSlash New")).GetComponent<DamageEnemies>();
DamageEnemies wallSlashDamager2 = val.WallSlashDamager;
wallSlashDamager2.stunDamage *= 1.75f;
((Component)obj.Find("DashUpper Slash")).GetComponent<DamageEnemies>();
DamageEnemies component = ((Component)obj.Find("DashUpper Slash/Extra Damager")).GetComponent<DamageEnemies>();
component.stunDamage *= 1.75f;
EnemyDamagerGroup component2 = ((Component)__instance.transform.Find("Attacks/Charge Slash Scythe")).GetComponent<EnemyDamagerGroup>();
DamageEnemies[] damagers = component2.damagers;
foreach (DamageEnemies obj2 in damagers)
{
obj2.stunDamage *= 1.75f;
}
Extensions.SetScale2D(((Component)component2).transform, Vector2.one * 1.45f);
ProbabilityInt[] reaperBundleDrops = __instance.reaperBundleDrops;
((ProbabilityBase<int>)(object)reaperBundleDrops[0]).Probability = 0.25f;
((ProbabilityBase<int>)(object)reaperBundleDrops[1]).Probability = 0.5f;
((ProbabilityBase<int>)(object)reaperBundleDrops[2]).Probability = 0.25f;
}
[HarmonyPatch(typeof(ObjectPool), "AddSpawnedObject")]
[HarmonyWrapSafe]
[HarmonyPostfix]
private static void AutoCollectSilkOrbs(GameObject obj, GameObject prefab)
{
if (!(((Object)prefab).name != "Reaper Silk Bundle") && !((Object)(object)obj.GetComponent<SilkOrbEditMarker>() != (Object)null))
{
BetterReaperPlugin.Logger.LogDebug((object)"Modifying Reaper Silk Bundle");
obj.AddComponent<SilkOrbEditMarker>();
Fsm fsm = FSMUtility.LocateMyFSM(obj, "Control").Fsm;
fsm.GetState("Get Silk").Actions[2].Enabled = false;
FsmState state = fsm.GetState("Collectable");
FsmTransition obj2 = state.Transitions.First((FsmTransition i) => i.EventName == "DISAPPEAR");
obj2.ToFsmState = fsm.GetState("Collect");
obj2.toState = obj2.toFsmState.Name;
FsmStateAction[] actions = state.Actions;
int num = 0;
FsmStateAction[] array = (FsmStateAction[])(object)new FsmStateAction[1 + actions.Length];
ReadOnlySpan<FsmStateAction> readOnlySpan = new ReadOnlySpan<FsmStateAction>(actions);
readOnlySpan.CopyTo(new Span<FsmStateAction>(array).Slice(num, readOnlySpan.Length));
num += readOnlySpan.Length;
array[num] = (FsmStateAction)(object)new ListenForBindComplete(FsmEvent.GetFsmEvent("REAP"));
state.Actions = array;
}
}
[HarmonyPatch(typeof(HeroController), "ResetReaperCrestState")]
[HarmonyWrapSafe]
[HarmonyPrefix]
private static void ReaperExitAward(HeroController __instance)
{
//IL_0001: Unknown result type (might be due to invalid IL or missing references)
//IL_0006: Unknown result type (might be due to invalid IL or missing references)
//IL_0007: Unknown result type (might be due to invalid IL or missing references)
//IL_000f: Unknown result type (might be due to invalid IL or missing references)
ReaperCrestStateInfo reaperState = __instance.reaperState;
if (reaperState.IsInReaperMode && reaperState.ReaperModeDurationLeft <= 0f)
{
BetterReaperPlugin.ReaperReward(__instance);
}
}
[HarmonyPatch(typeof(HeroController), "BindCompleted")]
[HarmonyWrapSafe]
[HarmonyPrefix]
private static void ReaperRestartAward(HeroController __instance)
{
ListenForBindComplete.NotifyAll();
if (__instance.reaperState.IsInReaperMode)
{
BetterReaperPlugin.ReaperReward(__instance);
}
}
[HarmonyPatch(typeof(HealthManager), "TakeDamage")]
[HarmonyWrapSafe]
[HarmonyTranspiler]
private static IEnumerable<CodeInstruction> ChangeFlingSpeed(IEnumerable<CodeInstruction> insts)
{
//IL_0002: Unknown result type (might be due to invalid IL or missing references)
//IL_0025: Unknown result type (might be due to invalid IL or missing references)
//IL_002b: Expected O, but got Unknown
//IL_0042: Unknown result type (might be due to invalid IL or missing references)
//IL_0048: Expected O, but got Unknown
//IL_007a: Unknown result type (might be due to invalid IL or missing references)
//IL_0080: Expected O, but got Unknown
//IL_0097: Unknown result type (might be due to invalid IL or missing references)
//IL_009d: Expected O, but got Unknown
return new CodeMatcher(insts, (ILGenerator)null).MatchForward(false, (CodeMatch[])(object)new CodeMatch[2]
{
new CodeMatch((OpCode?)OpCodes.Ldc_R4, (object)25f, (string)null),
new CodeMatch((OpCode?)OpCodes.Stfld, (object)FieldInfo.GetFieldFromHandle((RuntimeFieldHandle)/*OpCode not supported: LdMemberToken*/), (string)null)
}).SetOperandAndAdvance((object)18.75f).MatchForward(false, (CodeMatch[])(object)new CodeMatch[2]
{
new CodeMatch((OpCode?)OpCodes.Ldc_R4, (object)50f, (string)null),
new CodeMatch((OpCode?)OpCodes.Stfld, (object)FieldInfo.GetFieldFromHandle((RuntimeFieldHandle)/*OpCode not supported: LdMemberToken*/), (string)null)
})
.SetOperandAndAdvance((object)37.5f)
.InstructionEnumeration();
}
[HarmonyPatch(typeof(HeroController), "TakeDamage")]
[HarmonyWrapSafe]
[HarmonyTranspiler]
private static IEnumerable<CodeInstruction> RemoveReaperReset(IEnumerable<CodeInstruction> insts, ILGenerator generator)
{
//IL_0002: Unknown result type (might be due to invalid IL or missing references)
//IL_001c: Unknown result type (might be due to invalid IL or missing references)
//IL_0022: Expected O, but got Unknown
//IL_003e: Unknown result type (might be due to invalid IL or missing references)
//IL_0044: Expected O, but got Unknown
return new CodeMatcher(insts, generator).MatchForward(false, (CodeMatch[])(object)new CodeMatch[2]
{
new CodeMatch((OpCode?)OpCodes.Ldarg_0, (object)null, (string)null),
new CodeMatch((OpCode?)OpCodes.Call, (object)(MethodInfo)MethodBase.GetMethodFromHandle((RuntimeMethodHandle)/*OpCode not supported: LdMemberToken*/), (string)null)
}).RemoveInstructions(2).InstructionEnumeration();
}
[HarmonyPatch(typeof(PlayerData), "TakeHealth")]
[HarmonyWrapSafe]
[HarmonyPrefix]
private static void ResetReaperOnActualDamage(PlayerData __instance, ref int amount)
{
//IL_0007: Unknown result type (might be due to invalid IL or missing references)
HeroController instance = HeroController.instance;
if (instance.ReaperState.IsInReaperMode)
{
int num = Math.Min(__instance.silk / 3, amount);
instance.TakeSilk(num * 3);
amount -= num;
BetterReaperPlugin.Logger.LogDebug((object)$"Reaper mode reducing damage by {num} to {amount}");
if (amount > 0)
{
BetterReaperPlugin.Logger.LogDebug((object)"Resetting reaper mode");
instance.ResetReaperCrestState();
}
else
{
BetterReaperPlugin.Logger.LogDebug((object)"Exempted reaper mode reset");
}
}
}
}
internal sealed class SilkOrbEditMarker : MonoBehaviour
{
}
}
internal class BetterReaper_ProcessedByFody
{
internal const string FodyVersion = "6.9.3.0";
internal const string InfoOf = "2.2.0.0";
}