Decompiled source of NoWeaponsGlow v1.0.4

plugins/NoWeaponsGlow.dll

Decompiled 3 weeks ago
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using System.Runtime.Versioning;
using System.Security.Permissions;
using BepInEx;
using BepInEx.Configuration;
using Jotunn;
using Jotunn.Entities;
using Jotunn.Managers;
using Jotunn.Utils;
using NoWeaponsGlow.Common;
using NoWeaponsGlow.Prefabs;
using NoWeaponsGlow.Prefabs.Code;
using UnityEngine;

[assembly: CompilationRelaxations(8)]
[assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)]
[assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)]
[assembly: AssemblyTitle("NoWeaponsGlow")]
[assembly: AssemblyDescription("Disables glow of various weapons in Valheim.")]
[assembly: AssemblyConfiguration("")]
[assembly: AssemblyCompany("")]
[assembly: AssemblyProduct("NoWeaponsGlow")]
[assembly: AssemblyCopyright("")]
[assembly: AssemblyTrademark("")]
[assembly: ComVisible(false)]
[assembly: Guid("748670d6-f89a-325f-037b-502ec1c79424")]
[assembly: AssemblyFileVersion("1.0.4.0")]
[assembly: TargetFramework(".NETFramework,Version=v4.6.2", FrameworkDisplayName = ".NET Framework 4.6.2")]
[assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)]
[assembly: AssemblyVersion("1.0.4.0")]
internal static class PluginInfo
{
	public const string PluginGUID = "noglow.NoWeaponsGlow";

	public const string PluginName = "NoWeaponsGlow";

	public const string PluginDescription = "Disables glow of various weapons in Valheim.";

	public const string PluginVersion = "1.0.4";
}
namespace NoWeaponsGlow
{
	internal class PluginConfig
	{
		public static ConfigFile File;

		public static ConfigEntry<bool> DisableGlowOnDraugarFang;

		public static ConfigEntry<bool> DisableGlowOnSpineSnap;

		public static ConfigEntry<bool> DisableGlowOnFrostner;

		public static ConfigEntry<bool> DisableGlowOnCrystalBattleaxe;

		public static ConfigEntry<bool> DisableGlowOnMistwalker;

		public static ConfigEntry<bool> DisableGlowOnPorcupine;

		public static ConfigEntry<bool> DisableGlowOnJotunBane;

		public static ConfigEntry<bool> DisableGlowOnHimminafl;

		public static ConfigEntry<bool> DisableGlowOnStaffOfEmbers;

		public static ConfigEntry<bool> DisableGlowOnStaffOfFrost;

		public static ConfigEntry<bool> DisableGlowOnStaffOfProtection;

		public static ConfigEntry<bool> DisableGlowOnStaffOfTheWild;

		public static ConfigEntry<bool> DisableGlowOnDeadRaiser;

		public static ConfigEntry<bool> DisableGlowOnDyrnwyn;

		public static void Bind(ConfigFile config)
		{
			if (File == null)
			{
				File = config;
				DisableGlowOnDraugarFang = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Draugar Fang", true, "Draugar Fang"));
				DisableGlowOnSpineSnap = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Spine snap", true, "Spine Snap"));
				DisableGlowOnFrostner = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Frostner", true, "Frostner"));
				DisableGlowOnCrystalBattleaxe = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Crystal Battleaxe", true, "Crystal Battleaxe"));
				DisableGlowOnMistwalker = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Mistwalker", true, "Mistwalker"));
				DisableGlowOnPorcupine = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Porcupine", true, "Porcupine"));
				DisableGlowOnJotunBane = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Jotun Bane", true, "Jotun Bane"));
				DisableGlowOnHimminafl = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Himminafl", true, "Himminafl"));
				DisableGlowOnStaffOfEmbers = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Staff of Embers", true, "Staff of Embers"));
				DisableGlowOnStaffOfFrost = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Staff of Frost", true, "Staff of Frost"));
				DisableGlowOnStaffOfProtection = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Staff of Protection", true, "Staff of Protection"));
				DisableGlowOnStaffOfTheWild = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Staff of the Wild", true, "Staff of the Wild"));
				DisableGlowOnDeadRaiser = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Dead Raiser", true, "Dead Raiser"));
				DisableGlowOnDyrnwyn = WithChangedHandler(config.Bind<bool>("Disable glow and effects", "Dyrnwyn", true, "Dyrnwyn"));
			}
		}

		private static ConfigEntry<bool> WithChangedHandler(ConfigEntry<bool> configEntry)
		{
			if (configEntry != null)
			{
				configEntry.SettingChanged += OnSettingsChanged;
			}
			return configEntry;
		}

		private static void OnSettingsChanged(object sender, EventArgs e)
		{
			Controller.UpdatePrefabs();
		}
	}
	internal static class Flags
	{
		public static PrefabState DraugarFang;

		public static PrefabState SpineSnap;

		public static PrefabState Frostner;

		public static PrefabState CrystalBattleaxe;

		public static PrefabState Mistwalker;

		public static PrefabState Porcupine;

		public static PrefabState JotunBane;

		public static PrefabState Himminafl;

		public static PrefabState StaffOfEmbers;

		public static PrefabState StaffOfFrost;

		public static PrefabState StaffOfProtection;

		public static PrefabState StaffOfTheWild;

		public static PrefabState DeadRaiser;

		public static PrefabState Dyrnwyn;

		public static bool Evaluate()
		{
			bool flag = false;
			flag = Evaluate(ref DraugarFang, PluginConfig.DisableGlowOnDraugarFang.Value) || flag;
			flag = Evaluate(ref SpineSnap, PluginConfig.DisableGlowOnSpineSnap.Value) || flag;
			flag = Evaluate(ref Frostner, PluginConfig.DisableGlowOnFrostner.Value) || flag;
			flag = Evaluate(ref CrystalBattleaxe, PluginConfig.DisableGlowOnCrystalBattleaxe.Value) || flag;
			flag = Evaluate(ref Mistwalker, PluginConfig.DisableGlowOnMistwalker.Value) || flag;
			flag = Evaluate(ref Porcupine, PluginConfig.DisableGlowOnPorcupine.Value) || flag;
			flag = Evaluate(ref JotunBane, PluginConfig.DisableGlowOnJotunBane.Value) || flag;
			flag = Evaluate(ref Himminafl, PluginConfig.DisableGlowOnHimminafl.Value) || flag;
			flag = Evaluate(ref StaffOfEmbers, PluginConfig.DisableGlowOnStaffOfEmbers.Value) || flag;
			flag = Evaluate(ref StaffOfFrost, PluginConfig.DisableGlowOnStaffOfFrost.Value) || flag;
			flag = Evaluate(ref StaffOfProtection, PluginConfig.DisableGlowOnStaffOfProtection.Value) || flag;
			flag = Evaluate(ref StaffOfTheWild, PluginConfig.DisableGlowOnStaffOfTheWild.Value) || flag;
			flag = Evaluate(ref DeadRaiser, PluginConfig.DisableGlowOnDeadRaiser.Value) || flag;
			return Evaluate(ref Dyrnwyn, PluginConfig.DisableGlowOnDyrnwyn.Value) || flag;
		}

		private static bool Evaluate(ref PrefabState state, bool config)
		{
			if (state == PrefabState.Unknown)
			{
				state = (config ? PrefabState.ToModify : PrefabState.ToRestore);
				return true;
			}
			if (config)
			{
				if (state == PrefabState.Modified)
				{
					return false;
				}
				state = PrefabState.ToModify;
				return true;
			}
			if (state == PrefabState.Restored)
			{
				return false;
			}
			state = PrefabState.ToRestore;
			return true;
		}
	}
	[BepInPlugin("noglow.NoWeaponsGlow", "NoWeaponsGlow", "1.0.4")]
	[BepInDependency(/*Could not decode attribute arguments.*/)]
	[NetworkCompatibility(/*Could not decode attribute arguments.*/)]
	internal class Plugin : BaseUnityPlugin
	{
		public static CustomLocalization Localization = LocalizationManager.Instance.GetLocalization();

		public void Awake()
		{
			//IL_0000: Unknown result type (might be due to invalid IL or missing references)
			//IL_0006: Invalid comparison between Unknown and I4
			if ((int)SystemInfo.graphicsDeviceType != 4)
			{
				PluginConfig.Bind(((BaseUnityPlugin)this).Config);
				PrefabManager.OnVanillaPrefabsAvailable += OnVanillaPrefabsAvailable;
			}
		}

		private static void OnVanillaPrefabsAvailable()
		{
			Controller.UpdatePrefabs();
		}
	}
}
namespace NoWeaponsGlow.Common
{
	internal enum PrefabState
	{
		Unknown,
		ToModify,
		Modified,
		ToRestore,
		Restored
	}
	internal static class GameObjectExtensions
	{
		public static bool SetChildrenInactive(this GameObject prefab, params string[] names)
		{
			if ((Object)(object)prefab == (Object)null)
			{
				return false;
			}
			HashSet<string> hashSet = new HashSet<string>(names?.Where((string x) => !string.IsNullOrEmpty(x)), StringComparer.InvariantCultureIgnoreCase);
			int num = 0;
			Transform[] componentsInChildren = prefab.GetComponentsInChildren<Transform>(false);
			Transform[] array = componentsInChildren;
			foreach (Transform val in array)
			{
				if ((Object)(object)val != (Object)null && names.Contains<string>(((Object)val).name, StringComparer.InvariantCultureIgnoreCase))
				{
					GameObject gameObject = ((Component)val).gameObject;
					if ((Object)(object)gameObject != (Object)null)
					{
						gameObject.SetActive(false);
						hashSet.Remove(((Object)val).name);
						num++;
					}
				}
			}
			if (hashSet.Count > 0)
			{
				Logger.LogInfo((object)("GameObjectExtensions.SetChildrenInactive: Not all names were found.\nPrefab: " + ((Object)prefab).name + "\nNames not found: " + string.Join(", ", hashSet) + "\nChildren: " + string.Join(", ", componentsInChildren.Select((Transform x) => ((Object)x).name))));
			}
			return num > 0;
		}

		public static bool SetSubChildrenInactive(this GameObject prefab, string subParent, params string[] names)
		{
			if ((Object)(object)prefab == (Object)null)
			{
				return false;
			}
			Transform val = prefab.GetComponentsInChildren<Transform>(true)?.FirstOrDefault((Func<Transform, bool>)((Transform x) => string.Compare(((Object)x).name, subParent, StringComparison.InvariantCultureIgnoreCase) == 0));
			if ((Object)(object)val == (Object)null)
			{
				Logger.LogInfo((object)("GameObjectExtensions.SetSubChildrenInactive: Sub-parent '" + subParent + "' not found in prefab '" + ((Object)prefab).name + "'."));
				return false;
			}
			HashSet<string> hashSet = new HashSet<string>(names?.Where((string x) => !string.IsNullOrEmpty(x)), StringComparer.InvariantCultureIgnoreCase);
			int num = 0;
			Transform[] componentsInChildren = ((Component)val).GetComponentsInChildren<Transform>(false);
			Transform[] array = componentsInChildren;
			foreach (Transform val2 in array)
			{
				if ((Object)(object)val2 != (Object)null && names.Contains<string>(((Object)val2).name, StringComparer.InvariantCultureIgnoreCase))
				{
					GameObject gameObject = ((Component)val2).gameObject;
					if ((Object)(object)gameObject != (Object)null)
					{
						gameObject.SetActive(false);
						hashSet.Remove(((Object)val2).name);
						num++;
					}
				}
			}
			if (hashSet.Count > 0)
			{
				Logger.LogInfo((object)("GameObjectExtensions.SetSubChildrenInactive: Not all names were found.\nPrefab: " + ((Object)prefab).name + " > " + ((Object)val).name + "\nNames not found: " + string.Join(", ", hashSet) + "\nChildren: " + string.Join(", ", componentsInChildren.Select((Transform x) => ((Object)x).name))));
			}
			return num > 0;
		}

		public static bool SetChildrenActive(this GameObject prefab, params string[] names)
		{
			if ((Object)(object)prefab == (Object)null)
			{
				return false;
			}
			HashSet<string> hashSet = new HashSet<string>(names?.Where((string x) => !string.IsNullOrEmpty(x)), StringComparer.InvariantCultureIgnoreCase);
			int num = 0;
			Transform[] componentsInChildren = prefab.GetComponentsInChildren<Transform>(true);
			Transform[] array = componentsInChildren;
			foreach (Transform val in array)
			{
				if ((Object)(object)val != (Object)null && names.Contains<string>(((Object)val).name, StringComparer.InvariantCultureIgnoreCase))
				{
					GameObject gameObject = ((Component)val).gameObject;
					if ((Object)(object)gameObject != (Object)null)
					{
						gameObject.SetActive(true);
						hashSet.Remove(((Object)val).name);
						num++;
					}
				}
			}
			if (hashSet.Count > 0)
			{
				Logger.LogInfo((object)("GameObjectExtensions.SetChildrenActive: Not all names were found.\nPrefab: " + ((Object)prefab).name + "\nNames not found: " + string.Join(", ", hashSet) + "\nChildren: " + string.Join(", ", componentsInChildren.Select((Transform x) => ((Object)x).name))));
			}
			return num > 0;
		}

		public static bool SetSubChildrenActive(this GameObject prefab, string subParent, params string[] names)
		{
			if ((Object)(object)prefab == (Object)null)
			{
				return false;
			}
			Transform val = prefab.GetComponentsInChildren<Transform>(true)?.FirstOrDefault((Func<Transform, bool>)((Transform x) => string.Compare(((Object)x).name, subParent, StringComparison.InvariantCultureIgnoreCase) == 0));
			if ((Object)(object)val == (Object)null)
			{
				Logger.LogInfo((object)("GameObjectExtensions.SetSubChildrenActive: Sub-parent '" + subParent + "' not found in prefab '" + ((Object)prefab).name + "'."));
				return false;
			}
			HashSet<string> hashSet = new HashSet<string>(names?.Where((string x) => !string.IsNullOrEmpty(x)), StringComparer.InvariantCultureIgnoreCase);
			int num = 0;
			Transform[] componentsInChildren = ((Component)val).GetComponentsInChildren<Transform>(true);
			Transform[] array = componentsInChildren;
			foreach (Transform val2 in array)
			{
				if ((Object)(object)val2 != (Object)null && names.Contains<string>(((Object)val2).name, StringComparer.InvariantCultureIgnoreCase))
				{
					GameObject gameObject = ((Component)val2).gameObject;
					if ((Object)(object)gameObject != (Object)null)
					{
						gameObject.SetActive(true);
						hashSet.Remove(((Object)val2).name);
						num++;
					}
				}
			}
			if (hashSet.Count > 0)
			{
				Logger.LogInfo((object)("GameObjectExtensions.SetSubChildrenActive: Not all names were found.\nPrefab: " + ((Object)prefab).name + " > " + ((Object)val).name + "\nNames not found: " + string.Join(", ", hashSet) + "\nChildren: " + string.Join(", ", componentsInChildren.Select((Transform x) => ((Object)x).name))));
			}
			return num > 0;
		}

		public static bool DisableShaderKeyword(this GameObject prefab, string rendererName, string keyword)
		{
			if ((Object)(object)prefab == (Object)null)
			{
				return false;
			}
			Renderer val = ((prefab == null) ? null : prefab.GetComponentsInChildren<Renderer>()?.FirstOrDefault((Func<Renderer, bool>)((Renderer x) => StringComparer.InvariantCultureIgnoreCase.Compare(((Object)x).name, rendererName) == 0)));
			if ((Object)(object)val == (Object)null)
			{
				Logger.LogInfo((object)("GameObjectExtensions.DisableShaderKeyword: Renderer not found.\nPrefab: " + ((Object)prefab).name + "\nRenderer name: " + rendererName + "\nAvailable renderers: " + string.Join(", ", ((prefab == null) ? null : prefab.GetComponentsInChildren<Renderer>()?.Select((Renderer x) => ((Object)x).name)) ?? Array.Empty<string>())));
				return false;
			}
			Material sharedMaterial = val.sharedMaterial;
			if ((Object)(object)sharedMaterial == (Object)null)
			{
				Logger.LogInfo((object)("GameObjectExtensions.DisableShaderKeyword: Material not found.\nPrefab: " + ((Object)prefab).name + "\nRenderer name: " + rendererName));
				return false;
			}
			if (!sharedMaterial.IsKeywordEnabled(keyword))
			{
				Logger.LogInfo((object)("GameObjectExtensions.DisableShaderKeyword: Keyward is not enabled.\nKeyword: '" + keyword + "'\nPrefab: " + ((Object)prefab).name + "\nRenderer name: " + rendererName));
				return false;
			}
			sharedMaterial.DisableKeyword(keyword);
			return true;
		}

		public static bool EnableShaderKeyword(this GameObject prefab, string rendererName, string keyword)
		{
			if ((Object)(object)prefab == (Object)null)
			{
				return false;
			}
			Renderer val = ((prefab == null) ? null : prefab.GetComponentsInChildren<Renderer>()?.FirstOrDefault((Func<Renderer, bool>)((Renderer x) => StringComparer.InvariantCultureIgnoreCase.Compare(((Object)x).name, rendererName) == 0)));
			if ((Object)(object)val == (Object)null)
			{
				Logger.LogInfo((object)("GameObjectExtensions.EnableShaderKeyword: Renderer not found.\nPrefab: " + ((Object)prefab).name + "\nRenderer name: " + rendererName + "\nAvailable renderers: " + string.Join(", ", ((prefab == null) ? null : prefab.GetComponentsInChildren<Renderer>()?.Select((Renderer x) => ((Object)x).name)) ?? Array.Empty<string>())));
				return false;
			}
			Material sharedMaterial = val.sharedMaterial;
			if ((Object)(object)sharedMaterial == (Object)null)
			{
				Logger.LogInfo((object)("GameObjectExtensions.EnableShaderKeyword: Material not found.\nPrefab: " + ((Object)prefab).name + "\nRenderer name: " + rendererName));
				return false;
			}
			if (sharedMaterial.IsKeywordEnabled(keyword))
			{
				Logger.LogInfo((object)("GameObjectExtensions.EnableShaderKeyword: Keyward already enabled.\nKeyword: '" + keyword + "'\nPrefab: " + ((Object)prefab).name + "\nRenderer name: " + rendererName));
				return false;
			}
			sharedMaterial.EnableKeyword(keyword);
			return true;
		}
	}
}
namespace NoWeaponsGlow.Prefabs
{
	internal static class Controller
	{
		private static readonly HashSet<string> Names = new HashSet<string>
		{
			"BattleaxeCrystal", "StaffSkeleton", "BowDraugrFang", "SwordIronFire", "SwordDyrnwyn", "MaceSilver", "AtgeirHimminAfl", "AxeJotunBane", "SwordMistwalker", "MaceNeedle",
			"BowSpineSnap", "StaffFireball", "StaffIceShards", "StaffShield", "StaffGreenRoots"
		};

		public static void UpdatePrefabs()
		{
			if (Flags.Evaluate())
			{
				Dictionary<string, GameObject> dictionary = Find();
				if (dictionary.Count != 0)
				{
					Restore(dictionary);
					Modify(dictionary);
				}
			}
		}

		private static Dictionary<string, GameObject> Find()
		{
			Dictionary<string, GameObject> dictionary = new Dictionary<string, GameObject>();
			HashSet<string> hashSet = new HashSet<string>(Names);
			foreach (string name in Names)
			{
				GameObject prefab = PrefabManager.Instance.GetPrefab(name);
				if (!((Object)(object)prefab == (Object)null) && !string.IsNullOrEmpty(((Object)prefab).name))
				{
					hashSet.Remove(((Object)prefab).name);
					dictionary.Add(((Object)prefab).name, prefab);
				}
			}
			if (hashSet.Count > 0)
			{
				Logger.LogWarning((object)("Controller.Find: Not all prefabs were found.\nNames not found: " + string.Join(", ", hashSet)));
			}
			return dictionary;
		}

		private static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			bool flag = true;
			flag = DraugarFang.Modify(prefabs) && flag;
			flag = SpineSnap.Modify(prefabs) && flag;
			flag = Frostner.Modify(prefabs) && flag;
			flag = CrystalBattleaxe.Modify(prefabs) && flag;
			flag = Mistwalker.Modify(prefabs) && flag;
			flag = Porcupine.Modify(prefabs) && flag;
			flag = JotunBane.Modify(prefabs) && flag;
			flag = Himminafl.Modify(prefabs) && flag;
			flag = StaffOfEmbers.Modify(prefabs) && flag;
			flag = StaffOfFrost.Modify(prefabs) && flag;
			flag = StaffOfProtection.Modify(prefabs) && flag;
			flag = StaffOfTheWild.Modify(prefabs) && flag;
			flag = DeadRaiser.Modify(prefabs) && flag;
			return Dyrnwyn.Modify(prefabs) && flag;
		}

		private static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			bool flag = true;
			flag = DraugarFang.Restore(prefabs) && flag;
			flag = SpineSnap.Restore(prefabs) && flag;
			flag = Frostner.Restore(prefabs) && flag;
			flag = CrystalBattleaxe.Restore(prefabs) && flag;
			flag = Mistwalker.Restore(prefabs) && flag;
			flag = Porcupine.Restore(prefabs) && flag;
			flag = JotunBane.Restore(prefabs) && flag;
			flag = Himminafl.Restore(prefabs) && flag;
			flag = StaffOfEmbers.Restore(prefabs) && flag;
			flag = StaffOfFrost.Restore(prefabs) && flag;
			flag = StaffOfProtection.Restore(prefabs) && flag;
			flag = StaffOfTheWild.Restore(prefabs) && flag;
			flag = DeadRaiser.Restore(prefabs) && flag;
			return Dyrnwyn.Restore(prefabs) && flag;
		}
	}
}
namespace NoWeaponsGlow.Prefabs.Code
{
	internal static class StaffOfTheWild
	{
		public const string PrefabName = "StaffGreenRoots";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnStaffOfTheWild.Value)
				{
					return true;
				}
				if (Flags.StaffOfTheWild != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffGreenRoots", out var value))
				{
					Logger.LogInfo((object)"StaffOfTheWild.Modify: Prefab StaffGreenRoots not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetSubChildrenInactive("effects", "Point light", "flare", "embers (1)") && flag;
				flag = value.SetSubChildrenInactive("glow", "Point light", "flare") && flag;
				if (flag)
				{
					Flags.StaffOfTheWild = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfTheWild", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.StaffOfTheWild != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffGreenRoots", out var value))
				{
					Logger.LogInfo((object)"StaffOfTheWild.Restore: Prefab StaffGreenRoots not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetSubChildrenActive("effects", "Point light", "flare", "embers (1)") && flag;
				flag = value.SetSubChildrenActive("glow", "Point light", "flare") && flag;
				if (flag)
				{
					Flags.StaffOfTheWild = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfTheWild", "Restore", arg));
				return false;
			}
		}
	}
	internal static class CrystalBattleaxe
	{
		public const string PrefabName = "BattleaxeCrystal";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnCrystalBattleaxe.Value)
				{
					return true;
				}
				if (Flags.CrystalBattleaxe != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("BattleaxeCrystal", out var value))
				{
					Logger.LogInfo((object)"CrystalBattleaxe.Modify: Prefab BattleaxeCrystal not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point Light", "flare") && flag;
				flag = value.DisableShaderKeyword("default", "_EMISSION") && flag;
				if (flag)
				{
					Flags.CrystalBattleaxe = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "CrystalBattleaxe", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.CrystalBattleaxe != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("BattleaxeCrystal", out var value))
				{
					Logger.LogInfo((object)"CrystalBattleaxe.Restore: Prefab BattleaxeCrystal not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point Light", "flare") && flag;
				flag = value.EnableShaderKeyword("default", "_EMISSION") && flag;
				if (flag)
				{
					Flags.CrystalBattleaxe = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "CrystalBattleaxe", "Restore", arg));
				return false;
			}
		}
	}
	internal static class Frostner
	{
		public const string PrefabName = "MaceSilver";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnFrostner.Value)
				{
					return true;
				}
				if (Flags.Frostner != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("MaceSilver", out var value))
				{
					Logger.LogInfo((object)"Frostner.Modify: Prefab MaceSilver not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("soft cloud") && flag;
				if (flag)
				{
					Flags.Frostner = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Frostner", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.Frostner != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("MaceSilver", out var value))
				{
					Logger.LogInfo((object)"Frostner.Restore: Prefab MaceSilver not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("soft cloud") && flag;
				if (flag)
				{
					Flags.Frostner = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Frostner", "Restore", arg));
				return false;
			}
		}
	}
	internal static class JotunBane
	{
		public const string PrefabName = "AxeJotunBane";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnJotunBane.Value)
				{
					return true;
				}
				if (Flags.JotunBane != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("AxeJotunBane", out var value))
				{
					Logger.LogInfo((object)"JotunBane.Modify: Prefab AxeJotunBane not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "Glow", "poison drip", "poison splat") && flag;
				if (flag)
				{
					Flags.JotunBane = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "JotunBane", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.JotunBane != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("AxeJotunBane", out var value))
				{
					Logger.LogInfo((object)"JotunBane.Restore: Prefab AxeJotunBane not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "Glow", "poison drip", "poison splat") && flag;
				if (flag)
				{
					Flags.JotunBane = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "JotunBane", "Restore", arg));
				return false;
			}
		}
	}
	internal static class Himminafl
	{
		public const string PrefabName = "AtgeirHimminAfl";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnHimminafl.Value)
				{
					return true;
				}
				if (Flags.Himminafl != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("AtgeirHimminAfl", out var value))
				{
					Logger.LogInfo((object)"Himminafl.Modify: Prefab AtgeirHimminAfl not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "Sparcs") && flag;
				if (flag)
				{
					Flags.Himminafl = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Himminafl", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.Himminafl != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("AtgeirHimminAfl", out var value))
				{
					Logger.LogInfo((object)"Himminafl.Restore: Prefab AtgeirHimminAfl not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "Sparcs") && flag;
				if (flag)
				{
					Flags.Himminafl = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Himminafl", "Restore", arg));
				return false;
			}
		}
	}
	internal static class DeadRaiser
	{
		public const string PrefabName = "StaffSkeleton";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnDeadRaiser.Value)
				{
					return true;
				}
				if (Flags.DeadRaiser != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffSkeleton", out var value))
				{
					Logger.LogInfo((object)"DeadRaiser.Modify: Prefab StaffSkeleton not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "flames", "embers", "fi_vil_combs_props_bone_skull (1)") && flag;
				if (flag)
				{
					Flags.DeadRaiser = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "DeadRaiser", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.DeadRaiser != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffSkeleton", out var value))
				{
					Logger.LogInfo((object)"DeadRaiser.Restore: Prefab StaffSkeleton not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "flames", "embers", "fi_vil_combs_props_bone_skull (1)") && flag;
				if (flag)
				{
					Flags.DeadRaiser = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "DeadRaiser", "Restore", arg));
				return false;
			}
		}
	}
	internal static class StaffOfEmbers
	{
		public const string PrefabName = "StaffFireball";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnStaffOfEmbers.Value)
				{
					return true;
				}
				if (Flags.StaffOfEmbers != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffFireball", out var value))
				{
					Logger.LogInfo((object)"StaffOfEmbers.Modify: Prefab StaffFireball not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetSubChildrenInactive("equiped", "embers", "flames") && flag;
				flag = value.SetSubChildrenInactive("effects", "Point light", "flare", "embers (1)") && flag;
				if (flag)
				{
					Flags.StaffOfEmbers = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfEmbers", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.StaffOfEmbers != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffFireball", out var value))
				{
					Logger.LogInfo((object)"StaffOfEmbers.Restore: Prefab StaffFireball not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetSubChildrenActive("equiped", "embers", "flames") && flag;
				flag = value.SetSubChildrenActive("effects", "Point light", "flare", "embers (1)") && flag;
				if (flag)
				{
					Flags.StaffOfEmbers = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfEmbers", "Restore", arg));
				return false;
			}
		}
	}
	internal static class StaffOfFrost
	{
		public const string PrefabName = "StaffIceShards";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnStaffOfFrost.Value)
				{
					return true;
				}
				if (Flags.StaffOfFrost != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffIceShards", out var value))
				{
					Logger.LogInfo((object)"StaffOfFrost.Modify: Prefab StaffIceShards not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "flare", "embers (1)") && flag;
				flag = value.DisableShaderKeyword("default (1)", "_EMISSION") && flag;
				if (flag)
				{
					Flags.StaffOfFrost = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfFrost", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.StaffOfFrost != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffIceShards", out var value))
				{
					Logger.LogInfo((object)"StaffOfFrost.Restore: Prefab StaffIceShards not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "flare", "embers (1)") && flag;
				flag = value.EnableShaderKeyword("default (1)", "_EMISSION") && flag;
				if (flag)
				{
					Flags.StaffOfFrost = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfFrost", "Restore", arg));
				return false;
			}
		}
	}
	internal static class StaffOfProtection
	{
		public const string PrefabName = "StaffShield";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnStaffOfProtection.Value)
				{
					return true;
				}
				if (Flags.StaffOfProtection != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffShield", out var value))
				{
					Logger.LogInfo((object)"StaffOfProtection.Modify: Prefab StaffShield not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("flames") && flag;
				if (flag)
				{
					Flags.StaffOfProtection = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfProtection", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.StaffOfProtection != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("StaffShield", out var value))
				{
					Logger.LogInfo((object)"StaffOfProtection.Restore: Prefab StaffShield not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("flames") && flag;
				if (flag)
				{
					Flags.StaffOfProtection = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "StaffOfProtection", "Restore", arg));
				return false;
			}
		}
	}
	internal static class Porcupine
	{
		public const string PrefabName = "MaceNeedle";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnPorcupine.Value)
				{
					return true;
				}
				if (Flags.Porcupine != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("MaceNeedle", out var value))
				{
					Logger.LogInfo((object)"Porcupine.Modify: Prefab MaceNeedle not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point Light") && flag;
				if (flag)
				{
					Flags.Porcupine = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Porcupine", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.Porcupine != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("MaceNeedle", out var value))
				{
					Logger.LogInfo((object)"Porcupine.Restore: Prefab MaceNeedle not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point Light") && flag;
				if (flag)
				{
					Flags.Porcupine = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Porcupine", "Restore", arg));
				return false;
			}
		}
	}
	internal static class Dyrnwyn
	{
		public const string PrefabName1 = "SwordIronFire";

		public const string PrefabName2 = "SwordDyrnwyn";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnDyrnwyn.Value)
				{
					return true;
				}
				if (Flags.Dyrnwyn != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("SwordIronFire", out var value))
				{
					Logger.LogInfo((object)"Dyrnwyn.Modify: Prefab SwordIronFire not found.");
					return false;
				}
				if (!prefabs.TryGetValue("SwordDyrnwyn", out var value2))
				{
					Logger.LogInfo((object)"Dyrnwyn.Modify: Prefab SwordDyrnwyn not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "sfx_fire_loop", "flames (1)", "embers", "flames_local", "flames", "smoke (1)") && flag;
				flag = value.DisableShaderKeyword("Viking_Sword (1)", "_EMISSION") && flag;
				flag = value2.SetChildrenInactive("Point light", "Burny vfx") && flag;
				flag = value2.DisableShaderKeyword("default", "_EMISSION") && flag;
				if (flag)
				{
					Flags.Dyrnwyn = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Dyrnwyn", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.Dyrnwyn != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("SwordIronFire", out var value))
				{
					Logger.LogInfo((object)"Dyrnwyn.Modify: Prefab SwordIronFire not found.");
					return false;
				}
				if (!prefabs.TryGetValue("SwordDyrnwyn", out var value2))
				{
					Logger.LogInfo((object)"Dyrnwyn.Restore: Prefab SwordDyrnwyn not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "sfx_fire_loop", "flames (1)", "embers", "flames_local", "flames", "smoke (1)") && flag;
				flag = value.EnableShaderKeyword("Viking_Sword (1)", "_EMISSION") && flag;
				flag = value2.SetChildrenActive("Point light", "Burny vfx") && flag;
				flag = value2.EnableShaderKeyword("default", "_EMISSION") && flag;
				if (flag)
				{
					Flags.Dyrnwyn = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Dyrnwyn", "Restore", arg));
				return false;
			}
		}
	}
	internal static class Mistwalker
	{
		public const string PrefabName = "SwordMistwalker";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnMistwalker.Value)
				{
					return true;
				}
				if (Flags.Mistwalker != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("SwordMistwalker", out var value))
				{
					Logger.LogInfo((object)"Mistwalker.Modify: Prefab SwordMistwalker not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "Particle System", "Particle System Force Field") && flag;
				if (flag)
				{
					Flags.Mistwalker = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Mistwalker", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.Mistwalker != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("SwordMistwalker", out var value))
				{
					Logger.LogInfo((object)"Mistwalker.Restore: Prefab SwordMistwalker not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "Particle System", "Particle System Force Field") && flag;
				if (flag)
				{
					Flags.Mistwalker = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "Mistwalker", "Restore", arg));
				return false;
			}
		}
	}
	internal static class SpineSnap
	{
		public const string PrefabName = "BowSpineSnap";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnSpineSnap.Value)
				{
					return true;
				}
				if (Flags.SpineSnap != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("BowSpineSnap", out var value))
				{
					Logger.LogInfo((object)"SpineSnap.Modify: Prefab BowSpineSnap not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "Particle System") && flag;
				if (flag)
				{
					Flags.SpineSnap = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "SpineSnap", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.SpineSnap != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("BowSpineSnap", out var value))
				{
					Logger.LogInfo((object)"SpineSnap.Restore: Prefab BowSpineSnap not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "Particle System") && flag;
				if (flag)
				{
					Flags.SpineSnap = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "SpineSnap", "Restore", arg));
				return false;
			}
		}
	}
	internal static class DraugarFang
	{
		public const string PrefabName = "BowDraugrFang";

		public static bool Modify(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (!PluginConfig.DisableGlowOnDraugarFang.Value)
				{
					return true;
				}
				if (Flags.DraugarFang != PrefabState.ToModify)
				{
					return false;
				}
				if (!prefabs.TryGetValue("BowDraugrFang", out var value))
				{
					Logger.LogInfo((object)"DraugarFang.Modify: Prefab BowDraugrFang not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenInactive("Point light", "Particle System") && flag;
				if (flag)
				{
					Flags.DraugarFang = PrefabState.Modified;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "DraugarFang", "Modify", arg));
				return false;
			}
		}

		public static bool Restore(Dictionary<string, GameObject> prefabs)
		{
			try
			{
				if (Flags.DraugarFang != PrefabState.ToRestore)
				{
					return false;
				}
				if (!prefabs.TryGetValue("BowDraugrFang", out var value))
				{
					Logger.LogInfo((object)"DraugarFang.Restore: Prefab BowDraugrFang not found.");
					return false;
				}
				bool flag = true;
				flag = value.SetChildrenActive("Point light", "Particle System") && flag;
				if (flag)
				{
					Flags.DraugarFang = PrefabState.Restored;
				}
				return flag;
			}
			catch (Exception arg)
			{
				Logger.LogError((object)string.Format("{0}.{1}: Exception occurred:\n{2}", "DraugarFang", "Restore", arg));
				return false;
			}
		}
	}
}