mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 12:45:09 +08:00
Prefer provided resource store over realm backed to keep tests working
This commit is contained in:
parent
b4d89b4e31
commit
35d2f973a3
@ -69,7 +69,7 @@ namespace osu.Game.Skinning
|
|||||||
/// <param name="resources">Access to raw game resources.</param>
|
/// <param name="resources">Access to raw game resources.</param>
|
||||||
/// <param name="configurationStream">An optional stream containing the contents of a skin.ini file.</param>
|
/// <param name="configurationStream">An optional stream containing the contents of a skin.ini file.</param>
|
||||||
protected LegacySkin(SkinInfo skin, [CanBeNull] IResourceStore<byte[]> storage, [CanBeNull] IStorageResourceProvider resources, [CanBeNull] Stream configurationStream)
|
protected LegacySkin(SkinInfo skin, [CanBeNull] IResourceStore<byte[]> storage, [CanBeNull] IStorageResourceProvider resources, [CanBeNull] Stream configurationStream)
|
||||||
: base(skin, resources, configurationStream)
|
: base(skin, resources, storage, configurationStream)
|
||||||
{
|
{
|
||||||
// todo: this shouldn't really be duplicated here (from ManiaLegacySkinTransformer). we need to come up with a better solution.
|
// todo: this shouldn't really be duplicated here (from ManiaLegacySkinTransformer). we need to come up with a better solution.
|
||||||
hasKeyTexture = new Lazy<bool>(() => this.GetAnimation(
|
hasKeyTexture = new Lazy<bool>(() => this.GetAnimation(
|
||||||
|
@ -13,6 +13,7 @@ using osu.Framework.Bindables;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.OpenGL.Textures;
|
using osu.Framework.Graphics.OpenGL.Textures;
|
||||||
using osu.Framework.Graphics.Textures;
|
using osu.Framework.Graphics.Textures;
|
||||||
|
using osu.Framework.IO.Stores;
|
||||||
using osu.Framework.Logging;
|
using osu.Framework.Logging;
|
||||||
using osu.Game.Audio;
|
using osu.Game.Audio;
|
||||||
using osu.Game.Database;
|
using osu.Game.Database;
|
||||||
@ -51,30 +52,36 @@ namespace osu.Game.Skinning
|
|||||||
|
|
||||||
public abstract IBindable<TValue> GetConfig<TLookup, TValue>(TLookup lookup);
|
public abstract IBindable<TValue> GetConfig<TLookup, TValue>(TLookup lookup);
|
||||||
|
|
||||||
private readonly RealmBackedResourceStore skinStorage;
|
protected Skin(SkinInfo skin, [CanBeNull] IStorageResourceProvider resources, [CanBeNull] IResourceStore<byte[]> storage = null, [CanBeNull] Stream configurationStream = null)
|
||||||
|
|
||||||
protected Skin(SkinInfo skin, IStorageResourceProvider resources, [CanBeNull] Stream configurationStream = null)
|
|
||||||
{
|
{
|
||||||
if (resources.RealmAccess != null)
|
if (resources != null)
|
||||||
{
|
{
|
||||||
SkinInfo = skin.ToLive(resources.RealmAccess);
|
if (resources.RealmAccess != null)
|
||||||
skinStorage = new RealmBackedResourceStore(skin, resources.Files);
|
{
|
||||||
|
SkinInfo = skin.ToLive(resources.RealmAccess);
|
||||||
|
|
||||||
var samples = resources?.AudioManager?.GetSampleStore(skinStorage);
|
if (storage == null)
|
||||||
|
{
|
||||||
|
var realmStorage = new RealmBackedResourceStore(skin, resources.Files);
|
||||||
|
realmStorage.AddExtension("ogg");
|
||||||
|
|
||||||
|
storage = realmStorage;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SkinInfo = skin.ToLiveUnmanaged();
|
||||||
|
}
|
||||||
|
|
||||||
|
var samples = resources.AudioManager?.GetSampleStore(storage);
|
||||||
if (samples != null)
|
if (samples != null)
|
||||||
samples.PlaybackConcurrency = OsuGameBase.SAMPLE_CONCURRENCY;
|
samples.PlaybackConcurrency = OsuGameBase.SAMPLE_CONCURRENCY;
|
||||||
|
|
||||||
Samples = samples;
|
Samples = samples;
|
||||||
Textures = new TextureStore(resources?.CreateTextureLoaderStore(skinStorage));
|
Textures = new TextureStore(resources.CreateTextureLoaderStore(storage));
|
||||||
|
|
||||||
skinStorage.AddExtension("ogg");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SkinInfo = skin.ToLiveUnmanaged();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
configurationStream ??= skinStorage?.GetStream(@"skin.ini");
|
configurationStream ??= storage?.GetStream(@"skin.ini");
|
||||||
|
|
||||||
if (configurationStream != null)
|
if (configurationStream != null)
|
||||||
// stream will be closed after use by LineBufferedReader.
|
// stream will be closed after use by LineBufferedReader.
|
||||||
@ -87,7 +94,7 @@ namespace osu.Game.Skinning
|
|||||||
{
|
{
|
||||||
string filename = $"{skinnableTarget}.json";
|
string filename = $"{skinnableTarget}.json";
|
||||||
|
|
||||||
byte[] bytes = skinStorage?.Get(filename);
|
byte[] bytes = storage?.Get(filename);
|
||||||
|
|
||||||
if (bytes == null)
|
if (bytes == null)
|
||||||
continue;
|
continue;
|
||||||
|
Loading…
Reference in New Issue
Block a user