mirror of
https://github.com/ppy/osu.git
synced 2025-01-12 23:12:56 +08:00
Take current mod settings value into account on equality comparsion
This commit is contained in:
parent
fbd5195738
commit
92fab653e1
@ -11,6 +11,7 @@ using osu.Framework.Bindables;
|
|||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Rulesets;
|
using osu.Game.Rulesets;
|
||||||
using osu.Game.Rulesets.Mods;
|
using osu.Game.Rulesets.Mods;
|
||||||
|
using osu.Game.Utils;
|
||||||
|
|
||||||
namespace osu.Game.Online.API
|
namespace osu.Game.Online.API
|
||||||
{
|
{
|
||||||
@ -64,7 +65,15 @@ namespace osu.Game.Online.API
|
|||||||
}
|
}
|
||||||
|
|
||||||
public bool Equals(IMod other) => other is APIMod them && Equals(them);
|
public bool Equals(IMod other) => other is APIMod them && Equals(them);
|
||||||
public bool Equals(APIMod other) => Acronym == other?.Acronym;
|
|
||||||
|
public bool Equals(APIMod other)
|
||||||
|
{
|
||||||
|
if (ReferenceEquals(null, other)) return false;
|
||||||
|
if (ReferenceEquals(this, other)) return true;
|
||||||
|
|
||||||
|
return Acronym == other.Acronym &&
|
||||||
|
Settings.SequenceEqual(other.Settings, ModSettingsEqualityComparer.Default);
|
||||||
|
}
|
||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
@ -73,5 +82,20 @@ namespace osu.Game.Online.API
|
|||||||
|
|
||||||
return $"{Acronym}";
|
return $"{Acronym}";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class ModSettingsEqualityComparer : IEqualityComparer<KeyValuePair<string, object>>
|
||||||
|
{
|
||||||
|
public static ModSettingsEqualityComparer Default { get; } = new ModSettingsEqualityComparer();
|
||||||
|
|
||||||
|
public bool Equals(KeyValuePair<string, object> x, KeyValuePair<string, object> y)
|
||||||
|
{
|
||||||
|
object xValue = ModUtils.GetSettingUnderlyingValue(x.Value);
|
||||||
|
object yValue = ModUtils.GetSettingUnderlyingValue(y.Value);
|
||||||
|
|
||||||
|
return x.Key == y.Key && EqualityComparer<object>.Default.Equals(xValue, yValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int GetHashCode(KeyValuePair<string, object> obj) => HashCode.Combine(obj.Key, ModUtils.GetSettingUnderlyingValue(obj.Value));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,6 +12,7 @@ using osu.Framework.Testing;
|
|||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.IO.Serialization;
|
using osu.Game.IO.Serialization;
|
||||||
using osu.Game.Rulesets.UI;
|
using osu.Game.Rulesets.UI;
|
||||||
|
using osu.Game.Utils;
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Mods
|
namespace osu.Game.Rulesets.Mods
|
||||||
{
|
{
|
||||||
@ -173,7 +174,18 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
}
|
}
|
||||||
|
|
||||||
public bool Equals(IMod other) => other is Mod them && Equals(them);
|
public bool Equals(IMod other) => other is Mod them && Equals(them);
|
||||||
public bool Equals(Mod other) => GetType() == other?.GetType();
|
|
||||||
|
public bool Equals(Mod other)
|
||||||
|
{
|
||||||
|
if (ReferenceEquals(null, other)) return false;
|
||||||
|
if (ReferenceEquals(this, other)) return true;
|
||||||
|
|
||||||
|
return GetType() == other.GetType() &&
|
||||||
|
this.GetSettingsSourceProperties().All(pair =>
|
||||||
|
EqualityComparer<object>.Default.Equals(
|
||||||
|
ModUtils.GetSettingUnderlyingValue(pair.Item2.GetValue(this)),
|
||||||
|
ModUtils.GetSettingUnderlyingValue(pair.Item2.GetValue(other))));
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Reset all custom settings for this mod back to their defaults.
|
/// Reset all custom settings for this mod back to their defaults.
|
||||||
|
Loading…
Reference in New Issue
Block a user