Decompiled source of RngFix v2.3.0
RngFix.dll
Decompiled 2 months ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System.IO; 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 System.Text; using System.Threading; using AddWatermark; using BepInEx; using BepInEx.Bootstrap; using BepInEx.Configuration; using BepInEx.Logging; using Cysharp.Threading.Tasks; using HarmonyLib; using LBoL.Base; using LBoL.Base.Extensions; using LBoL.ConfigData; using LBoL.Core; using LBoL.Core.Adventures; using LBoL.Core.Battle; using LBoL.Core.Battle.BattleActions; using LBoL.Core.Cards; using LBoL.Core.Randoms; using LBoL.Core.Stations; using LBoL.Core.Units; using LBoL.EntityLib.Adventures; using LBoL.EntityLib.Adventures.FirstPlace; using LBoL.EntityLib.Adventures.Stage2; using LBoL.EntityLib.Adventures.Stage3; using LBoL.EntityLib.Cards.Character.Cirno; using LBoL.EntityLib.Cards.Character.Marisa; using LBoL.EntityLib.Cards.Character.Reimu; using LBoL.EntityLib.Cards.Enemy; using LBoL.EntityLib.Cards.Neutral.Black; using LBoL.EntityLib.Cards.Neutral.MultiColor; using LBoL.EntityLib.Cards.Neutral.NoColor; using LBoL.EntityLib.Cards.Neutral.TwoColor; using LBoL.EntityLib.Cards.Others; using LBoL.EntityLib.EnemyUnits.Character; using LBoL.EntityLib.EnemyUnits.Normal; using LBoL.EntityLib.EnemyUnits.Normal.Bats; using LBoL.EntityLib.EnemyUnits.Normal.Guihuos; using LBoL.EntityLib.EnemyUnits.Normal.Maoyus; using LBoL.EntityLib.EnemyUnits.Normal.Ravens; using LBoL.EntityLib.EnemyUnits.Normal.Yinyangyus; using LBoL.EntityLib.EnemyUnits.Opponent; using LBoL.EntityLib.Exhibits; using LBoL.EntityLib.Exhibits.Adventure; using LBoL.EntityLib.Exhibits.Common; using LBoL.EntityLib.Exhibits.Shining; using LBoL.EntityLib.JadeBoxes; using LBoL.EntityLib.Stages.NormalStages; using LBoL.EntityLib.StatusEffects.Cirno; using LBoL.EntityLib.StatusEffects.Enemy; using LBoL.EntityLib.StatusEffects.Enemy.Seija; using LBoL.EntityLib.StatusEffects.Marisa; using LBoL.EntityLib.StatusEffects.Neutral.TwoColor; using LBoL.EntityLib.StatusEffects.Neutral.White; using LBoL.EntityLib.StatusEffects.Sakuya; using LBoL.Presentation; using LBoL.Presentation.UI; using LBoL.Presentation.UI.Panels; using LBoLEntitySideloader; using LBoLEntitySideloader.CustomHandlers; using LBoLEntitySideloader.Entities; using LBoLEntitySideloader.PersistentValues; using LBoLEntitySideloader.PersistentValues.TypeConverters; using LBoLEntitySideloader.ReflectionHelpers; using LBoLEntitySideloader.Resource; using Logging; using RngFix.CustomRngs; using RngFix.CustomRngs.Sampling; using RngFix.CustomRngs.Sampling.Pads; using RngFix.CustomRngs.Sampling.UniformPools; using RngFix.Patches; using RngFix.Patches.Battle; using RngFix.Patches.Debug; using UnityEngine; using YamlDotNet.Serialization; [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: IgnoresAccessChecksTo("LBoL.Base")] [assembly: IgnoresAccessChecksTo("LBoL.ConfigData")] [assembly: IgnoresAccessChecksTo("LBoL.Core")] [assembly: IgnoresAccessChecksTo("LBoL.EntityLib")] [assembly: IgnoresAccessChecksTo("LBoL.Presentation")] [assembly: IgnoresAccessChecksTo("Untitled.ConfigDataBuilder.Base")] [assembly: AssemblyCompany("RngFix")] [assembly: AssemblyConfiguration("Debug")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0")] [assembly: AssemblyProduct("RngFix")] [assembly: AssemblyTitle("RngFix")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [module: UnverifiableCode] namespace RngFix { [BepInPlugin("neo.lbol.fix.rngFix", "RngFix", "2.3.0")] [BepInDependency(/*Could not decode attribute arguments.*/)] [BepInDependency(/*Could not decode attribute arguments.*/)] [BepInProcess("LBoL.exe")] public class BepinexPlugin : BaseUnityPlugin { private class GrRestore_Patch { private static void Postfix(GameRunController __result) { log.LogDebug((object)"restoredeez"); __result.CardValidDebugLevel = 0; } } private static readonly Harmony harmony = PInfo.harmony; internal static ManualLogSource log; internal static TemplateSequenceTable sequenceTable = new TemplateSequenceTable(0); internal static IResourceSource embeddedSource = (IResourceSource)new EmbeddedSource(Assembly.GetExecutingAssembly()); internal static DirectorySource directorySource = new DirectorySource("neo.lbol.fix.rngFix", ""); public static ConfigEntry<bool> ignoreFactorsTableConf; public static ConfigEntry<bool> doLoggingConf; private KeyboardShortcut debgugBind = new KeyboardShortcut((KeyCode)121, (KeyCode[])(object)new KeyCode[1] { (KeyCode)304 }); private void Awake() { log = ((BaseUnityPlugin)this).Logger; Object.DontDestroyOnLoad((Object)(object)((Component)this).gameObject); ((Object)((Component)this).gameObject).hideFlags = (HideFlags)61; ignoreFactorsTableConf = ((BaseUnityPlugin)this).Config.Bind<bool>("Rng", "IgnoreFactorsTable", true, "Disables the mechanic where card chance of appearing as a card reward is decreased if an offered card is not picked. Setting this to true greatly increases card reward consistency."); doLoggingConf = ((BaseUnityPlugin)this).Config.Bind<bool>("Stats", "DoLogging", false, "Log various run stats (card, exhibits etc.) to <gameSaveDir>/RngFix"); EntityManager.AddPostLoadAction((Action)delegate { Padding.ResetPadCache(); }, (Assembly)null); EntityManager.RegisterSelf(); harmony.PatchAll(); if (Chainloader.PluginInfos.ContainsKey("neo.lbol.tools.watermark")) { WatermarkWrapper.ActivateWatermark(); } ((CustomGameRunSaveData)new RngSaveContainer()).RegisterSelf("neo.lbol.fix.rngFix"); PickCardLog.RegisterOnCardsAdded(); } private void OnDestroy() { if (harmony != null) { harmony.UnpatchSelf(); } } private void Update() { bool flag = false; } } public static class PInfo { public const string GUID = "neo.lbol.fix.rngFix"; public const string Name = "RngFix"; public const string version = "2.3.0"; public static readonly Harmony harmony = new Harmony("neo.lbol.fix.rngFix"); } internal class WatermarkWrapper { [MethodImpl(MethodImplOptions.NoInlining)] internal static void ActivateWatermark() { API.ActivateWatermark(); } } } namespace RngFix.Patches { [HarmonyPatch(typeof(GameRunController), "BaseCardWeight")] internal class KillCardFactors_Patch { private static bool IgnoreFactorTable() { return !BepinexPlugin.ignoreFactorsTableConf.Value; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Expected O, but got Unknown //IL_004f: Unknown result type (might be due to invalid IL or missing references) //IL_0055: Expected O, but got Unknown //IL_0068: Unknown result type (might be due to invalid IL or missing references) //IL_006e: Expected O, but got Unknown //IL_0096: Unknown result type (might be due to invalid IL or missing references) //IL_009c: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ldfld, (object)AccessTools.Field(typeof(GameRunController), "_cardRewardWeightFactors"))) }).MatchForward(false, (CodeMatch[])(object)new CodeMatch[1] { new CodeMatch((OpCode?)OpCodes.Brfalse, (object)null, (string)null) }).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Pop, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(KillCardFactors_Patch), "IgnoreFactorTable", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch(typeof(GameRunController), "GetShopCards")] internal class GetShopCards_Patch { private static int IgnoreFactorTable() { return (!BepinexPlugin.ignoreFactorsTableConf.Value) ? 1 : 0; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_007a: Unknown result type (might be due to invalid IL or missing references) //IL_0084: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).SearchForward((Func<CodeInstruction, bool>)((CodeInstruction ci) => ci.operand is MethodBase methodBase && methodBase.Name == "RollCards")).MatchBack(false, (CodeMatch[])(object)new CodeMatch[3] { CodeMatch.op_Implicit(OpCodes.Ldc_I4_1), CodeMatch.op_Implicit(OpCodes.Ldc_I4_0), CodeMatch.op_Implicit(OpCodes.Ldc_I4_0) }).SetInstruction(new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(GetShopCards_Patch), "IgnoreFactorTable", (Type[])null, (Type[])null))) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] public class ShopFactor_Patch { public static ConditionalWeakTable<CardWeightTable, string> wt_cwt = new ConditionalWeakTable<CardWeightTable, string>(); public const float constRareFactor = 0.93f; private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Method(typeof(Stage), "GetShopNormalCards", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(Stage), "SupplyShopCard", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(Stage), "GetShopToolCards", (Type[])null, (Type[])null); } private static CardWeightTable ModCardWTable(CardWeightTable cwt, string cwtName) { //IL_0037: Unknown result type (might be due to invalid IL or missing references) //IL_0053: Expected O, but got Unknown //IL_004e: Unknown result type (might be due to invalid IL or missing references) //IL_0054: Expected O, but got Unknown CardWeightTable val = cwt; if (BepinexPlugin.ignoreFactorsTableConf.Value) { RarityWeightTable rarityTable = cwt.RarityTable; val = new CardWeightTable(new RarityWeightTable(rarityTable.Common, rarityTable.Uncommon, rarityTable.Rare * 0.93f, rarityTable.Mythic), cwt.OwnerTable, cwt.CardTypeTable, cwt.IncludeOutsideKeyword); } wt_cwt.AddOrUpdate(val, cwtName); return val; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions, ILGenerator generator) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0070: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Expected O, but got Unknown //IL_009e: Unknown result type (might be due to invalid IL or missing references) //IL_00a4: Expected O, but got Unknown CodeMatcher val = new CodeMatcher(instructions, (ILGenerator)null).Start(); while (val.IsValid) { val = val.SearchForward((Func<CodeInstruction, bool>)((CodeInstruction ci) => (ci.opcode == OpCodes.Call || ci.opcode == OpCodes.Callvirt) && ci.operand is MethodBase methodBase && methodBase.Name.StartsWith("get_Shop") && methodBase.Name.EndsWith("Weight"))); if (val.IsValid) { string name = (val.Instruction.operand as MethodBase).Name; val = val.Advance(1).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldstr, (object)name) }).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(ShopFactor_Patch), "ModCardWTable", (Type[])null, (Type[])null)) }); } } return val.LeaveJumpFix().InstructionEnumeration(); } } public static class GenerateTools { public static Card[] GetTools(Stage stage, int count, RandomGen rng) { //IL_0012: Unknown result type (might be due to invalid IL or missing references) GameRunController gameRun = ((GameEntity)stage).GameRun; Card[] array = gameRun.RollCards(rng, stage.ShopToolCardWeight, count, (ManaGroup?)gameRun.BaseMana, gameRun.RewardAndShopCardColorLimitFlag == 0, false, false, false, (Predicate<CardConfig>)null); Card[] array2 = array; foreach (Card val in array2) { gameRun.UpgradeNewDeckCardOnFlags(val); } return array; } } [HarmonyPatch(typeof(RingoEmp), "InitVariables")] internal class RingoEmp_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Expected O, but got Unknown //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_0082: Expected O, but got Unknown //IL_00aa: Unknown result type (might be due to invalid IL or missing references) //IL_00b0: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.Method(typeof(Stage), "GetShopToolCards", (Type[])null, (Type[])null))) }).Set(OpCodes.Call, (object)AccessTools.Method(typeof(GenerateTools), "GetTools", (Type[])null, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.PropertyGetter(typeof(GameRunController), "AdventureRng")) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(GrRngs), "Gr", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class FixBook_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return ExtraAccess.InnerMoveNext(typeof(FixBook), "SpecialGain"); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Expected O, but got Unknown //IL_009d: Unknown result type (might be due to invalid IL or missing references) //IL_00a3: Expected O, but got Unknown //IL_00b6: Unknown result type (might be due to invalid IL or missing references) //IL_00bc: Expected O, but got Unknown //IL_00e4: Unknown result type (might be due to invalid IL or missing references) //IL_00ea: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.Method(typeof(Stage), "GetShopToolCards", (Type[])null, (Type[])null))) }).Set(OpCodes.Call, (object)AccessTools.Method(typeof(GenerateTools), "GetTools", (Type[])null, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(ExhibitsSelfRngs), "GetSelfRng", new Type[2] { typeof(GameRunController), typeof(Exhibit) }, (Type[])null)) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc_1, (object)null) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(GrRngs), "Gr", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class Gongjuxiang_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Method(typeof(Gongjuxiang), "<OnAdded>b__0_0", (Type[])null, (Type[])null); } private static string ExId() { return "Gongjuxiang"; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Expected O, but got Unknown //IL_009d: Unknown result type (might be due to invalid IL or missing references) //IL_00a3: Expected O, but got Unknown //IL_00cb: Unknown result type (might be due to invalid IL or missing references) //IL_00d1: Expected O, but got Unknown //IL_00f9: Unknown result type (might be due to invalid IL or missing references) //IL_00ff: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.Method(typeof(Stage), "GetShopToolCards", (Type[])null, (Type[])null))) }).Set(OpCodes.Call, (object)AccessTools.Method(typeof(GenerateTools), "GetTools", (Type[])null, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(ExhibitsSelfRngs), "GetSelfRng", new Type[2] { typeof(GameRunController), typeof(string) }, (Type[])null)) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Gongjuxiang_Patch), "ExId", (Type[])null, (Type[])null)) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(GrRngs), "Gr", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } public static class Helpers { public static CodeMatcher LeaveJumpFix(this CodeMatcher matcher) { //IL_0046: Unknown result type (might be due to invalid IL or missing references) //IL_004c: Expected O, but got Unknown matcher.Start(); while (matcher.IsValid) { matcher.MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(OpCodes.Leave) }).Advance(1); if (matcher.IsInvalid) { break; } matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Nop, (object)null) }); } return matcher; } public static CodeMatcher ReplaceRngGetter(this CodeMatcher matcher, string targetName, MethodInfo newCall, MethodInfo targetMethod = null) { //IL_006c: Unknown result type (might be due to invalid IL or missing references) //IL_0072: Expected O, but got Unknown if (targetMethod == null) { targetMethod = AccessTools.PropertyGetter(typeof(GameRunController), targetName); } if (targetMethod == null) { throw new ArgumentException(string.Format("Could not find {0}.{1}", "GameRunController", targetMethod)); } CodeMatch val = new CodeMatch((Func<CodeInstruction, bool>)((CodeInstruction ci) => ci.operand as MethodInfo == targetMethod), (string)null); return matcher.MatchForward(false, (CodeMatch[])(object)new CodeMatch[1] { val }).ThrowIfNotMatch(targetName + " getter not matched.", (CodeMatch[])(object)new CodeMatch[1] { val }).Set(OpCodes.Call, (object)newCall); } private static int RngGuardSingle(IEnumerable<EnemyUnit> alives) { return (alives.Count() <= 1) ? 1 : 0; } private static int RngGuardMany(IEnumerable<EnemyUnit> alives, int amount) { int num = alives.Count(); return (amount >= num || amount <= 0) ? 1 : 0; } private static RandomGen FakeRng() { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Expected O, but got Unknown return new RandomGen(); } public static CodeMatcher RngAdvancementGuard(this CodeMatcher matcher, ILGenerator generator, CodeMatch searchBackMatch = null, bool many = false, CodeMatch[] amountMatch = null, bool searchForAmountMatchFirst = false) { //IL_00d4: Unknown result type (might be due to invalid IL or missing references) //IL_00da: Expected O, but got Unknown //IL_012c: Unknown result type (might be due to invalid IL or missing references) //IL_0144: Expected O, but got Unknown //IL_00fa: Unknown result type (might be due to invalid IL or missing references) //IL_0100: Expected O, but got Unknown //IL_0097: Unknown result type (might be due to invalid IL or missing references) //IL_009e: Expected O, but got Unknown //IL_01c3: Unknown result type (might be due to invalid IL or missing references) //IL_01c9: Expected O, but got Unknown //IL_0299: Unknown result type (might be due to invalid IL or missing references) //IL_029f: Expected O, but got Unknown //IL_02b9: Unknown result type (might be due to invalid IL or missing references) //IL_02bf: Expected O, but got Unknown //IL_0266: Unknown result type (might be due to invalid IL or missing references) //IL_026c: Expected O, but got Unknown //IL_0374: Unknown result type (might be due to invalid IL or missing references) //IL_037a: Expected O, but got Unknown //IL_03a9: Unknown result type (might be due to invalid IL or missing references) //IL_03af: Expected O, but got Unknown //IL_0485: Unknown result type (might be due to invalid IL or missing references) //IL_048b: Expected O, but got Unknown string text = matcher.Instruction.operand?.ToString() ?? ""; if (!text.Contains("SampleOrDefault") && !text.Contains("SampleManyOrAll") && !text.Contains("Sample") && !text.Contains("SampleMany")) { throw new ArgumentException("Matcher's position is not on sampling method"); } if (searchBackMatch == null) { searchBackMatch = new CodeMatch((Func<CodeInstruction, bool>)((CodeInstruction ci) => ci.opcode == OpCodes.Callvirt && ci.operand as MethodInfo == AccessTools.PropertyGetter(typeof(EnemyGroup), "Alives")), (string)null); } Label label = generator.DefineLabel(); Label label2 = generator.DefineLabel(); matcher.AddLabels((IEnumerable<Label>)new Label[1] { label2 }).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Br, (object)label2) }); if (many) { matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldstr, (object)"deezdeeznuts") }); } else { matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { CodeInstructionExtensions.WithLabels(new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Helpers), "FakeRng", (Type[])null, (Type[])null)), new Label[1] { label }) }); } matcher.Advance(-1); if (amountMatch != null && searchForAmountMatchFirst) { matcher.ThrowIfNotMatchBack($"{amountMatch} didn't match anything", amountMatch).MatchStartBackwards(amountMatch).Advance(-1); } matcher.ThrowIfNotMatchBack($"{searchBackMatch} didn't match anything", (CodeMatch[])(object)new CodeMatch[1] { searchBackMatch }).MatchEndBackwards((CodeMatch[])(object)new CodeMatch[1] { searchBackMatch }).Advance(1) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Dup, (object)null) }); List<CodeInstruction> list = new List<CodeInstruction>(); if (many) { if (amountMatch == null) { list.Add(matcher.Instruction); } else { matcher.ThrowIfNotMatchForward($"AmountMatch@{matcher.Pos}: {amountMatch} didn't match anything", amountMatch).MatchEndForward(amountMatch); list.AddRange(matcher.InstructionsWithOffsets(-amountMatch.Length + 1, 0)); } matcher.Advance(1); matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Helpers), "RngGuardMany", (Type[])null, (Type[])null)) }); } else { matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Helpers), "RngGuardSingle", (Type[])null, (Type[])null)) }); } matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Brtrue, (object)label) }); foreach (var (val, num) in list.Select((CodeInstruction ci, int i) => (ci, i))) { matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { val.Clone() }); } if (many) { matcher.ThrowIfNotMatchForward("SATORRI", (CodeMatch[])(object)new CodeMatch[1] { new CodeMatch((Func<CodeInstruction, bool>)((CodeInstruction ci) => (ci.operand?.ToString() ?? "") == "deezdeeznuts"), (string)null) }); matcher.MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { new CodeMatch((Func<CodeInstruction, bool>)((CodeInstruction ci) => (ci.operand?.ToString() ?? "") == "deezdeeznuts"), (string)null) }); foreach (var item in list.Select((CodeInstruction ci, int i) => (ci, i))) { var (val2, _) = item; if (item.Item2 == 0) { matcher.SetInstruction(val2.Clone()).AddLabels((IEnumerable<Label>)new Label[1] { label }).Advance(1); } else { matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { val2.Clone() }); } } matcher.InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Helpers), "FakeRng", (Type[])null, (Type[])null)) }); } return matcher; } public static bool IsActTransition(MapNode node) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Invalid comparison between Unknown and I4 //IL_000a: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Invalid comparison between Unknown and I4 //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_0019: Invalid comparison between Unknown and I4 //IL_001c: Unknown result type (might be due to invalid IL or missing references) //IL_0023: Invalid comparison between Unknown and I4 return (int)node.StationType == 7 || (int)node.StationType == 8 || (int)node.StationType == 3 || (int)node.StationType == 9; } public static bool GetOrCreateVal<K, V>(this Dictionary<K, V> dic, K key, Func<V> valInit, out V value) { if (dic.TryGetValue(key, out value)) { return true; } value = valInit(); dic[key] = value; return false; } public static int BitArrayToInt(int[] bitArray) { int num = 0; for (int i = 0; i < bitArray.Length; i++) { if (bitArray[i] == 1) { num |= 1 << i; } } return num; } public static int CountSetBits(ulong n) { int num = 0; while (n != 0) { n &= n - 1; num++; } return num; } } [HarmonyPatch] internal class Gr_InitRngs_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Constructor(typeof(GameRunController), new Type[1] { typeof(GameRunStartupParameters) }, false); } internal static void InitRngs(GameRunController gr) { //IL_005f: Unknown result type (might be due to invalid IL or missing references) //IL_0069: Expected O, but got Unknown //IL_007a: Unknown result type (might be due to invalid IL or missing references) //IL_0084: Expected O, but got Unknown //IL_0095: Unknown result type (might be due to invalid IL or missing references) //IL_009f: Expected O, but got Unknown //IL_00b0: Unknown result type (might be due to invalid IL or missing references) //IL_00ba: Expected O, but got Unknown //IL_00cb: Unknown result type (might be due to invalid IL or missing references) //IL_00d5: Expected O, but got Unknown //IL_014b: Unknown result type (might be due to invalid IL or missing references) //IL_0151: Expected O, but got Unknown //IL_015d: Unknown result type (might be due to invalid IL or missing references) //IL_0167: Expected O, but got Unknown //IL_0173: Unknown result type (might be due to invalid IL or missing references) //IL_017d: Expected O, but got Unknown //IL_0189: Unknown result type (might be due to invalid IL or missing references) //IL_0193: Expected O, but got Unknown //IL_023a: Unknown result type (might be due to invalid IL or missing references) //IL_0244: Expected O, but got Unknown //IL_0250: Unknown result type (might be due to invalid IL or missing references) //IL_025a: Expected O, but got Unknown GrRngs orCreate = GrRngs.GetOrCreate(gr); BepinexPlugin.log.LogDebug((object)"Initing GrRngs.."); orCreate.persRngs.stageMasterRng = new StageMasterRng(gr.RootRng.NextULong()); orCreate.persRngs.actMasterRng = new ActMasterRng(gr.RootRng.NextULong()); orCreate.persRngs.gapInitRng = new RandomGen(gr.RootRng.NextULong()); orCreate.persRngs.shopInitRng = new RandomGen(gr.RootRng.NextULong()); orCreate.persRngs.rareExhibitQueueRng = new RandomGen(gr.RootRng.NextULong()); orCreate.persRngs.qingeUpgradeQueueRng = new RandomGen(gr.RootRng.NextULong()); orCreate.persRngs.fallbackInitRng = new RandomGen(gr.RootRng.NextULong()); orCreate.ExhibitSelfRngs = new EntitySelfRngs<Exhibit>((Exhibit ex) => ((GameEntity)ex).Id, gr.RootRng.NextULong()); orCreate.ExhibitSelfRngs.InitialiseRngs(Padding.AllExhibits.Select((Type ec) => ec?.Name)); RandomGen val = new RandomGen(gr.RootRng.NextULong()); orCreate.persRngs.cardUpgradeQueueRng = new RandomGen(val.NextULong()); orCreate.persRngs.eliteCardRng = new RandomGen(val.NextULong()); orCreate.persRngs.bossCardRng = new RandomGen(val.NextULong()); orCreate.persRngs.adventureSelfRngs = new EntitySelfRngs<Adventure>((Adventure a) => a.Id, gr.RootRng.NextULong()); orCreate.persRngs.adventureSelfRngs.InitialiseRngs(from ac in Padding.AllAdventurePadding() select ac?.Name); orCreate.persRngs.shopRngs = ShopRngs.Init(gr.RootRng.NextULong()); orCreate.persRngs.extraCardRewardRng = new RandomGen(gr.RootRng.NextULong()); orCreate.unusedRoot0 = new RandomGen(gr.RootRng.NextULong()); GrRngs.wr_midConstructGr.SetTarget(gr); } private static void Postfix() { GrRngs.wr_midConstructGr.SetTarget(null); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_0034: Expected O, but got Unknown //IL_004e: Unknown result type (might be due to invalid IL or missing references) //IL_0054: Expected O, but got Unknown //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_0082: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Call, (object)AccessTools.PropertySetter(typeof(GameRunController), "RootRng"))) }).Advance(1).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_0, (object)null) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Gr_InitRngs_Patch), "InitRngs", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch(typeof(GameMaster), "BattleStationFlowFromEndSave")] internal class ReEnterAfterBattle_Patch { private static void Prefix(GameMaster __instance) { GameRunController currentGameRun = __instance.CurrentGameRun; GrRngs orCreate = GrRngs.GetOrCreate(currentGameRun); if (orCreate.NodeMaster == null) { orCreate.NodeMaster = new NodeMasterRng { rng = RandomGen.FromState(orCreate.persRngs.prevNodeMasterState) }; orCreate.NodeMaster.Advance(currentGameRun); } } } [HarmonyPatch(typeof(GameRunController), "EnterStation")] internal class EnterStation_Patch { private static void Prefix(GameRunController __instance, Station station) { //IL_0019: Unknown result type (might be due to invalid IL or missing references) //IL_001e: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0022: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Unknown result type (might be due to invalid IL or missing references) //IL_005b: Expected I4, but got Unknown //IL_01d4: Unknown result type (might be due to invalid IL or missing references) //IL_01da: Invalid comparison between Unknown and I4 //IL_01f1: Unknown result type (might be due to invalid IL or missing references) GrRngs orCreate = GrRngs.GetOrCreate(__instance); MapNode visitingNode = __instance.CurrentMap.VisitingNode; RandomGen val = null; StationType stationType = visitingNode.StationType; StationType val2 = stationType; switch ((int)val2) { case 0: val = orCreate.persRngs.fallbackInitRng; BepinexPlugin.log.LogWarning((object)$"Node({visitingNode.X}, {visitingNode.Y}) station type is {(object)(StationType)0} using fallback rng."); break; case 1: val = orCreate.persRngs.battleInitRng; break; case 2: val = orCreate.persRngs.eliteInitRng; break; case 3: orCreate.persRngs.actMasterRng.Advance(__instance); val = orCreate.persRngs.transitionInitRng; break; case 4: val = orCreate.persRngs.gapInitRng; break; case 5: val = orCreate.persRngs.shopInitRng; break; case 6: orCreate.NodeMaster = null; break; case 7: orCreate.persRngs.stageMasterRng.Advance(__instance); orCreate.persRngs.actMasterRng.Advance(__instance); val = orCreate.persRngs.transitionInitRng; break; case 8: orCreate.persRngs.actMasterRng.Advance(__instance); val = orCreate.persRngs.transitionInitRng; break; case 9: orCreate.persRngs.actMasterRng.Advance(__instance); val = orCreate.persRngs.transitionInitRng; break; case 10: val = orCreate.persRngs.bossInitRng; break; case 11: val = orCreate.persRngs.fallbackInitRng; break; } if (val != null) { orCreate.NodeMaster = new NodeMasterRng(val.NextULong()); orCreate.NodeMaster.Advance(__instance); } else if ((int)visitingNode.StationType != 6) { BepinexPlugin.log.LogError((object)$"NodeRngs were not assigned for station {visitingNode.StationType}"); } } private static void Postfix(GameRunController __instance) { StatsLogger.LogGeneral(__instance); StatsLogger.LogVanillaRngs(__instance); StatsLogger.LogPersistentRngs(__instance); } } [HarmonyPatch(typeof(AdventureStation), "OnEnter")] internal class InitAdventureNode_Patch { private static void SetNodeMaster(Type aType, Stage stage) { BepinexPlugin.log.LogDebug((object)$"{stage}: {aType}"); GameRunController gameRun = ((GameEntity)stage).GameRun; GrRngs orCreate = GrRngs.GetOrCreate(gameRun); ulong seed = orCreate.persRngs.adventureSelfRngs.GetRng(aType.Name).NextULong(); orCreate.NodeMaster = new NodeMasterRng(seed); orCreate.NodeMaster.Advance(gameRun); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions, ILGenerator generator) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Expected O, but got Unknown //IL_004f: Unknown result type (might be due to invalid IL or missing references) //IL_0055: Expected O, but got Unknown //IL_0068: Unknown result type (might be due to invalid IL or missing references) //IL_006e: Expected O, but got Unknown //IL_0094: Unknown result type (might be due to invalid IL or missing references) //IL_009a: Expected O, but got Unknown //IL_00c2: Unknown result type (might be due to invalid IL or missing references) //IL_00c8: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.Method(typeof(Stage), "GetAdventure", (Type[])null, (Type[])null))) }).Advance(1).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Dup, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_0, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.PropertyGetter(typeof(AdventureStation), "Stage")) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(InitAdventureNode_Patch), "SetNodeMaster", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch(typeof(Overrider), "OnEnteredWithMode")] internal class DoremyPortal_Patch { private static void Prefix(Overrider __instance) { GameRunController gameRun = __instance._gameRun; GrRngs.AdvanceRngsOnJump(gameRun, gameRun.CurrentMap.BossNode); } } [HarmonyPatch(typeof(GameRunController), "RollNormalExhibit")] [HarmonyPriority(200)] internal class ExhibitRoll_Patch { private static bool Prefix(GameRunController __instance, ref Exhibit __result, RandomGen rng, ExhibitWeightTable weightTable, Func<Exhibit> fallback, Predicate<ExhibitConfig> filter) { GrRngs orCreate = GrRngs.GetOrCreate(__instance); orCreate.NormalExSampler.successAction = delegate(Exhibit ex) { __instance.ExhibitPool.Remove(((object)ex).GetType()); }; __result = orCreate.NormalExSampler.Roll(rng, (Type t) => weightTable.WeightFor(ExhibitConfig.FromId(t.Name)) * Library.WeightForExhibit(t, __instance), out var logInfo, (Type t) => filter == null || filter(ExhibitConfig.FromId(t.Name)), fallback); orCreate.NormalExSampler.successAction = null; StatsLogger.LogEx(__result, __instance, logInfo); return false; } } [HarmonyPatch(typeof(Stage), "GetAdventure")] [HarmonyPriority(200)] internal class AdventureRoll_Patch { private static bool Prefix(Stage __instance, ref Type __result) { GameRunController gr = ((GameEntity)__instance).GameRun; GrRngs orCreate = GrRngs.GetOrCreate(gr); AdventureInPool adventureInPool = orCreate.AdventureSampler.requirements.Find((ISlotRequirement<Type> r) => r is AdventureInPool) as AdventureInPool; Dictionary<Type, float> t2W = new Dictionary<Type, float>(); CollectionExtensions.Do<RandomPoolEntry<Type>>((IEnumerable<RandomPoolEntry<Type>>)__instance.AdventurePool, (Action<RandomPoolEntry<Type>>)delegate(RandomPoolEntry<Type> e) { t2W.TryAdd(e.Elem, e.Weight); }); adventureInPool.poolSet = new HashSet<Type>(t2W.Keys); orCreate.AdventureSampler.successAction = delegate(Type t) { __instance.AdventurePool.Remove(t, true); }; __result = orCreate.AdventureSampler.Roll(GrRngs.GetAdventureQueueRng(gr), delegate(Type t) { float value = 0f; t2W.TryGetValue(t, out value); return value * Library.WeightForAdventure(t, gr); }, out var logInfo, null, () => typeof(FakeAdventure)); StatsLogger.LogEvent(__result, gr, logInfo); return false; } } [HarmonyPatch(typeof(GameRunController), "RollCards", new Type[] { typeof(RandomGen), typeof(CardWeightTable), typeof(int), typeof(ManaGroup?), typeof(bool), typeof(bool), typeof(bool), typeof(bool), typeof(Predicate<CardConfig>) })] [HarmonyPriority(200)] internal class CardRoll_Patch { private static bool Prefix(GameRunController __instance, ref Card[] __result, RandomGen rng, CardWeightTable weightTable, int count, ManaGroup? manaLimit, bool colorLimit, bool applyFactors = false, bool battleRolling = false, bool ensureCount = false, [MaybeNull] Predicate<CardConfig> filter = null) { GrRngs orCreate = GrRngs.GetOrCreate(__instance); List<Card> rolledCards = new List<Card>(); CardInPool cardInPool = orCreate.RewardCardSampler.requirements.Find((ISlotRequirement<Type> r) => r is CardInPool) as CardInPool; cardInPool.poolSet = new HashSet<Type>(((IEnumerable<RandomPoolEntry<Type>>)__instance.CreateValidCardsPool(weightTable, manaLimit, colorLimit, applyFactors, battleRolling, filter)).Select((RandomPoolEntry<Type> re) => re.Elem)); HashSet<string> charExSet = new HashSet<string> { ((GameEntity)__instance.Player).Id }; if (__instance.AllCharacterCardsFlag > 0) { foreach (PlayerUnitConfig item in PlayerUnitConfig.AllConfig()) { charExSet.Add(item.Id); } } else { foreach (Exhibit exhibit in __instance.Player.Exhibits) { if (exhibit.OwnerId != null) { charExSet.Add(exhibit.OwnerId); } } } Func<Type, float> getW = delegate(Type t) { CardConfig val2 = CardConfig.FromId(t.Name); float num = weightTable.WeightFor(val2, ((GameEntity)__instance.Player).Id, (ISet<string>)charExSet); float num2 = __instance.BaseCardWeight(val2, false); return num * num2; }; CsvLogger log = ((__instance.Battle == null) ? StatsLogger.GetCardLog(__instance) : StatsLogger.GetCardGenLog(__instance)); for (int i = 0; i < count; i++) { ulong state = rng.State; SamplerLogInfo logInfo; Card val = orCreate.RewardCardSampler.Roll(rng, getW, out logInfo, (Type t) => rolledCards.All((Card c) => ((object)c).GetType() != t)); if (val == null) { if (!ensureCount) { StatsLogger.LogCard(log, val, __instance, logInfo); break; } BepinexPlugin.log.LogWarning((object)"ENSURING COUNT ENSURING COUNT ENSURING COUNT"); rng.State = state; val = orCreate.RewardCardSampler.Roll(rng, getW, out logInfo); } if (val != null) { rolledCards.Add(val); } StatsLogger.LogCard(log, val, __instance, logInfo); } __result = rolledCards.ToArray(); return false; } } } namespace RngFix.Patches.Stages { [HarmonyPatch(typeof(BambooForest), "GetEliteEnemies")] internal class BambooForest_EliteSample_Patch { private static string SampleFirstElite(UniqueRandomPool<string> _, RandomGen rng, BambooForest stage) { //IL_001a: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Expected O, but got Unknown UniqueRandomPool<string> val = new UniqueRandomPool<string>(((Stage)stage).EliteEnemyPool); RandomGen val2 = new RandomGen((ulong)rng.NextInt(0, int.MaxValue)); string text = "Aya"; if (val._entries.All((RandomPoolEntry<string> e) => e.Elem == "Aya") && ((IEnumerable<RandomPoolEntry<string>>)val._fallbackPool).All((RandomPoolEntry<string> e) => e.Elem == "Aya")) { return text; } while (text == "Aya") { text = val.Sample(val2); } return text; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0047: Unknown result type (might be due to invalid IL or missing references) //IL_0051: Expected O, but got Unknown //IL_005f: Unknown result type (might be due to invalid IL or missing references) //IL_0065: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).SearchForward((Func<CodeInstruction, bool>)((CodeInstruction ci) => ci.opcode == OpCodes.Callvirt && ci.operand.ToString().Contains("Sample"))).SetInstruction(new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(BambooForest_EliteSample_Patch), "SampleFirstElite", (Type[])null, (Type[])null))).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_0, (object)null) }) .LeaveJumpFix() .InstructionEnumeration(); } } } namespace RngFix.Patches.RngGetters { [HarmonyPatch(typeof(GameRunController), "GetRewardCards")] internal class CardReward_Patch { private static RandomGen SwitchCardRng(GameRunController gr) { StackFrame stackFrame = new StackFrame(2); string name = stackFrame.GetMethod().Name; GrRngs orCreate = GrRngs.GetOrCreate(gr); return (RandomGen)(name switch { "GetEnemyCardReward" => gr.CardRng, "GetEliteEnemyCardReward" => gr.CardRng, "GetBossCardReward" => GrRngs.GetBossCardRng(gr), "GetDrinkTeaCardReward" => orCreate.ExhibitSelfRngs.GetRng("HuangyouJiqiren"), _ => gr.CardRng, }); } private static RandomGen ExtraCardRewardRng(GameRunController gr) { return GrRngs.GetOrCreate(gr).persRngs.extraCardRewardRng; } private static RandomGen UpgradeRng(GameRunController gr) { //IL_0018: Unknown result type (might be due to invalid IL or missing references) //IL_001e: Expected O, but got Unknown RandomGen cardUpgradeQueueRng = GrRngs.GetOrCreate(gr).persRngs.cardUpgradeQueueRng; return new RandomGen(cardUpgradeQueueRng.NextULong()); } private static float UpgradeFloat(RandomGen rng) { return rng.NextFloat(0f, 1f); } private static bool CheckRepeatRareBoss(bool repeat, bool boss) { return repeat && !boss; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions, ILGenerator generator) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0009: Expected O, but got Unknown //IL_002b: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Expected O, but got Unknown //IL_0054: Unknown result type (might be due to invalid IL or missing references) //IL_005a: Expected O, but got Unknown //IL_0082: Unknown result type (might be due to invalid IL or missing references) //IL_0088: Expected O, but got Unknown //IL_012c: Unknown result type (might be due to invalid IL or missing references) //IL_0136: Expected O, but got Unknown //IL_014a: Unknown result type (might be due to invalid IL or missing references) //IL_0154: Expected O, but got Unknown //IL_0178: Unknown result type (might be due to invalid IL or missing references) //IL_017e: Expected O, but got Unknown //IL_0197: Unknown result type (might be due to invalid IL or missing references) //IL_019d: Expected O, but got Unknown //IL_01b6: Unknown result type (might be due to invalid IL or missing references) //IL_01bc: Expected O, but got Unknown //IL_01e4: Unknown result type (might be due to invalid IL or missing references) //IL_01ea: Expected O, but got Unknown //IL_0207: Unknown result type (might be due to invalid IL or missing references) //IL_020d: Expected O, but got Unknown //IL_0220: Unknown result type (might be due to invalid IL or missing references) //IL_022a: Expected O, but got Unknown //IL_024e: Unknown result type (might be due to invalid IL or missing references) //IL_0254: Expected O, but got Unknown //IL_027c: Unknown result type (might be due to invalid IL or missing references) //IL_0282: Expected O, but got Unknown //IL_029f: Unknown result type (might be due to invalid IL or missing references) //IL_02a5: Expected O, but got Unknown CodeMatcher val = new CodeMatcher(instructions, (ILGenerator)null); val = val.MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ldfld, (object)AccessTools.Field(typeof(GameRunController), "_cardRewardDecreaseRepeatRare"))) }).Advance(1).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_S, (object)6) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(CardReward_Patch), "CheckRepeatRareBoss", (Type[])null, (Type[])null)) }); for (int i = 0; i < 3; i++) { val = val.ReplaceRngGetter("CardRng", AccessTools.Method(typeof(CardReward_Patch), "SwitchCardRng", (Type[])null, (Type[])null)); } val = val.ReplaceRngGetter("CardRng", AccessTools.Method(typeof(CardReward_Patch), "ExtraCardRewardRng", (Type[])null, (Type[])null)); LocalBuilder localBuilder = generator.DeclareLocal(typeof(RandomGen)); LocalBuilder localBuilder2 = generator.DeclareLocal(typeof(float)); val.MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Call, (object)AccessTools.PropertyGetter(typeof(GameRunController), "CardRng"))) }).MatchEndBackwards((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ldarg_0, (object)null)) }).RemoveInstructions(5) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc, (object)localBuilder2.LocalIndex) }) .MatchEndBackwards((CodeMatch[])(object)new CodeMatch[1] { new CodeMatch((OpCode?)OpCodes.Br, (object)null, (string)null) }) .Advance(-1) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_0, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(CardReward_Patch), "UpgradeRng", (Type[])null, (Type[])null)) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Stloc, (object)localBuilder.LocalIndex) }) .MatchEndForward((CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ldloca_S, (object)null)) }) .Advance(1) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc, (object)localBuilder.LocalIndex) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(CardReward_Patch), "UpgradeFloat", (Type[])null, (Type[])null)) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Stloc, (object)localBuilder2.LocalIndex) }); return val.LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch] internal class RareExhibitRoll_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Method(typeof(MiyoiBartender), "InitVariables", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(YachieOppression), "InitVariables", (Type[])null, (Type[])null); } public static Exhibit RollExhibitInAdventure(Stage stage, ExhibitWeightTable weightTable, Predicate<ExhibitConfig> filter = null) { GameRunController gameRun = ((GameEntity)stage).GameRun; return gameRun.RollNormalExhibit(gameRun.AdventureRng, weightTable, (Func<Exhibit>)stage.GetSentinelExhibit, filter); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0036: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.Method(typeof(Stage), "RollExhibitInAdventure", (Type[])null, (Type[])null))) }).Set(OpCodes.Call, (object)AccessTools.Method(typeof(RareExhibitRoll_Patch), "RollExhibitInAdventure", (Type[])null, (Type[])null)).LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class MoneyReward_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Method(typeof(BossStation), "GenerateRewards", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(Station), "GenerateEliteEnemyRewards", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(Station), "GenerateEnemyRewards", (Type[])null, (Type[])null); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0009: Expected O, but got Unknown CodeMatcher matcher = new CodeMatcher(instructions, (ILGenerator)null); while (true) { try { matcher = matcher.ReplaceRngGetter("GameRunEventRng", AccessTools.Method(typeof(GrRngs), "GetMoneyRewardRng", (Type[])null, (Type[])null)); } catch (InvalidOperationException) { break; } } return matcher.LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch(typeof(GameRunController), "GetShopCards")] internal class GetShopCards_Patch { private static RandomGen ReplaceShopRng(GameRunController gr, CardWeightTable cwt) { GrRngs orCreate = GrRngs.GetOrCreate(gr); ShopRngs shopRngs = orCreate.persRngs.shopRngs; if (!ShopFactor_Patch.wt_cwt.TryGetValue(cwt, out var value)) { BepinexPlugin.log.LogWarning((object)"No matching CardWeightTable found. Using fallback rng."); return shopRngs.fallbackRng; } if (!shopRngs.rngs.TryGetValue(value, out var value2)) { BepinexPlugin.log.LogWarning((object)("No matching cwtName " + value + " in shop rngs. Using fallback rng")); return shopRngs.fallbackRng; } return value2; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown //IL_0037: Unknown result type (might be due to invalid IL or missing references) //IL_003d: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "ShopRng", AccessTools.Method(typeof(GetShopCards_Patch), "ReplaceShopRng", (Type[])null, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_2, (object)null) }).LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch(typeof(Stage), "GetShopExhibit")] internal class GetShopExhibit_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "ShopRng", AccessTools.Method(typeof(GrRngs), "GetShopExRng", (Type[])null, (Type[])null)).LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch(typeof(Stage), "GetEnemies")] internal class GetEnemies_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_001a: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Expected O, but got Unknown MethodInfo newCall = AccessTools.Method(typeof(GrRngs), "GetEnemyActQueueRng", (Type[])null, (Type[])null); return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "StationRng", newCall).ReplaceRngGetter("StationRng", newCall).ReplaceRngGetter("StationRng", newCall) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class GetEliteEnemies_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Method(typeof(Stage), "GetEliteEnemies", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(BambooForest), "GetEliteEnemies", (Type[])null, (Type[])null); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "StationRng", AccessTools.Method(typeof(GrRngs), "GetEliteQueueRng", (Type[])null, (Type[])null)).LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch(typeof(Stage), "GetAdventure")] internal class GetAdventure_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "StationRng", AccessTools.Method(typeof(GrRngs), "GetAdventureQueueRng", (Type[])null, (Type[])null)).LeaveJumpFix().InstructionEnumeration(); } } } namespace RngFix.Patches.Exhibits { [HarmonyPatch(typeof(GameRunController), "RollShiningExhibit")] internal class RollShiningExhibit_Patch { public const float maxTotalWeight = 200f; private static Type ConsistentExSample(RepeatableRandomPool<Type> pool, RandomGen rng, GameRunController gr) { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_000d: Expected O, but got Unknown RandomGen val = new RandomGen(rng.NextULong()); RepeatableRandomPool<Type> val2 = new RepeatableRandomPool<Type>(pool); float num = pool._entries.Sum((RandomPoolEntry<Type> e) => e.Weight); if (200f > num) { val2.Add((Type)null, 200f - num); } else { BepinexPlugin.log.LogWarning((object)$"Total shining exhibit weight {num} exceed {200f}"); } Type type = null; int num2 = 0; int num3 = 1000000; while (type == null && num2 < num3) { type = val2.Sample(val); num2++; } if (type == null) { type = pool.Sample(val); BepinexPlugin.log.LogWarning((object)$"Shinning exhibit not sampled in {num2} rolls. Using fallback."); } return type; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0051: Unknown result type (might be due to invalid IL or missing references) //IL_005b: Expected O, but got Unknown //IL_0069: Unknown result type (might be due to invalid IL or missing references) //IL_006f: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).SearchForward((Func<CodeInstruction, bool>)((CodeInstruction ci) => ci.opcode == OpCodes.Callvirt && ci.operand is MethodBase methodBase && methodBase.Name == "Sample")).ThrowIfInvalid("").SetInstruction(new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(RollShiningExhibit_Patch), "ConsistentExSample", (Type[])null, (Type[])null))) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_0, (object)null) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class LightBulb_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return ExtraAccess.InnerMoveNext(typeof(GapOptionsPanel), "GetRareCardRunner"); } private static string LightBulbId() { return "ShanliangDengpao"; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Expected O, but got Unknown //IL_006b: Unknown result type (might be due to invalid IL or missing references) //IL_0071: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "AdventureRng", AccessTools.Method(typeof(ExhibitsSelfRngs), "GetSelfRng", new Type[2] { typeof(GameRunController), typeof(string) }, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(LightBulb_Patch), "LightBulbId", (Type[])null, (Type[])null)) }).LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class MagicGuideBook_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return ExtraAccess.InnerMoveNext(typeof(Modaoshu), "SpecialGain"); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Expected O, but got Unknown //IL_0056: Unknown result type (might be due to invalid IL or missing references) //IL_005c: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "CardRng", AccessTools.Method(typeof(ExhibitsSelfRngs), "GetSelfRng", new Type[2] { typeof(GameRunController), typeof(Exhibit) }, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc_1, (object)null) }).LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class FragmentsOfTheWorld_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return ExtraAccess.InnerMoveNext(typeof(ShijieSuipian), "SpecialGain"); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Expected O, but got Unknown //IL_0056: Unknown result type (might be due to invalid IL or missing references) //IL_005c: Expected O, but got Unknown //IL_00af: Unknown result type (might be due to invalid IL or missing references) //IL_00b5: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "GameRunEventRng", AccessTools.Method(typeof(ExhibitsSelfRngs), "GetSelfRng", new Type[2] { typeof(GameRunController), typeof(Exhibit) }, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc_1, (object)null) }).ReplaceRngGetter("GameRunEventRng", AccessTools.Method(typeof(ExhibitsSelfRngs), "GetSelfRng", new Type[2] { typeof(GameRunController), typeof(Exhibit) }, (Type[])null)) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc_1, (object)null) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch] internal class UpgradeRandomCards_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Method(typeof(Chaidao), "OnGain", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(Jiaobu), "OnGain", (Type[])null, (Type[])null); yield return AccessTools.Method(typeof(QipaiYouhua), "OnGain", (Type[])null, (Type[])null); } public static void UpgradeRandomCards(GameRunController gr, int amount = 1, CardType? type = null, Exhibit exhibit = null) { //IL_0055: Unknown result type (might be due to invalid IL or missing references) //IL_005c: Unknown result type (might be due to invalid IL or missing references) if (amount <= 0) { throw new InvalidOperationException("DEEZNUTS"); } List<Card> list = new List<Card>(); foreach (Card item in gr._baseDeck) { if (!item.CanUpgradeAndPositive) { continue; } if (type.HasValue) { if (item.CardType == type.Value) { list.Add(item); } } else { list.Add(item); } } Card[] array = CollectionsExtensions.SampleManyOrAll<Card>((IEnumerable<Card>)list, amount, GrRngs.GetOrCreate(gr).ExhibitSelfRngs.GetRng(exhibit)); gr.UpgradeDeckCards((IEnumerable<Card>)array, false); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0036: Expected O, but got Unknown //IL_006a: Unknown result type (might be due to invalid IL or missing references) //IL_0070: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.Method(typeof(GameRunController), "UpgradeRandomCards", (Type[])null, (Type[])null))) }).Set(OpCodes.Call, (object)AccessTools.Method(typeof(UpgradeRandomCards_Patch), "UpgradeRandomCards", (Type[])null, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_0, (object)null) }) .LeaveJumpFix() .InstructionEnumeration(); } } } namespace RngFix.Patches.Events { [HarmonyPatch(typeof(GameRunController), "GetOpponentCandidates")] internal class GameRunController_GetOpponentCandidates_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "StationRng", AccessTools.PropertyGetter(typeof(GameRunController), "AdventureRng")).LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch] internal class GameMaster_SelectStationFlow_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return ExtraAccess.InnerMoveNext(typeof(GameMaster), "SelectStationFlow"); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "RootRng", AccessTools.PropertyGetter(typeof(GameRunController), "AdventureRng")).LeaveJumpFix().InstructionEnumeration(); } } public class DancersRng { public RandomGen optionRng; public RandomGen toolRng; public RandomGen exhibitRng; public RandomGen abilityRng; } [HarmonyPatch(typeof(BackgroundDancers))] internal class DancersInit_Patch { private static ConditionalWeakTable<BackgroundDancers, DancersRng> table = new ConditionalWeakTable<BackgroundDancers, DancersRng>(); public static DancersRng GerOrCreateRng(Adventure adventure) { BackgroundDancers val = (BackgroundDancers)(object)((adventure is BackgroundDancers) ? adventure : null); if (val != null) { return table.GetOrCreateValue(val); } return null; } public static RandomGen GetOptionRng(BackgroundDancers bd) { return GerOrCreateRng((Adventure)(object)bd).optionRng; } public static RandomGen GetToolRng(BackgroundDancers bd) { return GerOrCreateRng((Adventure)(object)bd).toolRng; } public static RandomGen GetExhibitRng(BackgroundDancers bd) { return GerOrCreateRng((Adventure)(object)bd).exhibitRng; } public static RandomGen GetAbilityRng(BackgroundDancers bd) { return GerOrCreateRng((Adventure)(object)bd).abilityRng; } [HarmonyPatch("InitVariables")] [HarmonyPrefix] private static void InitPrefix(BackgroundDancers __instance) { //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Expected O, but got Unknown //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Expected O, but got Unknown //IL_0047: Unknown result type (might be due to invalid IL or missing references) //IL_0051: Expected O, but got Unknown //IL_005d: Unknown result type (might be due to invalid IL or missing references) //IL_0067: Expected O, but got Unknown DancersRng dancersRng = GerOrCreateRng((Adventure)(object)__instance); GameRunController gameRun = ((Adventure)__instance).GameRun; dancersRng.optionRng = new RandomGen(gameRun.AdventureRng.NextULong()); dancersRng.toolRng = new RandomGen(gameRun.AdventureRng.NextULong()); dancersRng.exhibitRng = new RandomGen(gameRun.AdventureRng.NextULong()); dancersRng.abilityRng = new RandomGen(gameRun.AdventureRng.NextULong()); } } [HarmonyPatch] internal class DancersRollSelect_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return AccessTools.Method(typeof(BackgroundDancers), "RollOptions", (Type[])null, (Type[])null); yield return ExtraAccess.InnerMoveNext(typeof(BackgroundDancers), "SelectOption"); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions, MethodBase __originalMethod) { //IL_0022: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Expected O, but got Unknown //IL_0052: Unknown result type (might be due to invalid IL or missing references) //IL_0058: Expected O, but got Unknown //IL_006b: Unknown result type (might be due to invalid IL or missing references) //IL_0071: Expected O, but got Unknown //IL_00a1: Unknown result type (might be due to invalid IL or missing references) //IL_00a7: Expected O, but got Unknown //IL_00ba: Unknown result type (might be due to invalid IL or missing references) //IL_00c0: Expected O, but got Unknown //IL_00f0: Unknown result type (might be due to invalid IL or missing references) //IL_00f6: Expected O, but got Unknown //IL_0109: Unknown result type (might be due to invalid IL or missing references) //IL_010f: Expected O, but got Unknown OpCode opCode = ((__originalMethod.Name == "MoveNext") ? OpCodes.Ldloc_1 : OpCodes.Ldarg_0); return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "AdventureRng", AccessTools.Method(typeof(DancersInit_Patch), "GetOptionRng", (Type[])null, (Type[])null)).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(opCode, (object)null) }).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Pop, (object)null) }) .ReplaceRngGetter("AdventureRng", AccessTools.Method(typeof(DancersInit_Patch), "GetToolRng", (Type[])null, (Type[])null)) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(opCode, (object)null) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Pop, (object)null) }) .ReplaceRngGetter("AdventureRng", AccessTools.Method(typeof(DancersInit_Patch), "GetAbilityRng", (Type[])null, (Type[])null)) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(opCode, (object)null) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Pop, (object)null) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch(typeof(Stage), "GetSpecialAdventureExhibit")] internal class GetSpecialAdventureExhibit_Patch { private static RandomGen GetRng(GameRunController gr) { try { VnPanel panel = UiManager.GetPanel<VnPanel>(); Adventure currentAdventure = panel._currentAdventure; RandomGen val = DancersInit_Patch.GerOrCreateRng(currentAdventure)?.exhibitRng; if (val != null) { return val; } } catch (InvalidOperationException) { } return gr.ExhibitRng; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "ExhibitRng", AccessTools.Method(typeof(GetSpecialAdventureExhibit_Patch), "GetRng", (Type[])null, (Type[])null)).LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch(typeof(MiyoiBartender), "InitVariables")] internal class MiyoiBartender_InitVariables_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "StationRng", AccessTools.PropertyGetter(typeof(GameRunController), "AdventureRng")).LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch(typeof(RinnosukeTrade), "GetExhibitPrice")] internal class RinnosukeTrade_GetExhibitPrice_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "ShopRng", AccessTools.Method(typeof(GrRngs), "GetTransitionRng", (Type[])null, (Type[])null)).LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch(typeof(SumirekoGathering), "InitVariables")] internal class SumirekoGathering_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "AdventureRng", AccessTools.Method(typeof(GrRngs), "GetTransitionRng", (Type[])null, (Type[])null)).LeaveJumpFix().InstructionEnumeration(); } } [HarmonyPatch(typeof(Stage), "GetSupplyExhibit")] internal class GetSupplyExhibit_Patch { private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Expected O, but got Unknown return Helpers.ReplaceRngGetter(new CodeMatcher(instructions, (ILGenerator)null), "ExhibitRng", AccessTools.Method(typeof(GrRngs), "GetTransitionRng", (Type[])null, (Type[])null)).LeaveJumpFix().InstructionEnumeration(); } } internal class Yachie { } } namespace RngFix.Patches.Debug { internal class PickCardLog { public static void RegisterOnCardsAdded() { CHandlerManager.RegisterGameEventHandler<CardsEventArgs>((EventProvider<CardsEventArgs, GameRunController>)((GameRunController gr) => gr.DeckCardsAdded), (GameEventHandler<CardsEventArgs>)delegate(CardsEventArgs args) { CollectionExtensions.Do<IGrouping<string, Card>>(from c in args.Cards group c by ((c != null) ? ((GameEntity)c).Id : null) ?? "null", (Action<IGrouping<string, Card>>)delegate(IGrouping<string, Card> cg) { StatsLogger.LogPickedCard(cg.FirstOrDefault(), cg.Count(), StatsLogger.Gr()); }); }, (GameEventPriority)10); } } internal class RngGetDebug_Patch { private static MethodInfo adventureRng = AccessTools.PropertyGetter(typeof(GameRunController), "AdventureRng"); private static IEnumerable<MethodBase> TargetMethods() { return from pi in typeof(GameRunController).GetProperties() where pi.Name.EndsWith("Rng") select pi.GetMethod; } private static void Postfix(MethodBase __originalMethod, RandomGen __result) { if (__originalMethod.Name.StartsWith("get_Adventure")) { BepinexPlugin.log.LogDebug((object)$"adventureRng state: {((__result != null) ? new ulong?(__result.State) : null)}"); } if (__originalMethod.Name.StartsWith("get_CardRng")) { } if (!__originalMethod.Name.StartsWith("get_DebutRng")) { } } } internal class rollDeez_patch { private static void Prefix() { BepinexPlugin.log.LogDebug((object)"rolling Deez"); } } [HarmonyPatch(typeof(Debut), "InitVariables")] internal class debutdeez_Patch { private static void nuts(RandomGen rng) { BepinexPlugin.log.LogDebug((object)$"true debutRng state: {rng.State}"); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions, ILGenerator generator) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_000d: Expected O, but got Unknown return Helpers.LeaveJumpFix(new CodeMatcher(instructions, (ILGenerator)null)).InstructionEnumeration(); } } internal class naz_Patch { private static void Prefix(int resultIndex) { BepinexPlugin.log.LogDebug((object)$"rez: {resultIndex}"); StackTrace stackTrace = new StackTrace(); BepinexPlugin.log.LogDebug((object)"---------------"); StackFrame[] frames = stackTrace.GetFrames(); foreach (StackFrame stackFrame in frames) { BepinexPlugin.log.LogDebug((object)(stackFrame.GetMethod().DeclaringType.FullName + "::" + stackFrame.GetMethod().Name)); } BepinexPlugin.log.LogDebug((object)"---------------"); } } internal class VnPanel_Patch { private static void Prefix(string command, RuntimeCommandHandler extraCommandHandler) { BepinexPlugin.log.LogDebug((object)$"{command}, {extraCommandHandler}"); } } internal class RandomGenNext_Patch { private static bool CheckSt(StackTrace st) { return st.GetFrames().FirstOrDefault((StackFrame st) => st.GetMethod().Name.Contains("RollCards")) != null; } private static void Prefix(RandomGen __instance) { StackTrace st = new StackTrace(); if (CheckSt(st)) { BepinexPlugin.log.LogDebug((object)$"before{__instance.State}---------------"); } } private static void Postfix(RandomGen __instance) { StackTrace stackTrace = new StackTrace(); if (CheckSt(stackTrace)) { StackFrame[] frames = stackTrace.GetFrames(); foreach (StackFrame stackFrame in frames) { BepinexPlugin.log.LogDebug((object)(stackFrame.GetMethod().DeclaringType.FullName + "::" + stackFrame.GetMethod().Name)); } BepinexPlugin.log.LogDebug((object)$"after{__instance.State}---------------"); } } } internal class Up_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return typeof(UniqueRandomPool<>).MakeGenericType(typeof(Card)).GetMethod("Sample", new Type[1] { typeof(Func<float, float, float>) }); } private static GameRunController Gr() { GameMaster instance = Singleton<GameMaster>.Instance; return (instance != null) ? instance.CurrentGameRun : null; } private static bool CheckSt() { StackTrace stackTrace = new StackTrace(); return stackTrace.GetFrames().FirstOrDefault((StackFrame st) => st.GetMethod().Name.StartsWith("RollCards")) != null; } private static void W1(float w) { if (CheckSt()) { ManualLogSource log = BepinexPlugin.log; GameRunController obj = Gr(); ulong? obj2; if (obj == null) { obj2 = null; } else { RandomGen cardRng = obj.CardRng; obj2 = ((cardRng != null) ? new ulong?(cardRng.State) : null); } log.LogDebug((object)$"state before: {obj2}"); BepinexPlugin.log.LogDebug((object)$"total weights: {w}"); } } private static void W2(float w) { if (CheckSt()) { BepinexPlugin.log.LogDebug((object)$"rolled weight: {w}"); ManualLogSource log = BepinexPlugin.log; GameRunController obj = Gr(); ulong? obj2; if (obj == null) { obj2 = null; } else { RandomGen cardRng = obj.CardRng; obj2 = ((cardRng != null) ? new ulong?(cardRng.State) : null); } log.LogDebug((object)$"state after: {obj2}"); } } private static void PrintCard(object o, string s) { if (o is Type type && type.IsSubclassOf(typeof(Card))) { BepinexPlugin.log.LogDebug((object)(s + type.Name)); BepinexPlugin.log.LogDebug((object)"-----"); } } private static void PrintDefault(object o) { PrintCard(o, "(Default roll) "); } private static void PrintCond(object o) { PrintCard(o, "(Conditional roll) "); } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Expected O, but got Unknown //IL_0035: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Expected O, but got Unknown //IL_0069: Unknown result type (might be due to invalid IL or missing references) //IL_006f: Expected O, but got Unknown //IL_0083: Unknown result type (might be due to invalid IL or missing references) //IL_008d: Expected O, but got Unknown //IL_00a1: Unknown result type (might be due to invalid IL or missing references) //IL_00a7: Expected O, but got Unknown //IL_00d5: Unknown result type (might be due to invalid IL or missing references) //IL_00db: Expected O, but got Unknown //IL_00ef: Unknown result type (might be due to invalid IL or missing references) //IL_00f9: Expected O, but got Unknown //IL_010d: Unknown result type (might be due to invalid IL or missing references) //IL_0113: Expected O, but got Unknown //IL_013b: Unknown result type (might be due to invalid IL or missing references) //IL_0141: Expected O, but got Unknown //IL_015b: Unknown result type (might be due to invalid IL or missing references) //IL_0165: Expected O, but got Unknown //IL_0179: Unknown result type (might be due to invalid IL or missing references) //IL_017f: Expected O, but got Unknown //IL_01a7: Unknown result type (might be due to invalid IL or missing references) //IL_01ad: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Stloc_0, (object)null)) }).Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Dup, (object)null) }).Advance(1) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Up_Patch), "W1", (Type[])null, (Type[])null)) }) .MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Stloc_1, (object)null)) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Dup, (object)null) }) .Advance(1) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Up_Patch), "W2", (Type[])null, (Type[])null)) }) .MatchForward(false, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ret, (object)null)) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Dup, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Up_Patch), "PrintDefault", (Type[])null, (Type[])null)) }) .Advance(1) .MatchForward(false, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ret, (object)null)) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Dup, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Up_Patch), "PrintCond", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } internal class NormalizeWeights_Patch { private static IEnumerable<MethodBase> TargetMethods() { yield return typeof(UniqueRandomPool<>).MakeGenericType(typeof(Card)).GetMethod("Sample", new Type[1] { typeof(Func<float, float, float>) }); } private static float DivideItemWeight(float w, float totalW) { return w / totalW; } private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Expected O, but got Unknown //IL_0033: Unknown result type (might be due to invalid IL or missing references) //IL_003d: Expected O, but got Unknown //IL_0079: Unknown result type (might be due to invalid IL or missing references) //IL_0083: Expected O, but got Unknown //IL_009d: Unknown result type (might be due to invalid IL or missing references) //IL_00a3: Expected O, but got Unknown //IL_00cb: Unknown result type (might be due to invalid IL or missing references) //IL_00d1: Expected O, but got Unknown //IL_00fe: Unknown result type (might be due to invalid IL or missing references) //IL_0108: Expected O, but got Unknown //IL_0122: Unknown result type (might be due to invalid IL or missing references) //IL_0128: Expected O, but got Unknown //IL_0150: Unknown result type (might be due to invalid IL or missing references) //IL_0156: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchForward(true, (CodeMatch[])(object)new CodeMatch[2] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ldc_R4, (object)0f)), CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Ldloc_0, (object)null)) }).Set(OpCodes.Ldc_R4, (object)1f).MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.PropertyGetter(typeof(RandomPoolEntry<Card>), "Weight"))) }) .Advance(1) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc_0, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(NormalizeWeights_Patch), "DivideItemWeight", (Type[])null, (Type[])null)) }) .Advance(1) .MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Callvirt, (object)AccessTools.PropertyGetter(typeof(RandomPoolEntry<Card>), "Weight"))) }) .Advance(1) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldloc_0, (object)null) }) .InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(NormalizeWeights_Patch), "DivideItemWeight", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } public class RngGetDebugCardDef : CardTemplate { public class RngGetDebugCard : Card { private ManaGroup suspendCost; private bool shouldSuspend; public ManaGroup SuspendCost => suspendCost; public bool ShouldSuspend { get { return shouldSuspend; } set { shouldSuspend = value; } } public ManaGroup NaturalCost { get { //IL_000d: Unknown result type (might be due to invalid IL or missing references) //IL_0012: Unknown result type (might be due to invalid IL or missing references) //IL_00b3: Unknown result type (might be due to invalid IL or missing references) //IL_0039: Unknown result type (might be due to invalid IL or missing references) //IL_003f: Unknown result type (might be due to invalid IL or missing references) //IL_0044: Unknown result type (might be due to invalid IL or missing references) //IL_004a: Unknown result type (might be due to invalid IL or missing references) //IL_004f: Unknown result type (might be due to invalid IL or missing references) //IL_0054: Unknown result type (might be due to invalid IL or missing references) //IL_0058: Unknown result type (might be due to invalid IL or missing references) //IL_005d: Unknown result type (might be due to invalid IL or missing references) //IL_0030: Unknown result type (might be due to invalid IL or missing references) //IL_0035: Unknown result type (might be due to invalid IL or missing references) //IL_0069: Unknown result type (might be due to invalid IL or missing references) //IL_006a: Unknown result type (might be due to invalid IL or missing references) //IL_0066: Unknown result type (might be due to invalid IL or missing references) //IL_006f: Unknown result type (might be due to invalid IL or missing references) //IL_0084: Unknown result type (might be due to invalid IL or missing references) //IL_008a: Invalid comparison between Unknown and I4 //IL_00af: Unknown result type (might be due to invalid IL or missing references) //IL_00b0: Unknown result type (might be due to invalid IL or missing references) //IL_0096: Unknown result type (might be due to invalid IL or missing references) //IL_00a2: Unknown result type (might be due to invalid IL or missing references) //IL_00a7: Unknown result type (might be due to invalid IL or missing references) //IL_00ac: Unknown result type (might be due to invalid IL or missing references) if (((Card)this).IsXCost) { return ((Card)this).BaseCost; } if (((Card)this).FreeCost || ((Card)this).Summoned) { return ManaGroup.Empty; } ManaGroup val = ((Card)this).TurnCost + ((Card)this).AdditionalCost + ((Card)this).AuraCost; ManaGroup corrected = ((ManaGroup)(ref val)).Corrected; corrected = (((Card)this).IsPurified ? ManaGroupExtensions.Purified(corrected) : corrected); BattleController battle = ((Card)this).Battle; if (battle != null && battle.ManaFreezeLevel > 0 && (int)((Card)this).Zone == 2) { return corrected + ManaGroup.Anys(((Card)this).Battle.ManaFreezeLevel); } return corrected; } } public override ManaGroup ForceCost => SuspendCost; public override bool IsForceCost { get { //IL_000f: Unknown result type (might be due to invalid IL or missing references) //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_0018: Unknown result type (might be due to invalid IL or missing references) if (((Card)this).Battle != null) { ManaGroup battleMana = ((Card)this).Battle.BattleMana; if (!((ManaGroup)(ref battleMana)).CanAfford(NaturalCost)) { ShouldSuspend = true; ((GameEntity)this).NotifyChanged(); return true; } } ShouldSuspend = false; ((GameEntity)this).NotifyChanged(); return false; } } protected override void OnEnterBattle(BattleController battle) { ((Card)this).OnEnterBattle(battle); } private UniTask<RandomGen> AsyncRng() { //IL_0016: Unknown result type (might be due to invalid IL or missing references) return UniTask.RunOnThreadPool<RandomGen>((Func<RandomGen>)(() => ((GameEntity)this).GameRun.BattleRng), true, default(CancellationToken)); } protected override IEnumerable<BattleAction> Actions(UnitSelector selector, ManaGroup consumingMana, Interaction precondition) { //IL_0016: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) BepinexPlugin.log.LogDebug((object)$"suspend deez: {ShouldSuspend}"); yield break; } public RngGetDebugCard() { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_001b: 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) ManaGroup val = default(ManaGroup); ((ManaGroup)(ref val)).Any = 1; ((ManaGroup)(ref val)).Black = 1; suspendCost = val; shouldSuspend = false; ((Card)this)..ctor(); } } public override IdContainer GetId() { //IL_0005: Unknown result type (might be due to invalid IL or missing references) return IdContainer.op_Implicit("RngGetDebugCard"); } public override CardImages LoadCardImages() { return null; } public override LocalizationOption LoadLocalization() { //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_0030: Expected O, but got Unknown return (LocalizationOption)new DirectLocalization(new Dictionary<string, object> { { "Name", "deez" }, { "Description", "Sus:{ShouldSuspend} ({SuspendCost})\nNat:{NaturalCost}\nActual:{Cost}" } }, (Locale)0, (Locale)0, false); } public override CardConfig MakeConfig() { //IL_0038: Unknown result type (might be due to invalid IL or missing references) //IL_0050: Unknown result type (might be due to invalid IL or missing references) //IL_0173: Unknown result type (might be due to invalid IL or missing references) //IL_0179: Expected O, but got Unknown string[][] array = new string[0][]; TargetType? val = (TargetType)4; List<ManaColor> obj = new List<ManaColor> { (ManaColor)4 }; ManaGroup val2 = default(ManaGroup); ((ManaGroup)(ref val2)).Any = 2; ((ManaGroup)(ref val2)).Black = 2; return new CardConfig(0, "", 10, true, array, "", "", 0, false, true, true, false, true, (Rarity)0, (CardType)3, val, (IReadOnlyList<ManaColor>)obj, false, val2, (ManaGroup?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (ManaGroup?)null, (ManaGroup?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (int?)null, (Keyword)0, (Keyword)0, false, (Keyword)0, (Keyword)0, (IReadOnlyList<string>)new List<string>(), (IReadOnlyList<string>)new List<string>(), (IReadOnlyList<string>)new List<string>(), (IReadOnlyList<string>)new List<string>(), (string)null, "", "", false, (string)null, (IReadOnlyList<string>)new List<string>()); } public static RandomGen StaticRng() { GameRunController obj = GrRngs.Gr(); return (obj != null) ? obj.BattleRng : null; } } public class StatsLogger { [HarmonyPatch] private class InitLog { [HarmonyPatch(typeof(GameRunController), "Create")] [HarmonyPostfix] private static void Postfix(GameRunController __result) { currentGrId = ""; InitAndLogGrInfo(__result); } private static void EarlyInit(GameRunController gr) { InitLogs(gr); } [HarmonyPatch(/*Could not decode attribute arguments.*/)] [HarmonyPriority(300)] [HarmonyTranspiler] private static IEnumerable<CodeInstruction> Transpiler(IEnumerable<CodeInstruction> instructions) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) //IL_002c: Unknown result type (might be due to invalid IL or missing references) //IL_0036: Expected O, but got Unknown //IL_0050: Unknown result type (might be due to invalid IL or missing references) //IL_0056: Expected O, but got Unknown //IL_007e: Unknown result type (might be due to invalid IL or missing references) //IL_0084: Expected O, but got Unknown return new CodeMatcher(instructions, (ILGenerator)null).MatchForward(true, (CodeMatch[])(object)new CodeMatch[1] { CodeMatch.op_Implicit(new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(Gr_InitRngs_Patch), "InitRngs", (Type[])null, (Type[])null))) }).Advance(1).InsertAndAdvance((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Ldarg_0, (object)null) }) .Insert((CodeInstruction[])(object)new CodeInstruction[1] { new CodeInstruction(OpCodes.Call, (object)AccessTools.Method(typeof(InitLog), "EarlyInit", (Type[])null, (Type[])null)) }) .LeaveJumpFix() .InstructionEnumeration(); } } [HarmonyPatch(typeof(GameRunController), "Restore")] [HarmonyPriority(300)] private class RestoreLogs { private static void Postfix(GameRunController __result) { InitLogs(__result); } } public static string[] generalHead = new string[3] { "ManaBase", "Char", "Exhibits" }; public static string[] cardsHeader = new string[7] { "Card", "Rarity", "Colors", "RareFactorAfter", "CardRng", "ShopRng", "UpgradeRng" }; public static string[] addedCardHead = new string[4] { "AddedCard", "Amount", "Rarity", "Colors" }; public static List<KeyValuePair<string, MethodInfo>> vanillaRngsHead = new List<KeyValuePair<string, MethodInfo>>(); public static List<KeyValuePair<string, FieldInfo>> persistentRngsHead = new List<KeyValuePair<string, FieldInfo>>(); public static string[] exHeader = new string[6] { "Exhibit", "Rarity", "Pool", "ExRng", "ShopRng", "AdvRng" }; public static string[] eventHead = new string[2] { "Adventure", "AdvInitRng" }; public static string[] grInfoHead = new string[5] { "GameVersion", "CardValidDebugLevel", "Jadeboxes", "rngFixOptions", "Mods" }; public static string[] rollHead = new string[12] { "ItemW", "WThreshold", "itemProb", "passThreshold", "probabilityFraction", "probabiltyMul", "MaxW", "rawMaxW", "TotalW", "wRollAttempts", "Rolls", "fractionWarning" }; public static string[] commonHead = new string[6] { "Station", "Event", "Stage", "Act", "X", "Y" }; private static MethodInfo mi_rngState = AccessTools.PropertyGetter(typeof(RandomGen), "State"); public static string currentGrId = ""; public static void InitAndLogGrInfo(GameRunController gr) { if (BepinexPlugin.doLoggingConf.Value) { CsvLogger grInfoLog = GetGrInfoLog(gr); grInfoLog.SetHeader((IEnumerable<string>)grInfoHead); grInfoLog.LogHead(); grInfoLog.SetValSafe(VersionInfo.Current.Version, "GameVersion"); grInfoLog.SetValSafe(gr.CardValidDebugLevel, "CardValidDebugLevel"); grInfoLog.SetValSafe(string.Join(";", gr.JadeBoxes.Select((JadeBox jb) => ((GameEntity)jb).Name)), "Jadeboxes"); grInfoLog.SetValSafe(string.Join("|", BepinexPlugin.ignoreFactorsTableConf.Value, BepinexPlugin.doLoggingConf.Value), "rngFixOptions"); grInfoLog.SetValSafe(string.Join(";", Chainloader.PluginInfos.Values.Select((PluginInfo pi) => $"{pi.Metadata.GUID}|{pi.Metadata.Version}")), "Mods"); grInfoLog.FlushVals(); } } public static void LogGeneral(GameRunController gr) { //IL_001e: Unknown result type (might be due to invalid IL or missing references) if (BepinexPlugin.doLoggingConf.Value) { CsvLogger generalLog = GetGeneralLog(gr); generalLog.SetValSafe(gr.BaseMana, "ManaBase"); generalLog.SetValSafe(((GameEntity)gr.Player).Name, "Char"); generalLog.SetValSafe(string.Join("|", gr.Player.Exhibits), "Exhibits"); LogCommonAndFlush(generalLog, gr); } } public static void LogEvent(Type adv, GameRunController gr, SamplerLogInfo li) { if (BepinexPlugin.doLoggingConf.Value) { CsvLogger eventLog = GetEventLog(gr); GrRngs orCreate = GrRngs.GetOrCreate(gr); eventLog.SetValSafe(adv.Name, "Adventure"); eventLog.SetValSafe(orCreate.persRngs.adventureSelfRngs.GetRng(adv.Name).State, "AdvInitRng"); LogRoll(eventLog, li); LogCommonAndFlush(eventLog, gr); } } public static void LogEx(Exhibit ex, GameRunController gr, SamplerLogInfo li) { //IL_0053: Unknown result type (might be due to invalid IL or missing references) //IL_0083: Unknown result type (might be due to invalid IL or missing references) if (BepinexPlugin.doLoggingConf.Value) { CsvLogger exLog = GetExLog(gr); GrRngs orCreate = GrRngs.GetOrCreate(gr); exLog.SetValSafe((ex != null) ? ((GameEntity)ex).Name : null, "Exhibit"); exLog.SetValSafe((ex != null) ? new Rarity?(ex.Config.Rarity) : null, "Rarity"); exLog.SetValSafe((ex != null) ? new AppearanceType?(ex.Config.Appearance) : null, "Pool"); exLog.SetValSafe(gr.ExhibitRng.State, "ExRng"); exLog.SetValSafe(gr.ShopRng.State, "ShopRng"); exLog.SetValSafe(gr.AdventureRng.State, "AdvRng"); LogRoll(exLog, li); LogCommonAndFlush(exLog, gr); } } public static void LogVanillaRngs(GameRunController gr) { if (!BepinexPlugin.doLoggingConf.Value) { return; } CsvLogger vanillaRngsLog = GetVanillaRngsLog(gr); foreach (KeyValuePair<string, MethodInfo> item in vanillaRngsHead) { object obj = item.Value.Invoke(gr, Array.Empty<object>()); ulong num = 0uL; if (obj != null) { num = (ulong)mi_rngState.Invoke(obj, Array.Empty<object>()); } vanillaRngsLog.SetValSafe(num, item.Key); } LogCommonAndFlush(vanillaRngsLog, gr); } public static void LogPersistentRngs(GameRunController gr) { if (!BepinexPlugin.doLoggingConf.Value) { return; } CsvLogger per
Logging.dll
Decompiled 2 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.Serialization; using System.Runtime.Versioning; using System.Security; using System.Security.Permissions; using HarmonyLib; 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: IgnoresAccessChecksTo("LBoL.Base")] [assembly: IgnoresAccessChecksTo("LBoL.ConfigData")] [assembly: IgnoresAccessChecksTo("LBoL.Core")] [assembly: IgnoresAccessChecksTo("LBoL.EntityLib")] [assembly: IgnoresAccessChecksTo("LBoL.Presentation")] [assembly: IgnoresAccessChecksTo("Untitled.ConfigDataBuilder.Base")] [assembly: AssemblyCompany("Logging")] [assembly: AssemblyConfiguration("Debug")] [assembly: AssemblyFileVersion("1.0.0.0")] [assembly: AssemblyInformationalVersion("1.0.0")] [assembly: AssemblyProduct("Logging")] [assembly: AssemblyTitle("Logging")] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("1.0.0.0")] [module: UnverifiableCode] namespace Logging { public sealed class CsvLogger : IDisposable { private static readonly Dictionary<string, CsvLogger> loggers = new Dictionary<string, CsvLogger>(); private static readonly string SessionFolder = $"_{DateTime.Now:yyyy-MM-dd_HH.mm.ss}"; private static ObjectIDGenerator objectAssociations = new ObjectIDGenerator(); private static int assCount = 0; private readonly FileStream _fileStream; private readonly StreamWriter _streamWriter; private readonly object lockObj = new object(); private bool isEnabled = true; public readonly string logFile; public readonly string subFolder; public readonly string fileDir; private List<string> header = new List<string>(); private Dictionary<string, string> values = new Dictionary<string, string>(); private Dictionary<string, bool> valsToSanitize = new Dictionary<string, bool>(); private string emptyValue = "N/A"; public static int AssCount => assCount; public IReadOnlyList<string> Header => header; public IReadOnlyDictionary<string, string> Values => values; public IReadOnlyDictionary<string, bool> ValsToSanitize => valsToSanitize; public string EmptyValue { get { return emptyValue; } set { CollectionExtensions.Do<string>(values.Keys.Where((string k) => values[k] == emptyValue), (Action<string>)delegate(string k) { values[k] = value; }); emptyValue = value; } } public bool IsEnabled { get { return isEnabled; } set { isEnabled = value; } } public CsvLogger(string logFile, string ext = ".csv", string subFolder = "", bool isEnabled = true) { this.logFile = logFile + ext; this.subFolder = subFolder; fileDir = Path.Join((ReadOnlySpan<char>)Application.dataPath, (ReadOnlySpan<char>)".."); fileDir = Path.Join((ReadOnlySpan<char>)fileDir, (ReadOnlySpan<char>)subFolder, (ReadOnlySpan<char>)SessionFolder); Directory.CreateDirectory(fileDir); string path = Path.Join((ReadOnlySpan<char>)fileDir, (ReadOnlySpan<char>)this.logFile); _fileStream = new FileStream(path, FileMode.Create, FileAccess.Write, FileShare.ReadWrite); _streamWriter = new StreamWriter(_fileStream); this.subFolder = subFolder; this.isEnabled = isEnabled; } public static CsvLogger GetOrCreateLog(string logFile, string id, string ext = ".csv", string subFolder = "", bool isEnabled = true) { string key = logFile + id; if (!loggers.TryGetValue(key, out var value)) { value = new CsvLogger(logFile + "_" + assCount, ext, subFolder, isEnabled); loggers[key] = value; } return value; } public static (CsvLogger, long) GetOrCreateLog(string logFile, object ass, string ext = ".csv", string subFolder = "", bool isEnabled = true) { bool firstTime; long id = objectAssociations.GetId(ass, out firstTime); if (firstTime) { assCount++; } CsvLogger orCreateLog = GetOrCreateLog(logFile, id.ToString(), ext, subFolder, isEnabled); return (orCreateLog, id); } public void AddHeaderVal(string valKey) { if (valKey != null && !values.ContainsKey(valKey)) { header.Add(valKey); values.Add(valKey, emptyValue); } } public void SetHeader(IEnumerable<string> collumns) { header.Clear(); values.Clear(); CollectionExtensions.Do<string>(collumns, (Action<string>)delegate(string c) { AddHeaderVal(c); }); } public void LogHead() { Log(header); } public bool SetVal(object val, string valKey, bool doThrow = true) { if (!isEnabled) { return false; } if (values.ContainsKey(valKey)) { values[valKey] = val?.ToString() ?? "null"; return true; } if (doThrow) { throw new ArgumentException("CsvLogger " + logFile + " doesn't have column " + valKey); } return false; } public bool SetVals(IEnumerable<KeyValuePair<string, string>> valsNKeys) { return valsNKeys.Select((KeyValuePair<string, string> kv) => SetVal(kv.Value, kv.Key)).Any(); } public bool HasVals() { return values.Values.Any((string v) => v != emptyValue); } public void FlushVals() { string[] array = new string[header.Count]; int num = 0; foreach (string item in header) { string text = values[item]; if (valsToSanitize.TryGetValue(item, out var value)) { text = SanitizeVal(text, value); } array[num] = text; values[item] = emptyValue; num++; } Log(array); } public bool SetCollumnToSanitize(string key, bool conditional = true) { if (!values.ContainsKey(key)) { return false; } if (!valsToSanitize.TryAdd(key, conditional)) { valsToSanitize[key] = conditional; } return true; } public static string SanitizeVal(string val, bool conditional) { bool flag = true; if (conditional) { flag = val.Contains(","); } return flag ? ("\"" + val + "\"") : val; } public void Log(IEnumerable<object> values) { Log(string.Join(", ", values)); } public void Log(string message) { if (!IsEnabled) { return; } lock (lockObj) { _streamWriter.WriteLine(message); _streamWriter.Flush(); } } public void Dispose() { lock (lockObj) { _streamWriter?.Dispose(); _fileStream?.Dispose(); } } } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)] internal sealed class IgnoresAccessChecksToAttribute : Attribute { internal IgnoresAccessChecksToAttribute(string assemblyName) { } } }