using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Diagnostics;
using System.Diagnostics.CodeAnalysis;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.Versioning;
using System.Security;
using System.Security.Permissions;
using BepInEx;
using BepInEx.Bootstrap;
using BepInEx.Configuration;
using BepInEx.Logging;
using HarmonyLib;
using Microsoft.CodeAnalysis;
using ObjectGrabber;
using Timer;
using UnityEngine;
[assembly: CompilationRelaxations(8)]
[assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)]
[assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)]
[assembly: TargetFramework(".NETFramework,Version=v4.8", FrameworkDisplayName = ".NET Framework 4.8")]
[assembly: AssemblyCompany("ObjectGrabberPLCCRestart")]
[assembly: AssemblyConfiguration("Release")]
[assembly: AssemblyFileVersion("1.0.2.0")]
[assembly: AssemblyInformationalVersion("1.0.2+88b6c6dc65e72a6eb20b71845dbee5124ee8da12")]
[assembly: AssemblyProduct("ObjectGrabberPLCCRestart")]
[assembly: AssemblyTitle("ObjectGrabberPLCCRestart")]
[assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)]
[assembly: AssemblyVersion("1.0.2.0")]
[module: UnverifiableCode]
[module: RefSafetyRules(11)]
namespace Microsoft.CodeAnalysis
{
[CompilerGenerated]
[Microsoft.CodeAnalysis.Embedded]
internal sealed class EmbeddedAttribute : Attribute
{
}
}
namespace System.Runtime.CompilerServices
{
[CompilerGenerated]
[Microsoft.CodeAnalysis.Embedded]
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)]
internal sealed class NullableAttribute : Attribute
{
public readonly byte[] NullableFlags;
public NullableAttribute(byte P_0)
{
NullableFlags = new byte[1] { P_0 };
}
public NullableAttribute(byte[] P_0)
{
NullableFlags = P_0;
}
}
[CompilerGenerated]
[Microsoft.CodeAnalysis.Embedded]
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)]
internal sealed class NullableContextAttribute : Attribute
{
public readonly byte Flag;
public NullableContextAttribute(byte P_0)
{
Flag = P_0;
}
}
[CompilerGenerated]
[Microsoft.CodeAnalysis.Embedded]
[AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)]
internal sealed class RefSafetyRulesAttribute : Attribute
{
public readonly int Version;
public RefSafetyRulesAttribute(int P_0)
{
Version = P_0;
}
}
}
namespace System
{
[ExcludeFromCodeCoverage]
internal readonly struct Index : IEquatable<Index>
{
private static class ThrowHelper
{
[DoesNotReturn]
public static void ThrowValueArgumentOutOfRange_NeedNonNegNumException()
{
throw new ArgumentOutOfRangeException("value", "Non-negative number required.");
}
}
private readonly int _value;
public static Index Start => new Index(0);
public static Index End => new Index(-1);
public int Value
{
get
{
if (_value < 0)
{
return ~_value;
}
return _value;
}
}
public bool IsFromEnd => _value < 0;
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public Index(int value, bool fromEnd = false)
{
if (value < 0)
{
ThrowHelper.ThrowValueArgumentOutOfRange_NeedNonNegNumException();
}
if (fromEnd)
{
_value = ~value;
}
else
{
_value = value;
}
}
private Index(int value)
{
_value = value;
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static Index FromStart(int value)
{
if (value < 0)
{
ThrowHelper.ThrowValueArgumentOutOfRange_NeedNonNegNumException();
}
return new Index(value);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static Index FromEnd(int value)
{
if (value < 0)
{
ThrowHelper.ThrowValueArgumentOutOfRange_NeedNonNegNumException();
}
return new Index(~value);
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public int GetOffset(int length)
{
int num = _value;
if (IsFromEnd)
{
num += length + 1;
}
return num;
}
public override bool Equals([NotNullWhen(true)] object? value)
{
if (value is Index)
{
return _value == ((Index)value)._value;
}
return false;
}
public bool Equals(Index other)
{
return _value == other._value;
}
public override int GetHashCode()
{
return _value;
}
public static implicit operator Index(int value)
{
return FromStart(value);
}
public override string ToString()
{
if (IsFromEnd)
{
return ToStringFromEnd();
}
return ((uint)Value).ToString();
}
private string ToStringFromEnd()
{
return "^" + Value;
}
}
[ExcludeFromCodeCoverage]
internal readonly struct Range : IEquatable<Range>
{
private static class HashHelpers
{
public static int Combine(int h1, int h2)
{
return (((h1 << 5) | (h1 >>> 27)) + h1) ^ h2;
}
}
private static class ThrowHelper
{
[DoesNotReturn]
public static void ThrowArgumentOutOfRangeException()
{
throw new ArgumentOutOfRangeException("length");
}
}
public Index Start { get; }
public Index End { get; }
public static Range All => Index.Start..Index.End;
public Range(Index start, Index end)
{
Start = start;
End = end;
}
public override bool Equals([NotNullWhen(true)] object? value)
{
if (value is Range range && range.Start.Equals(Start))
{
return range.End.Equals(End);
}
return false;
}
public bool Equals(Range other)
{
if (other.Start.Equals(Start))
{
return other.End.Equals(End);
}
return false;
}
public override int GetHashCode()
{
return HashHelpers.Combine(Start.GetHashCode(), End.GetHashCode());
}
public override string ToString()
{
return Start.ToString() + ".." + End;
}
public static Range StartAt(Index start)
{
return start..Index.End;
}
public static Range EndAt(Index end)
{
return Index.Start..end;
}
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public (int Offset, int Length) GetOffsetAndLength(int length)
{
Index start = Start;
int num = ((!start.IsFromEnd) ? start.Value : (length - start.Value));
Index end = End;
int num2 = ((!end.IsFromEnd) ? end.Value : (length - end.Value));
if ((uint)num2 > (uint)length || (uint)num > (uint)num2)
{
ThrowHelper.ThrowArgumentOutOfRangeException();
}
return (num, num2 - num);
}
}
}
namespace System.Runtime.Versioning
{
[AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface | AttributeTargets.Delegate, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class RequiresPreviewFeaturesAttribute : Attribute
{
public string? Message { get; }
public string? Url { get; set; }
public RequiresPreviewFeaturesAttribute()
{
}
public RequiresPreviewFeaturesAttribute(string? message)
{
Message = message;
}
}
}
namespace System.Runtime.CompilerServices
{
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, Inherited = false, AllowMultiple = false)]
[ExcludeFromCodeCoverage]
internal sealed class AsyncMethodBuilderAttribute : Attribute
{
public Type BuilderType { get; }
public AsyncMethodBuilderAttribute(Type builderType)
{
BuilderType = builderType;
}
}
[AttributeUsage(AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class CallerArgumentExpressionAttribute : Attribute
{
public string ParameterName { get; }
public CallerArgumentExpressionAttribute(string parameterName)
{
ParameterName = parameterName;
}
}
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Interface, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class CollectionBuilderAttribute : Attribute
{
public Type BuilderType { get; }
public string MethodName { get; }
public CollectionBuilderAttribute(Type builderType, string methodName)
{
BuilderType = builderType;
MethodName = methodName;
}
}
[AttributeUsage(AttributeTargets.All, AllowMultiple = true, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class CompilerFeatureRequiredAttribute : Attribute
{
public const string RefStructs = "RefStructs";
public const string RequiredMembers = "RequiredMembers";
public string FeatureName { get; }
public bool IsOptional { get; set; }
public CompilerFeatureRequiredAttribute(string featureName)
{
FeatureName = featureName;
}
}
[AttributeUsage(AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class InterpolatedStringHandlerArgumentAttribute : Attribute
{
public string[] Arguments { get; }
public InterpolatedStringHandlerArgumentAttribute(string argument)
{
Arguments = new string[1] { argument };
}
public InterpolatedStringHandlerArgumentAttribute(params string[] arguments)
{
Arguments = arguments;
}
}
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class InterpolatedStringHandlerAttribute : Attribute
{
}
[EditorBrowsable(EditorBrowsableState.Never)]
[ExcludeFromCodeCoverage]
internal static class IsExternalInit
{
}
[AttributeUsage(AttributeTargets.Method, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class ModuleInitializerAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class OverloadResolutionPriorityAttribute : Attribute
{
public int Priority { get; }
public OverloadResolutionPriorityAttribute(int priority)
{
Priority = priority;
}
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = true, AllowMultiple = false)]
[ExcludeFromCodeCoverage]
internal sealed class ParamCollectionAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class RequiredMemberAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
[EditorBrowsable(EditorBrowsableState.Never)]
[ExcludeFromCodeCoverage]
internal sealed class RequiresLocationAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Event | AttributeTargets.Interface, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class SkipLocalsInitAttribute : Attribute
{
}
}
namespace System.Diagnostics.CodeAnalysis
{
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class AllowNullAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class ConstantExpectedAttribute : Attribute
{
public object? Min { get; set; }
public object? Max { get; set; }
}
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class DisallowNullAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Method, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class DoesNotReturnAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class DoesNotReturnIfAttribute : Attribute
{
public bool ParameterValue { get; }
public DoesNotReturnIfAttribute(bool parameterValue)
{
ParameterValue = parameterValue;
}
}
[AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface | AttributeTargets.Delegate, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class ExperimentalAttribute : Attribute
{
public string DiagnosticId { get; }
public string? UrlFormat { get; set; }
public ExperimentalAttribute(string diagnosticId)
{
DiagnosticId = diagnosticId;
}
}
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter | AttributeTargets.ReturnValue, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class MaybeNullAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class MaybeNullWhenAttribute : Attribute
{
public bool ReturnValue { get; }
public MaybeNullWhenAttribute(bool returnValue)
{
ReturnValue = returnValue;
}
}
[AttributeUsage(AttributeTargets.Method | AttributeTargets.Property, Inherited = false, AllowMultiple = true)]
[ExcludeFromCodeCoverage]
internal sealed class MemberNotNullAttribute : Attribute
{
public string[] Members { get; }
public MemberNotNullAttribute(string member)
{
Members = new string[1] { member };
}
public MemberNotNullAttribute(params string[] members)
{
Members = members;
}
}
[AttributeUsage(AttributeTargets.Method | AttributeTargets.Property, Inherited = false, AllowMultiple = true)]
[ExcludeFromCodeCoverage]
internal sealed class MemberNotNullWhenAttribute : Attribute
{
public bool ReturnValue { get; }
public string[] Members { get; }
public MemberNotNullWhenAttribute(bool returnValue, string member)
{
ReturnValue = returnValue;
Members = new string[1] { member };
}
public MemberNotNullWhenAttribute(bool returnValue, params string[] members)
{
ReturnValue = returnValue;
Members = members;
}
}
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter | AttributeTargets.ReturnValue, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class NotNullAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Parameter | AttributeTargets.ReturnValue, AllowMultiple = true, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class NotNullIfNotNullAttribute : Attribute
{
public string ParameterName { get; }
public NotNullIfNotNullAttribute(string parameterName)
{
ParameterName = parameterName;
}
}
[AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class NotNullWhenAttribute : Attribute
{
public bool ReturnValue { get; }
public NotNullWhenAttribute(bool returnValue)
{
ReturnValue = returnValue;
}
}
[AttributeUsage(AttributeTargets.Constructor, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class SetsRequiredMembersAttribute : Attribute
{
}
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class StringSyntaxAttribute : Attribute
{
public const string CompositeFormat = "CompositeFormat";
public const string DateOnlyFormat = "DateOnlyFormat";
public const string DateTimeFormat = "DateTimeFormat";
public const string EnumFormat = "EnumFormat";
public const string GuidFormat = "GuidFormat";
public const string Json = "Json";
public const string NumericFormat = "NumericFormat";
public const string Regex = "Regex";
public const string TimeOnlyFormat = "TimeOnlyFormat";
public const string TimeSpanFormat = "TimeSpanFormat";
public const string Uri = "Uri";
public const string Xml = "Xml";
public string Syntax { get; }
public object?[] Arguments { get; }
public StringSyntaxAttribute(string syntax)
{
Syntax = syntax;
Arguments = new object[0];
}
public StringSyntaxAttribute(string syntax, params object?[] arguments)
{
Syntax = syntax;
Arguments = arguments;
}
}
[AttributeUsage(AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)]
[ExcludeFromCodeCoverage]
internal sealed class UnscopedRefAttribute : Attribute
{
}
}
namespace ObjectGrabberPLCCRestart
{
[BepInPlugin("tld.kirisoup.hff.ObjectGrabberPLCCRestart", "ObjectGrabberPLCCRestart", "1.0.2")]
[BepInProcess("Human.exe")]
[BepInDependency("top.zman350x.hff.objectgrabber", "1.3.1")]
[BepInDependency(/*Could not decode attribute arguments.*/)]
public sealed class Plugin : BaseUnityPlugin
{
public const string NAME = "ObjectGrabberPLCCRestart";
public const string GUID = "tld.kirisoup.hff.ObjectGrabberPLCCRestart";
private const string OBJECT_GRABBER_GUID = "top.zman350x.hff.objectgrabber";
private const string PLCC_TIMER_GUID = "com.plcc.hff.timer";
private const string CMD_KEY = "grab_autoreset";
private static Plugin? _instance;
private static ManualLogSource? _logger;
private bool _timerRunning;
private ConfigEntry<bool> _enabled;
public static Plugin Instance => _instance ?? throw new InvalidOperationException("Plugin \"tld.kirisoup.hff.ObjectGrabberPLCCRestart\" is not instanciated yet. ");
public static ManualLogSource Logger => _logger ?? throw new InvalidOperationException("Plugin \"tld.kirisoup.hff.ObjectGrabberPLCCRestart\" is not instanciated yet. ");
private Plugin()
{
if (_instance != null)
{
Object.Destroy((Object)(object)this);
throw new InvalidOperationException("Plugin \"tld.kirisoup.hff.ObjectGrabberPLCCRestart\" is already instanciated. ");
}
_instance = this;
_logger = ((BaseUnityPlugin)this).Logger;
}
private void Awake()
{
if (!Chainloader.PluginInfos.ContainsKey("com.plcc.hff.timer"))
{
Logger.LogWarning((object)"Plugin \"com.plcc.hff.timer\" is not loaded, ObjectGrabberPLCCRestart will do nothing. ");
((Behaviour)this).enabled = false;
}
else
{
_enabled = ((BaseUnityPlugin)this).Config.Bind<bool>("General", "Enabled", true, "Whether would the grab count auto-reset when plcc-timer restarts. ");
RegisterCommand();
}
}
private void Start()
{
_timerRunning = Main.timer.timerRunning;
}
private void FixedUpdate()
{
if (_enabled.Value)
{
bool timerRunning = _timerRunning;
_timerRunning = Main.timer.timerRunning;
if (!timerRunning && _timerRunning)
{
GrabberTracker.instance.ResetGrabCounter(false);
Shell.Print("Grab counter auto-reset");
}
}
}
private void OnDestroy()
{
UnregisterCommand();
}
private void RegisterCommand()
{
Shell.RegisterCommand("grab_autoreset", (Action<string>)delegate(string str)
{
string text = Interact(str, _enabled);
if (text != null)
{
Shell.Print(text);
}
}, "Configures auto-reset on/off. ");
static string? Interact(string? str, ConfigEntry<bool> entry)
{
string[] array = str?.ToLowerInvariant().Split(new char[1] { ' ' }, StringSplitOptions.RemoveEmptyEntries);
int? num = array?.Length;
if (!num.HasValue || num.GetValueOrDefault() != 1)
{
return $"Expected 1 argument but {((array != null) ? array.Length : 0)} is fed";
}
(bool, string) tuple;
switch (array[0])
{
case "h":
case "help":
tuple = (entry.Value, "Syntax: `grab_autoreset <option>`\r\nAvailable options:\r\n\t<u>h</u>elp\r\n\t<u>i</u>nspect\r\n\t<u>t</u>oggle\r\n\t<u>e</u>nable (on)\r\n\t<u>d</u>isable (off)");
break;
case "i":
case "inspect":
tuple = (entry.Value, "auto-reset is currently " + (entry.Value ? "enabled" : "disabled") + ". ");
break;
case "t":
case "toggle":
tuple = (!entry.Value, "toggled auto-reset " + (entry.Value ? "off" : "on") + ". ");
break;
case "d":
case "disable":
case "off":
tuple = (false, "disabled auto-reset. ");
break;
case "e":
case "enable":
case "on":
tuple = (true, "enabled auto-reset. ");
break;
default:
tuple = (entry.Value, "Argument must be one of the following: help, query, toggle, disable(off), enable(on). ");
break;
}
(bool, string) tuple2 = tuple;
(entry.Value, _) = tuple2;
return tuple2.Item2;
}
}
private static void UnregisterCommand()
{
object obj = AccessTools.Field(typeof(Shell), "commands")?.GetValue(null);
(AccessTools.Field(typeof(CommandRegistry), "commandsStr")?.GetValue(obj) as Dictionary<string, Action<string>>)?.Remove("grab_autoreset");
}
}
public static class PluginInfo
{
public const string PLUGIN_GUID = "ObjectGrabberPLCCRestart";
public const string PLUGIN_NAME = "ObjectGrabberPLCCRestart";
public const string PLUGIN_VERSION = "1.0.2";
}
}