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;
}
}
}
}