Decompiled source of ForceRadiance 1x v1.0.1

ForceRadiance_1x.dll

Decompiled a month ago
using System;
using System.Diagnostics;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.Versioning;
using System.Security;
using System.Security.Permissions;
using BepInEx;
using BepInEx.Logging;
using Configgy;
using HarmonyLib;
using Microsoft.CodeAnalysis;
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(".NETFramework,Version=v4.7.2", FrameworkDisplayName = ".NET Framework 4.7.2")]
[assembly: IgnoresAccessChecksTo("Assembly-CSharp")]
[assembly: AssemblyCompany("Force Radiance 1x damage")]
[assembly: AssemblyConfiguration("Debug")]
[assembly: AssemblyFileVersion("1.0.0.0")]
[assembly: AssemblyInformationalVersion("1.0.0")]
[assembly: AssemblyProduct("ForceRadiance 1x damage")]
[assembly: AssemblyTitle("Force Radiance 1x damage")]
[assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)]
[assembly: AssemblyVersion("1.0.0.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.Module, AllowMultiple = false, Inherited = false)]
	internal sealed class RefSafetyRulesAttribute : Attribute
	{
		public readonly int Version;

		public RefSafetyRulesAttribute(int P_0)
		{
			Version = P_0;
		}
	}
}
namespace ForceRadiance
{
	[BepInPlugin("com.nkmi.forceradiance", "ForceRadiance 1x damage", "1.0.0")]
	[BepInDependency(/*Could not decode attribute arguments.*/)]
	public class Plugin : BaseUnityPlugin
	{
		internal static ManualLogSource Logger;

		private ConfigBuilder config;

		private void Awake()
		{
			//IL_0027: Unknown result type (might be due to invalid IL or missing references)
			//IL_0031: Expected O, but got Unknown
			Logger = ((BaseUnityPlugin)this).Logger;
			Logger.LogInfo((object)"nkmi ForceRadiance loaded :3");
			config = new ConfigBuilder("com.nkmi.forceradiance", "ForceRadiance");
			config.BuildAll();
		}

		private void Start()
		{
			//IL_0006: Unknown result type (might be due to invalid IL or missing references)
			new Harmony("com.nkmi.forceradiance").PatchAll();
		}
	}
	public static class ForceRadianceConfig
	{
		[Configgable("", "Force Radiance", 0, null)]
		public static ConfigToggle radianceToggle = new ConfigToggle(false);

		[Configgable("", "Radiance Tier", 0, null)]
		public static float radianceTier = 1f;

		[Configgable("", "1x Damage", 0, null)]
		public static ConfigToggle disableDamageModToggle = new ConfigToggle(false);
	}
	[HarmonyPatch]
	public static class Patches
	{
		private static bool isDamageModDisabled;

		[HarmonyPostfix]
		[HarmonyPatch(typeof(OptionsManager), "Update")]
		private static void OptionsManager_Update_Postfix()
		{
			bool value = ((ConfigValueElement<bool>)(object)ForceRadianceConfig.radianceToggle).Value;
			float radianceTier = ForceRadianceConfig.radianceTier;
			bool value2 = ((ConfigValueElement<bool>)(object)ForceRadianceConfig.disableDamageModToggle).Value;
			if (value != OptionsManager.forceRadiance || radianceTier != OptionsManager.radianceTier || value2 != isDamageModDisabled)
			{
				updateRadiance(value, radianceTier, value2);
			}
		}

		private static void updateRadiance(bool isEnabled, float radianceTier, bool disableDamageModSetting)
		{
			if (isEnabled)
			{
				MonoSingleton<AssistController>.Instance.cheatsEnabled = true;
			}
			OptionsManager.forceRadiance = isEnabled;
			OptionsManager.radianceTier = radianceTier;
			isDamageModDisabled = disableDamageModSetting;
			EnemyIdentifier[] array = Object.FindObjectsOfType<EnemyIdentifier>();
			foreach (EnemyIdentifier val in array)
			{
				val.UpdateBuffs(false, true);
			}
		}

		[HarmonyPrefix]
		[HarmonyPatch(typeof(EnemyIdentifier), "UpdateModifiers")]
		private static bool EnemyIdentifier_UpdateModifiers_Prefix(EnemyIdentifier __instance)
		{
			__instance.totalSpeedModifier = 1f;
			__instance.totalHealthModifier = 1f;
			__instance.totalDamageModifier = 1f;
			float num = Mathf.Max(OptionsManager.radianceTier, __instance.radianceTier);
			if (__instance.speedBuff || OptionsManager.forceRadiance)
			{
				float num2 = ((num > 1f) ? (0.75f + num / 4f) : num);
				__instance.totalSpeedModifier *= __instance.speedBuffModifier * num2;
			}
			if (__instance.healthBuff || OptionsManager.forceRadiance)
			{
				float num3 = ((num > 1f) ? (0.75f + num / 4f) : num);
				__instance.totalHealthModifier *= __instance.healthBuffModifier * num3;
			}
			if (__instance.damageBuff || (OptionsManager.forceRadiance && !isDamageModDisabled))
			{
				__instance.totalDamageModifier *= __instance.damageBuffModifier;
			}
			if (__instance.puppet)
			{
				__instance.totalHealthModifier /= 2f;
				__instance.totalSpeedModifier *= Mathf.Lerp(0f, Mathf.Max(0f, __instance.puppetSpawnTimer - 0.75f) * 3f, __instance.puppetSpawnTimer);
			}
			return false;
		}
	}
	public static class PluginInfo
	{
		public const string PLUGIN_GUID = "Force Radiance 1x damage";

		public const string PLUGIN_NAME = "ForceRadiance 1x damage";

		public const string PLUGIN_VERSION = "1.0.0";
	}
}
namespace System.Runtime.CompilerServices
{
	[AttributeUsage(AttributeTargets.Assembly, AllowMultiple = true)]
	internal sealed class IgnoresAccessChecksToAttribute : Attribute
	{
		internal IgnoresAccessChecksToAttribute(string assemblyName)
		{
		}
	}
}