Mercurial > repos > IBDev-IBBoard.WarFoundry.API
view API/Objects/Requirement/IRequirement.cs @ 455:afc6410e4efc
Re #379: Fix validation of requirements to check for unit
* Move to "Unit" requirements, since we assume things depend on units
* Rename some classes to more meaningful names from unit-based change
* Rename "requires N for M" requirement as we can make it more flexible
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Wed, 22 Feb 2012 20:45:39 +0000 |
parents | 8f5125740316 |
children | 248df19652f9 |
line wrap: on
line source
// This file (Requirement.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2011 IBBoard // // The file and the library/program it is in are licensed and distributed, without warranty, under the GNU Affero GPL license, either version 3 of the License or (at your option) any later version. Please see COPYING for more information and the full license. using System; namespace IBBoard.WarFoundry.API.Objects.Requirement { /// <summary> /// Base interface for a Requirement that constrains the IWarFoundryObjects that can be taken in an army /// </summary> public interface IRequirement { /// <summary> /// Gets the ID of the requirement type. This is used by the requirement factories. /// It may be, but is not required to be, the name of the class. /// </summary> /// <value> /// The ID of the requirement type. /// </value> string RequirementID { get; } /// <summary> /// Checks whether the supplied IWarFoundryObject can be added to the supplied army. /// </summary> /// <returns> /// A <code>Validation</code> enum to show the result of the validation /// </returns> /// <param name='wfObject'> /// The object that we want to add. This may be involved in the check, or it may not affect the evaluation of the requirement /// </param> /// <param name='toArmy'> /// The army to add the object to. /// </param> Validation AllowsAdding(IWarFoundryObject wfObject, Army toArmy); /// <summary> /// Checks whether the supplied army is currently valid according to this requirement. /// </summary> /// <returns> /// A <code>Validation</code> enum to show the result of the validation /// </returns> /// <param name='toValidate'> /// The army to validate /// </param> Validation ValidatesArmy(Army army); /// <summary> /// Gets the validation message from validating the army /// </summary> /// <returns> /// A validation message, if the validation fails, else an empty string. /// </returns> /// <param name='army'> /// The army to validate. /// </param> string GetValidationMessage(Army army); /// <summary> /// Gets the validation message for adding an IWarFoundryObject to the army /// </summary> /// <returns> /// A validation message, if the object cannot be added, else an empty string. /// </returns> /// <param name='toAdd'> /// The IWarFoundryObject to try to add /// </param> /// <param name='toArmy'> /// The army the object will be added to /// </param> string GetAllowsAddingMessage(IWarFoundryObject toAdd, Army toArmy); } }