mirror of
https://github.com/ppy/osu.git
synced 2025-01-08 07:33:09 +08:00
Refactor latest changes to avoid unnecessary call when mods not present
This commit is contained in:
parent
6e3bea938e
commit
7cbe93efc3
@ -6,7 +6,6 @@ using System.Linq;
|
|||||||
using Humanizer;
|
using Humanizer;
|
||||||
using Humanizer.Localisation;
|
using Humanizer.Localisation;
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Game.Rulesets.Mods;
|
|
||||||
using osu.Game.Utils;
|
using osu.Game.Utils;
|
||||||
|
|
||||||
namespace osu.Game.Online.Rooms
|
namespace osu.Game.Online.Rooms
|
||||||
@ -46,13 +45,14 @@ namespace osu.Game.Online.Rooms
|
|||||||
public static string GetTotalDuration(this BindableList<PlaylistItem> playlist) =>
|
public static string GetTotalDuration(this BindableList<PlaylistItem> playlist) =>
|
||||||
playlist.Select(p =>
|
playlist.Select(p =>
|
||||||
{
|
{
|
||||||
IEnumerable<Mod> modList = [];
|
double rate = 1;
|
||||||
|
|
||||||
if (p.RequiredMods.Length > 0)
|
if (p.RequiredMods.Length > 0)
|
||||||
{
|
{
|
||||||
var ruleset = p.Beatmap.Ruleset.CreateInstance();
|
var ruleset = p.Beatmap.Ruleset.CreateInstance();
|
||||||
modList = p.RequiredMods.Select(mod => mod.ToMod(ruleset));
|
rate = ModUtils.CalculateRateWithMods(p.RequiredMods.Select(mod => mod.ToMod(ruleset)));
|
||||||
}
|
}
|
||||||
double rate = ModUtils.CalculateRateWithMods(modList);
|
|
||||||
return p.Beatmap.Length / rate;
|
return p.Beatmap.Length / rate;
|
||||||
}).Sum().Milliseconds().Humanize(minUnit: TimeUnit.Second, maxUnit: TimeUnit.Hour, precision: 2);
|
}).Sum().Milliseconds().Humanize(minUnit: TimeUnit.Second, maxUnit: TimeUnit.Hour, precision: 2);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user