2021-02-24 05:32:50 +00:00
|
|
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
|
|
|
// See the LICENCE file in the repository root for full licence text.
|
|
|
|
|
|
|
|
using System;
|
2021-08-12 02:12:35 +00:00
|
|
|
using osu.Framework.Bindables;
|
|
|
|
using osu.Game.Configuration;
|
2021-02-24 05:32:50 +00:00
|
|
|
using osu.Game.Rulesets.Judgements;
|
|
|
|
using osu.Game.Rulesets.Scoring;
|
|
|
|
|
|
|
|
namespace osu.Game.Rulesets.Mods
|
|
|
|
{
|
|
|
|
public abstract class ModFailCondition : Mod, IApplicableToHealthProcessor, IApplicableFailOverride
|
|
|
|
{
|
|
|
|
public override Type[] IncompatibleMods => new[] { typeof(ModNoFail), typeof(ModRelax), typeof(ModAutoplay) };
|
|
|
|
|
2021-08-12 02:12:35 +00:00
|
|
|
[SettingSource("Restart on fail", "Automatically restarts when failed.")]
|
|
|
|
public BindableBool Restart { get; } = new BindableBool();
|
|
|
|
|
2021-02-24 06:03:37 +00:00
|
|
|
public virtual bool PerformFail() => true;
|
2021-02-24 05:32:50 +00:00
|
|
|
|
2021-08-12 02:14:01 +00:00
|
|
|
public virtual bool RestartOnFail => Restart.Value;
|
2023-04-26 06:27:58 +00:00
|
|
|
|
|
|
|
private Action? triggerFailureDelegate;
|
2021-02-24 05:32:50 +00:00
|
|
|
|
|
|
|
public void ApplyToHealthProcessor(HealthProcessor healthProcessor)
|
|
|
|
{
|
2023-04-26 06:27:58 +00:00
|
|
|
triggerFailureDelegate = healthProcessor.TriggerFailure;
|
2021-02-24 05:32:50 +00:00
|
|
|
healthProcessor.FailConditions += FailCondition;
|
|
|
|
}
|
|
|
|
|
2022-06-08 18:02:15 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Immediately triggers a failure on the loaded <see cref="HealthProcessor"/>.
|
|
|
|
/// </summary>
|
2023-04-26 06:27:58 +00:00
|
|
|
protected void TriggerFailure() => triggerFailureDelegate?.Invoke();
|
2022-06-08 18:02:15 +00:00
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Determines whether <paramref name="result"/> should trigger a failure. Called every time a
|
|
|
|
/// judgement is applied to <paramref name="healthProcessor"/>.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="healthProcessor">The loaded <see cref="HealthProcessor"/>.</param>
|
|
|
|
/// <param name="result">The latest <see cref="JudgementResult"/>.</param>
|
|
|
|
/// <returns>Whether the fail condition has been met.</returns>
|
|
|
|
/// <remarks>
|
|
|
|
/// This method should only be used to trigger failures based on <paramref name="result"/>.
|
|
|
|
/// Using outside values to evaluate failure may introduce event ordering discrepancies, use
|
2022-06-10 17:11:17 +00:00
|
|
|
/// an <see cref="IApplicableMod"/> with <see cref="TriggerFailure"/> instead.
|
2022-06-08 18:02:15 +00:00
|
|
|
/// </remarks>
|
2021-02-24 05:32:50 +00:00
|
|
|
protected abstract bool FailCondition(HealthProcessor healthProcessor, JudgementResult result);
|
|
|
|
}
|
|
|
|
}
|