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

Don't use bindables to avoid potential cross-usage contamination

This commit is contained in:
Dean Herbert 2023-01-10 01:10:20 +09:00
parent 62ffb4fe78
commit 811a562608
6 changed files with 40 additions and 14 deletions

View File

@ -44,6 +44,16 @@ namespace osu.Game.Beatmaps
public Action<(BeatmapSetInfo beatmapSet, bool isBatch)>? ProcessBeatmap { private get; set; } public Action<(BeatmapSetInfo beatmapSet, bool isBatch)>? ProcessBeatmap { private get; set; }
public override bool PauseImports
{
get => base.PauseImports;
set
{
base.PauseImports = value;
beatmapImporter.PauseImports = value;
}
}
public BeatmapManager(Storage storage, RealmAccess realm, IAPIProvider? api, AudioManager audioManager, IResourceStore<byte[]> gameResources, GameHost? host = null, public BeatmapManager(Storage storage, RealmAccess realm, IAPIProvider? api, AudioManager audioManager, IResourceStore<byte[]> gameResources, GameHost? host = null,
WorkingBeatmap? defaultBeatmap = null, BeatmapDifficultyCache? difficultyCache = null, bool performOnlineLookups = false) WorkingBeatmap? defaultBeatmap = null, BeatmapDifficultyCache? difficultyCache = null, bool performOnlineLookups = false)
: base(storage, realm) : base(storage, realm)
@ -62,7 +72,6 @@ namespace osu.Game.Beatmaps
BeatmapTrackStore = audioManager.GetTrackStore(userResources); BeatmapTrackStore = audioManager.GetTrackStore(userResources);
beatmapImporter = CreateBeatmapImporter(storage, realm); beatmapImporter = CreateBeatmapImporter(storage, realm);
beatmapImporter.PauseImports.BindTo(PauseImports);
beatmapImporter.ProcessBeatmap = args => ProcessBeatmap?.Invoke(args); beatmapImporter.ProcessBeatmap = args => ProcessBeatmap?.Invoke(args);
beatmapImporter.PostNotification = obj => PostNotification?.Invoke(obj); beatmapImporter.PostNotification = obj => PostNotification?.Invoke(obj);

View File

@ -6,7 +6,6 @@ using System.Collections.Generic;
using System.Diagnostics; using System.Diagnostics;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using osu.Framework.Bindables;
using osu.Framework.Platform; using osu.Framework.Platform;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
using osu.Game.Extensions; using osu.Game.Extensions;
@ -22,7 +21,7 @@ namespace osu.Game.Database
/// <summary> /// <summary>
/// Temporarily pause imports to avoid performance overheads affecting gameplay scenarios. /// Temporarily pause imports to avoid performance overheads affecting gameplay scenarios.
/// </summary> /// </summary>
public readonly BindableBool PauseImports = new BindableBool(); public virtual bool PauseImports { get; set; }
protected RealmAccess Realm { get; } protected RealmAccess Realm { get; }

View File

@ -8,7 +8,6 @@ using System.Linq;
using System.Threading; using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Humanizer; using Humanizer;
using osu.Framework.Bindables;
using osu.Framework.Extensions; using osu.Framework.Extensions;
using osu.Framework.Extensions.IEnumerableExtensions; using osu.Framework.Extensions.IEnumerableExtensions;
using osu.Framework.Logging; using osu.Framework.Logging;
@ -60,7 +59,7 @@ namespace osu.Game.Database
/// <summary> /// <summary>
/// Temporarily pause imports to avoid performance overheads affecting gameplay scenarios. /// Temporarily pause imports to avoid performance overheads affecting gameplay scenarios.
/// </summary> /// </summary>
public readonly BindableBool PauseImports = new BindableBool(); public bool PauseImports { get; set; }
public abstract IEnumerable<string> HandledExtensions { get; } public abstract IEnumerable<string> HandledExtensions { get; }
@ -559,12 +558,12 @@ namespace osu.Game.Database
private void pauseIfNecessary(CancellationToken cancellationToken) private void pauseIfNecessary(CancellationToken cancellationToken)
{ {
if (!PauseImports.Value) if (!PauseImports)
return; return;
Logger.Log(@"Import is being paused."); Logger.Log(@"Import is being paused.");
while (PauseImports.Value) while (PauseImports)
{ {
cancellationToken.ThrowIfCancellationRequested(); cancellationToken.ThrowIfCancellationRequested();
Thread.Sleep(500); Thread.Sleep(500);

View File

@ -307,9 +307,12 @@ namespace osu.Game
// Transfer any runtime changes back to configuration file. // Transfer any runtime changes back to configuration file.
SkinManager.CurrentSkinInfo.ValueChanged += skin => configSkin.Value = skin.NewValue.ID.ToString(); SkinManager.CurrentSkinInfo.ValueChanged += skin => configSkin.Value = skin.NewValue.ID.ToString();
BeatmapManager.PauseImports.BindTo(LocalUserPlaying); LocalUserPlaying.BindValueChanged(p =>
SkinManager.PauseImports.BindTo(LocalUserPlaying); {
ScoreManager.PauseImports.BindTo(LocalUserPlaying); BeatmapManager.PauseImports = p.NewValue;
SkinManager.PauseImports = p.NewValue;
ScoreManager.PauseImports = p.NewValue;
}, true);
IsActive.BindValueChanged(active => updateActiveState(active.NewValue), true); IsActive.BindValueChanged(active => updateActiveState(active.NewValue), true);

View File

@ -28,6 +28,16 @@ namespace osu.Game.Scoring
private readonly OsuConfigManager configManager; private readonly OsuConfigManager configManager;
private readonly ScoreImporter scoreImporter; private readonly ScoreImporter scoreImporter;
public override bool PauseImports
{
get => base.PauseImports;
set
{
base.PauseImports = value;
scoreImporter.PauseImports = value;
}
}
public ScoreManager(RulesetStore rulesets, Func<BeatmapManager> beatmaps, Storage storage, RealmAccess realm, IAPIProvider api, public ScoreManager(RulesetStore rulesets, Func<BeatmapManager> beatmaps, Storage storage, RealmAccess realm, IAPIProvider api,
OsuConfigManager configManager = null) OsuConfigManager configManager = null)
: base(storage, realm) : base(storage, realm)
@ -38,8 +48,6 @@ namespace osu.Game.Scoring
{ {
PostNotification = obj => PostNotification?.Invoke(obj) PostNotification = obj => PostNotification?.Invoke(obj)
}; };
scoreImporter.PauseImports.BindTo(PauseImports);
} }
public Score GetScore(ScoreInfo score) => scoreImporter.GetScore(score); public Score GetScore(ScoreInfo score) => scoreImporter.GetScore(score);

View File

@ -64,6 +64,16 @@ namespace osu.Game.Skinning
private Skin trianglesSkin { get; } private Skin trianglesSkin { get; }
public override bool PauseImports
{
get => base.PauseImports;
set
{
base.PauseImports = value;
skinImporter.PauseImports = value;
}
}
public SkinManager(Storage storage, RealmAccess realm, GameHost host, IResourceStore<byte[]> resources, AudioManager audio, Scheduler scheduler) public SkinManager(Storage storage, RealmAccess realm, GameHost host, IResourceStore<byte[]> resources, AudioManager audio, Scheduler scheduler)
: base(storage, realm) : base(storage, realm)
{ {
@ -79,8 +89,6 @@ namespace osu.Game.Skinning
PostNotification = obj => PostNotification?.Invoke(obj), PostNotification = obj => PostNotification?.Invoke(obj),
}; };
skinImporter.PauseImports.BindTo(PauseImports);
var defaultSkins = new[] var defaultSkins = new[]
{ {
DefaultClassicSkin = new DefaultLegacySkin(this), DefaultClassicSkin = new DefaultLegacySkin(this),