view API/Objects/AbstractUnitEquipmentItemSelection.cs @ 429:7179c585d31d

Re #356: Stack overflow with some equipment limits * Add RawNumberTaken to be used in some locations to avoid indirect recursion * Use new RawNumberTaken within Unit equipment counting method Overflow fixed, but results not correct
author IBBoard <dev@ibboard.co.uk>
date Sun, 06 Nov 2011 20:21:57 +0000
parents 3c4a6403a88c
children c8002429ab45
line wrap: on
line source

// This file (AbstractUnitEquipmentItemSelection.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2009 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
{
	/// <summary>
	/// An abstract class that defines a selection of equipment for a unit
	/// </summary>	
	public abstract class AbstractUnitEquipmentItemSelection
	{
		private Unit selectionForUnit;
		private UnitEquipmentItem selectedItem;
		private double amountTaken;
		
		public AbstractUnitEquipmentItemSelection(Unit unit, UnitEquipmentItem item, double amount)
		{
			selectionForUnit = unit;
			selectedItem = item;
			AmountTaken = amount;
		}
		
		public Unit EquipmentForUnit
		{
			get
			{
				return selectionForUnit;
			}
		}
		
		public UnitEquipmentItem EquipmentItem
		{
			get
			{
				return selectedItem;
			}
		}
		
		public double AmountTaken
		{
			get
			{
				return amountTaken;
			}
			set
			{
				amountTaken = value;
				
				if (!IsValidValue(value))
				{
					//Fire validation failed event (once we have one)
				}
			}
		}
		
		public bool IsValid
		{
			get
			{
				return IsValidValue(AmountTaken) && IsInRange(AmountTaken);
			}	
		}
		
		protected virtual bool IsValidValue(double newValue)
		{
			return true;
		}
		
		protected bool IsInRange(double newValue)
		{
			int unitSize = EquipmentForUnit.Size;
			int minLimit = EquipmentItem.MinLimit.GetLimit(unitSize);
			int maxLimit = EquipmentItem.MaxLimit.GetLimit(unitSize);
			return (minLimit <= newValue) && (newValue <= maxLimit);
		}
		
		public double TotalCost
		{
			get
			{
				return NumberTaken * EquipmentItem.Cost;
			}
		}

		/// <summary>
		/// Gets the number taken as a whole number of times the item was taken. This number may be altered by the limits
		/// placed on the equipment item (e.g. reduced if there is a lower maximum limit)
		/// </summary>
		/// <value>
		/// The number of times the item was taken, modified by any limits.
		/// </value>
		public abstract int NumberTaken
		{
			 get;
		}

		/// <summary>
		/// Gets the raw amount taken as a whole number of times the item was taken.
		/// </summary>
		/// <value>
		/// The unmodified number of times the item was taken.
		/// </value>
		public abstract int RawNumberTaken { get; }
	}
}