view API/Objects/Requirement/RequiresNoMoreThanNOfUnitTypeRequirement.cs @ 343:acd390dba551

Re #27: Unit requirements * First draft of "Unit requires no more than X" requirement
author IBBoard <dev@ibboard.co.uk>
date Wed, 06 Apr 2011 20:05:46 +0000
parents 407757e597f9
children 8585dfacac3b
line wrap: on
line source

// This file (RequiresNoMoreThanNOfUnitTypeRequirement.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 IBBoard.WarFoundry.API.Objects;
using System.Collections.Generic;

namespace IBBoard.WarFoundry.API.Objects.Requirement
{
	/// <summary>
	/// A requirement where a WarFoundryObject cannot be taken in an army if more than N of a UnitType will be in the army.
	/// </summary>
	public class RequiresNoMoreThanNOfUnitTypeRequirement
	{
		private List<UnitCountRequirementData> limitedTypes;

		public RequiresNoMoreThanNOfUnitTypeRequirement(params UnitType[] limitedUnitTypes)
		{
			limitedTypes = new List<UnitCountRequirementData>();

			foreach (UnitType unitType in limitedUnitTypes)
			{
				AddUnitTypeRequirement(unitType);
			}
		}

		/// <summary>
		/// Checks whether the supplied WarFoundryObject 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>
		public virtual Validation AllowsAdding(WarFoundryObject wfObject, Army toArmy)
		{
			Validation canAdd = Validation.Passed;
			
			foreach (UnitCountRequirementData limit in limitedTypes)
			{
				if (toArmy.GetUnitTypeCount(limit.UnitType) > limit.Count)
				{
					canAdd = Validation.Failed;
					break;
				}
			}
			
			return canAdd;
		}

		/// <summary>
		/// Adds a requirement for there to be no more than maxCount of a given UnitType
		/// </summary>
		/// <param name='unitType'>
		/// The unit type to limit.
		/// </param>
		/// <param name='minCount'>
		/// The maximum number of that type that must exist.
		/// </param>
		public void AddUnitTypeRequirement(UnitType unitType, int maxCount)
		{
			limitedTypes.Add(new UnitCountRequirementData(unitType, maxCount));
		}

		/// <summary>
		/// Adds a requirement for there to be none of a given UnitType
		/// </summary>
		/// <param name='unitType'>
		/// The unit type to limit.
		/// </param>
		public void AddUnitTypeRequirement(UnitType unitType)
		{
			AddUnitTypeRequirement(unitType, 0);
		}
	}
}