// Copyright (c) ppy Pty Ltd . Licensed under the MIT Licence. // See the LICENCE file in the repository root for full licence text. #nullable enable using System; using System.Collections.Generic; using osu.Game.Utils; namespace osu.Game.Audio { /// /// Describes a gameplay hit sample. /// [Serializable] public class HitSampleInfo : ISampleInfo, IEquatable { public const string HIT_WHISTLE = @"hitwhistle"; public const string HIT_FINISH = @"hitfinish"; public const string HIT_NORMAL = @"hitnormal"; public const string HIT_CLAP = @"hitclap"; /// /// All valid sample addition constants. /// public static IEnumerable AllAdditions => new[] { HIT_WHISTLE, HIT_CLAP, HIT_FINISH }; /// /// The name of the sample to load. /// public readonly string Name; /// /// The bank to load the sample from. /// public readonly string? Bank; /// /// An optional suffix to provide priority lookup. Falls back to non-suffixed . /// public readonly string? Suffix; /// /// The sample volume. /// public int Volume { get; } public HitSampleInfo(string name, string? bank = null, string? suffix = null, int volume = 100) { Name = name; Bank = bank; Suffix = suffix; Volume = volume; } /// /// Retrieve all possible filenames that can be used as a source, returned in order of preference (highest first). /// public virtual IEnumerable LookupNames { get { if (!string.IsNullOrEmpty(Suffix)) yield return $"Gameplay/{Bank}-{Name}{Suffix}"; yield return $"Gameplay/{Bank}-{Name}"; } } /// /// Creates a new with overridden values. /// /// An optional new sample name. /// An optional new sample bank. /// An optional new lookup suffix. /// An optional new volume. /// The new . public virtual HitSampleInfo With(Optional name = default, Optional bank = default, Optional suffix = default, Optional volume = default) => new HitSampleInfo(name.GetOr(Name), bank.GetOr(Bank), suffix.GetOr(Suffix), volume.GetOr(Volume)); public bool Equals(HitSampleInfo? other) => other != null && Name == other.Name && Bank == other.Bank && Suffix == other.Suffix; public override bool Equals(object? obj) => Equals((HitSampleInfo?)obj); public override int GetHashCode() => HashCode.Combine(Name, Bank, Suffix); } }