diff --git a/osu.Game/Database/ArchiveModelManager.cs b/osu.Game/Database/ArchiveModelManager.cs
index dabd8fa2ef..445c8feb3b 100644
--- a/osu.Game/Database/ArchiveModelManager.cs
+++ b/osu.Game/Database/ArchiveModelManager.cs
@@ -486,7 +486,7 @@ namespace osu.Game.Database
///
/// Set a storage with access to an osu-stable install for import purposes.
///
- public Func GetStableStorage { protected get; set; }
+ public Func GetStableStorage { private get; set; }
///
/// Denotes whether an osu-stable installation is present to perform automated imports from.
@@ -501,7 +501,7 @@ namespace osu.Game.Database
///
/// Selects paths to import from.
///
- protected abstract IEnumerable GetStableImportPaths();
+ protected virtual IEnumerable GetStableImportPaths(Storage stableStoage) => stableStoage.GetDirectories(ImportFromStablePath);
///
/// Whether this specified path should be removed after successful import.
@@ -530,7 +530,7 @@ namespace osu.Game.Database
return Task.CompletedTask;
}
- return Task.Run(async () => await Import(GetStableImportPaths().Select(f => stable.GetFullPath(f)).ToArray()));
+ return Task.Run(async () => await Import(GetStableImportPaths(GetStableStorage()).Select(f => stable.GetFullPath(f)).ToArray()));
}
#endregion
diff --git a/osu.Game/Scoring/ScoreManager.cs b/osu.Game/Scoring/ScoreManager.cs
index 4c7de90d6f..770b56e1fe 100644
--- a/osu.Game/Scoring/ScoreManager.cs
+++ b/osu.Game/Scoring/ScoreManager.cs
@@ -56,9 +56,8 @@ namespace osu.Game.Scoring
}
}
- protected override IEnumerable GetStableImportPaths()
- => GetStableStorage().GetFiles(ImportFromStablePath)
- .Where(p => HandledExtensions.Any(ext => Path.GetExtension(p)?.Equals(ext, StringComparison.InvariantCultureIgnoreCase) ?? false));
+ protected override IEnumerable GetStableImportPaths(Storage stableStorage)
+ => stableStorage.GetFiles(ImportFromStablePath).Where(p => HandledExtensions.Any(ext => Path.GetExtension(p)?.Equals(ext, StringComparison.InvariantCultureIgnoreCase) ?? false));
public Score GetScore(ScoreInfo score) => new LegacyDatabasedScore(score, rulesets, beatmaps(), Files.Store);
diff --git a/osu.Game/Skinning/SkinManager.cs b/osu.Game/Skinning/SkinManager.cs
index 3509263e6f..70abfac501 100644
--- a/osu.Game/Skinning/SkinManager.cs
+++ b/osu.Game/Skinning/SkinManager.cs
@@ -55,8 +55,6 @@ namespace osu.Game.Skinning
};
}
- protected override IEnumerable GetStableImportPaths() => GetStableStorage().GetDirectories(ImportFromStablePath);
-
protected override bool ShouldDeleteArchive(string path) => Path.GetExtension(path)?.ToLowerInvariant() == ".osk";
///