using System;
using System.Diagnostics;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.Versioning;
using BepInEx;
using BepInEx.Logging;
using BepInEx.Unity.IL2CPP;
using ChainedPuzzles;
using HarmonyLib;
using Il2CppInterop.Runtime.InteropTypes;
using Il2CppInterop.Runtime.InteropTypes.Arrays;
using Microsoft.CodeAnalysis;
[assembly: CompilationRelaxations(8)]
[assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)]
[assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)]
[assembly: TargetFramework(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")]
[assembly: AssemblyCompany("ConsistentScanSpeed")]
[assembly: AssemblyConfiguration("Release")]
[assembly: AssemblyFileVersion("1.0.0.0")]
[assembly: AssemblyInformationalVersion("1.0.0")]
[assembly: AssemblyProduct("ConsistentScanSpeed")]
[assembly: AssemblyTitle("ConsistentScanSpeed")]
[assembly: AssemblyVersion("1.0.0.0")]
namespace Microsoft.CodeAnalysis
{
[CompilerGenerated]
[Microsoft.CodeAnalysis.Embedded]
internal sealed class EmbeddedAttribute : Attribute
{
}
}
namespace System.Runtime.CompilerServices
{
[CompilerGenerated]
[Microsoft.CodeAnalysis.Embedded]
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)]
internal sealed class NullableAttribute : Attribute
{
public readonly byte[] NullableFlags;
public NullableAttribute(byte P_0)
{
NullableFlags = new byte[1] { P_0 };
}
public NullableAttribute(byte[] P_0)
{
NullableFlags = P_0;
}
}
[CompilerGenerated]
[Microsoft.CodeAnalysis.Embedded]
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)]
internal sealed class NullableContextAttribute : Attribute
{
public readonly byte Flag;
public NullableContextAttribute(byte P_0)
{
Flag = P_0;
}
}
}
namespace ConsistentScanSpeed
{
[BepInPlugin("Dinorush.ConsistentScanSpeed", "ConsistentScanSpeed", "1.0.0")]
internal sealed class EntryPoint : BasePlugin
{
public const string MODNAME = "ConsistentScanSpeed";
public override void Load()
{
//IL_0015: Unknown result type (might be due to invalid IL or missing references)
((BasePlugin)this).Log.LogMessage((object)"Loading ConsistentScanSpeed");
new Harmony("ConsistentScanSpeed").PatchAll();
((BasePlugin)this).Log.LogMessage((object)"Loaded ConsistentScanSpeed");
}
}
[HarmonyPatch]
internal static class ScanPatch
{
[HarmonyPatch(typeof(CP_Bioscan_Core), "Setup")]
[HarmonyPostfix]
private static void SetUniformScanTime(CP_Bioscan_Core __instance)
{
CP_PlayerScanner val = ((Il2CppObjectBase)__instance.m_playerScanner).Cast<CP_PlayerScanner>();
Il2CppStructArray<float> scanSpeeds = val.m_scanSpeeds;
float num = ((Il2CppArrayBase<float>)(object)scanSpeeds)[((Il2CppArrayBase<float>)(object)scanSpeeds).Length - 1];
for (int i = 0; i < ((Il2CppArrayBase<float>)(object)val.m_scanSpeeds).Length; i++)
{
((Il2CppArrayBase<float>)(object)val.m_scanSpeeds)[i] = num;
}
}
}
}
namespace ConsistentScanSpeed.Utils
{
internal static class DinoLogger
{
private static ManualLogSource logger = Logger.CreateLogSource("ConsistentScanSpeed");
public static void Log(string format, params object[] args)
{
Log(string.Format(format, args));
}
public static void Log(string str)
{
if (logger != null)
{
logger.Log((LogLevel)8, (object)str);
}
}
public static void Warning(string format, params object[] args)
{
Warning(string.Format(format, args));
}
public static void Warning(string str)
{
if (logger != null)
{
logger.Log((LogLevel)4, (object)str);
}
}
public static void Error(string format, params object[] args)
{
Error(string.Format(format, args));
}
public static void Error(string str)
{
if (logger != null)
{
logger.Log((LogLevel)2, (object)str);
}
}
public static void Debug(string format, params object[] args)
{
Debug(string.Format(format, args));
}
public static void Debug(string str)
{
if (logger != null)
{
logger.Log((LogLevel)32, (object)str);
}
}
}
}