view API/Objects/Requirement/RequirementHandler.cs @ 361:8781e53c59bb

Re #345: Add failure message to requirements * Return message for each failure (don't stop at first one)
author IBBoard <dev@ibboard.co.uk>
date Sun, 01 May 2011 14:45:56 +0000
parents 47712a323cf2
children 506af4cbe3f5
line wrap: on
line source

// This file (RequirementHandler.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;
using System.Collections.Generic;

namespace IBBoard.WarFoundry.API.Objects.Requirement
{
	/// <summary>
	/// The requirement handler that tests the validity of armies.
	/// </summary>
	public class RequirementHandler
	{
		private RequirementHandler()
		{
		}

		public static Validation ValidateArmy (Army army)
		{
			ICollection<string> ignored;
			return ValidateArmy(army, out ignored);
		}

		public static Validation ValidateArmy (Army army, out ICollection<string> failureMessages)
		{
			Validation result = Validation.Passed;
			failureMessages = new List<string>();

			foreach (IRequirement requirement in army.GetRequirements())
			{
				if (!Validates.AsOkay(requirement.ValidatesArmy(army)))
				{
					result = Validation.Failed;
					failureMessages.Add(requirement.GetValidationMessage(army));
				}
			}

			return result;
		}

		public static Validation AllowsAdding(UnitType unitType, Army army)
		{
			Validation result = Validation.Passed;

			foreach (IRequirement requirement in army.GetRequirements())
			{
				if (!Validates.AsOkay(requirement.AllowsAdding(unitType, army)))
				{
					result = Validation.Failed;
					break;
				}
			}

			return result;
		}
	}
}