1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-07 19:13:21 +08:00

Do not attempt to recalculate non-legacy scores or scores set on custom rulesets

Addresses discussions such as https://github.com/ppy/osu/discussions/26407
or https://github.com/ppy/osu/discussions/25914 wherein:

- the game would attempt to convert scores for custom rulesets, which
  makes no sense, especially so when they're not there,

- the game would also "recalculate" lazer scores, but that was never the
  intention or was never supported; the game would just increment the
  score version on those but still include them in the converted tally.
This commit is contained in:
Bartłomiej Dach 2024-01-08 22:07:33 +01:00
parent 388f6599e0
commit 4f7dcb3a50
No known key found for this signature in database

View File

@ -13,6 +13,7 @@ using osu.Framework.Graphics;
using osu.Framework.Logging; using osu.Framework.Logging;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
using osu.Game.Database; using osu.Game.Database;
using osu.Game.Extensions;
using osu.Game.Online.API; using osu.Game.Online.API;
using osu.Game.Overlays; using osu.Game.Overlays;
using osu.Game.Overlays.Notifications; using osu.Game.Overlays.Notifications;
@ -28,7 +29,7 @@ namespace osu.Game
/// </summary> /// </summary>
public partial class BackgroundDataStoreProcessor : Component public partial class BackgroundDataStoreProcessor : Component
{ {
protected Task ProcessingTask = null!; protected Task ProcessingTask { get; private set; } = null!;
[Resolved] [Resolved]
private RulesetStore rulesetStore { get; set; } = null!; private RulesetStore rulesetStore { get; set; } = null!;
@ -316,10 +317,17 @@ namespace osu.Game
{ {
Logger.Log("Querying for scores that need total score conversion..."); Logger.Log("Querying for scores that need total score conversion...");
HashSet<Guid> scoreIds = realmAccess.Run(r => new HashSet<Guid>(r.All<ScoreInfo>() HashSet<Guid> scoreIds = realmAccess.Run(r => new HashSet<Guid>(
.Where(s => !s.BackgroundReprocessingFailed && s.BeatmapInfo != null r.All<ScoreInfo>()
.Where(s => !s.BackgroundReprocessingFailed
&& s.BeatmapInfo != null
&& s.IsLegacyScore
&& s.TotalScoreVersion < LegacyScoreEncoder.LATEST_VERSION) && s.TotalScoreVersion < LegacyScoreEncoder.LATEST_VERSION)
.AsEnumerable().Select(s => s.ID))); .AsEnumerable()
// must be done after materialisation, as realm doesn't want to support
// nested property predicates
.Where(s => s.Ruleset.IsLegacyRuleset())
.Select(s => s.ID)));
Logger.Log($"Found {scoreIds.Count} scores which require total score conversion."); Logger.Log($"Found {scoreIds.Count} scores which require total score conversion.");