Mercurial > repos > IBDev-IBBoard.WarFoundry.API
view api/Objects/AbstractUnitEquipmentItemSelection.cs @ 161:81abc04b3dbe
Re #192: Improve "clean coding" practice
* Move some calculation methods for equipment out of the encapsulation objects
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Sun, 04 Oct 2009 12:00:16 +0000 |
parents | 2f3cafb69799 |
children | 36adabb1c3ea |
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 { if (IsValidValue(value)) { amountTaken = value; } else { //Fire validation failed event (once we have one) } } } protected bool IsValidValue(double newValue) { return IsInRange(newValue); } protected abstract bool IsInRange(double newValue); public double TotalCost { get { return NumberTaken * EquipmentItem.Cost; } } public abstract int NumberTaken { get; } public abstract string GetEquipmentAmountString(); } }