mirror of
https://github.com/ppy/osu.git
synced 2025-01-15 15:12:57 +08:00
Refactor condition
This won't make any noticeable difference, but is the more correct way to handle MultiMod because flattening works through infinite recursion levels.
This commit is contained in:
parent
b54f65c282
commit
7a14e14e67
@ -17,6 +17,7 @@ using osu.Game.Rulesets;
|
|||||||
using osu.Game.Rulesets.Mods;
|
using osu.Game.Rulesets.Mods;
|
||||||
using osu.Game.Screens.OnlinePlay.Match;
|
using osu.Game.Screens.OnlinePlay.Match;
|
||||||
using osu.Game.Screens.Select;
|
using osu.Game.Screens.Select;
|
||||||
|
using osu.Game.Utils;
|
||||||
|
|
||||||
namespace osu.Game.Screens.OnlinePlay
|
namespace osu.Game.Screens.OnlinePlay
|
||||||
{
|
{
|
||||||
@ -126,7 +127,7 @@ namespace osu.Game.Screens.OnlinePlay
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="mod">The <see cref="Mod"/> to check.</param>
|
/// <param name="mod">The <see cref="Mod"/> to check.</param>
|
||||||
/// <returns>Whether <paramref name="mod"/> is a valid mod for online play.</returns>
|
/// <returns>Whether <paramref name="mod"/> is a valid mod for online play.</returns>
|
||||||
protected virtual bool IsValidMod(Mod mod) => mod.HasImplementation && !(mod is ModAutoplay) && (mod as MultiMod)?.Mods.Any(mm => mm is ModAutoplay) != true;
|
protected virtual bool IsValidMod(Mod mod) => mod.HasImplementation && !ModUtils.FlattenMod(mod).Any(m => m is ModAutoplay);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Checks whether a given <see cref="Mod"/> is valid for per-player free-mod selection.
|
/// Checks whether a given <see cref="Mod"/> is valid for per-player free-mod selection.
|
||||||
|
Loading…
Reference in New Issue
Block a user