// Copyright (C) Stichting Deltares 2016. All rights reserved.
//
// This file is part of Ringtoets.
//
// Ringtoets is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
//
// All names, logos, and references to "Deltares" are registered trademarks of
// Stichting Deltares and remain full property of Stichting Deltares at all times.
// All rights reserved.
namespace Ringtoets.Common.Service.MessageProviders
{
///
/// Interface for providing messages during calculations.
///
public interface ICalculationMessageProvider
{
///
/// Gets the calculation name that can be used for messaging.
///
/// The calculation subject used in the calculation name.
/// The calculation name.
string GetCalculationName(string calculationSubject);
///
/// Gets the activity name that can be used for messaging.
///
/// The calculation subject used in the calculation name.
/// The activity name.
string GetActivityName(string calculationSubject);
///
/// Gets the message that should be used when a calculation fails.
///
/// The calculation subject used in the calculation name.
/// The failure message provided by the calculation.
/// The message.
string GetCalculationFailedMessage(string calculationSubject, string failureMessage);
///
/// Gets the message that should be used when a calculation fails without explanation.
///
/// The calculation subject used in the calculation name.
/// The message.
string GetCalculationFailedUnexplainedMessage(string calculationSubject);
///
/// Gets the message that should be used when a calculation cannot be converged.
///
/// The calculation subject used in the calculation name.
/// The message.
string GetCalculatedNotConvergedMessage(string calculationSubject);
}
}