mirror of
https://github.com/osukey/osukey.git
synced 2025-08-05 15:44:04 +09:00
Replace hashcode override with local equality comparer
This commit is contained in:
@ -93,12 +93,5 @@ namespace osu.Game.Online.Multiplayer
|
||||
public bool ShouldSerializeapiBeatmap() => false;
|
||||
|
||||
public bool Equals(PlaylistItem other) => ID == other?.ID && BeatmapID == other.BeatmapID && RulesetID == other.RulesetID;
|
||||
|
||||
public override int GetHashCode()
|
||||
{
|
||||
// ReSharper disable NonReadonlyMemberInGetHashCode
|
||||
return HashCode.Combine(ID, BeatmapID, RulesetID);
|
||||
// ReSharper restore NonReadonlyMemberInGetHashCode
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -2,6 +2,7 @@
|
||||
// See the LICENCE file in the repository root for full licence text.
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using Newtonsoft.Json;
|
||||
using osu.Framework.Allocation;
|
||||
@ -124,15 +125,13 @@ namespace osu.Game.Online.Multiplayer
|
||||
var localItem = Playlist.FirstOrDefault(i => i.BeatmapID == item.BeatmapID);
|
||||
|
||||
if (localItem != null)
|
||||
{
|
||||
item.Beatmap.Value.Metadata = localItem.Beatmap.Value.Metadata;
|
||||
}
|
||||
}
|
||||
|
||||
foreach (var removeableItem in Playlist.Except(other.Playlist).ToArray())
|
||||
foreach (var removeableItem in Playlist.Except(other.Playlist, new PlaylistEqualityComparer()).ToArray())
|
||||
Playlist.Remove(removeableItem);
|
||||
|
||||
Playlist.AddRange(other.Playlist.Except(Playlist).ToArray());
|
||||
Playlist.AddRange(other.Playlist.Except(Playlist, new PlaylistEqualityComparer()).ToArray());
|
||||
|
||||
foreach (var removedItem in Participants.Except(other.Participants).ToArray())
|
||||
Participants.Remove(removedItem);
|
||||
@ -144,5 +143,12 @@ namespace osu.Game.Online.Multiplayer
|
||||
public bool ShouldSerializeRoomID() => false;
|
||||
public bool ShouldSerializeHost() => false;
|
||||
public bool ShouldSerializeEndDate() => false;
|
||||
|
||||
private class PlaylistEqualityComparer : IEqualityComparer<PlaylistItem>
|
||||
{
|
||||
public bool Equals(PlaylistItem x, PlaylistItem y) => x?.Equals(y) ?? false;
|
||||
|
||||
public int GetHashCode(PlaylistItem obj) => HashCode.Combine(obj.ID, obj.BeatmapID, obj.RulesetID);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user