view API/Objects/UnitEquipmentNumericSelection.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 (UnitEquipmentNumericSelection.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 object to hold the selection of a unit's equipment where the selection was made as an absolute number
	/// </summary>
	public class UnitEquipmentNumericSelection : AbstractUnitEquipmentItemSelection
	{	
		public UnitEquipmentNumericSelection(Unit unit, UnitEquipmentItem item, double amount) : base(unit, item, amount)
		{
		}
		
		public UnitEquipmentNumericSelection(Unit unit, UnitEquipmentItem item) : base(unit, item, item.MinLimit.GetLimit(unit.Size))
		{
		}
					
		public override int NumberTaken
		{
			get
			{
				return RawNumberTaken;
			}
		}

		public override int RawNumberTaken
		{
			get
			{
				return (int)AmountTaken;
			}
		}
		
		protected bool IsWholeNumber(double newValue)
		{
			return newValue == Math.Round(newValue);
		}
		
		protected override bool IsValidValue (double newValue)
		{
			return base.IsValidValue(newValue) && IsWholeNumber(newValue);
		}
	}
}