Mercurial > repos > IBBoard.WarFoundry.API
view api/Commands/AbstractReplaceUnitEquipmentCommand.cs @ 206:0ca96143aa03
Re #211: Swapping from percentage to numeric selection doesn't remove old selection
* Use Unit's "RemoveEquipmentItem" method instead of just removing from the equipment list and not the slot list
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Mon, 09 Nov 2009 12:20:34 +0000 |
parents | 2f3cafb69799 |
children | 391446c9b250 |
line wrap: on
line source
// This file (AbstractReplaceUnitEquipmentCommand.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; using IBBoard.Commands; using IBBoard.Lang; using IBBoard.WarFoundry.API.Objects; namespace IBBoard.WarFoundry.API.Commands { /// <summary> /// An abstract implementation of the core method for replacing one equipment item with another /// </summary> public abstract class AbstractReplaceUnitEquipmentCommand : Command { private SetUnitEquipmentNumericAmountCommand removeOldCommand; private AbstractSetUnitEquipmentAmountCommand addNewCommand; public AbstractReplaceUnitEquipmentCommand(Unit unit, UnitEquipmentItem oldItem, AbstractSetUnitEquipmentAmountCommand addNewEquipmentCommand) { //We can get away with a numeric amount here even if it is a ratio item because we're setting it to 0 removeOldCommand = new SetUnitEquipmentNumericAmountCommand(unit, oldItem, 0); addNewCommand = addNewEquipmentCommand; } public override bool CanExecute() { return removeOldCommand.CanExecute() && addNewCommand.CanExecute(); } public override string Description { get { return "Replace "+StringManipulation.CutToLength(removeOldCommand.EquipItem.Name, 20)+" with "+StringManipulation.CutToLength(addNewCommand.EquipItem.Name, 20)+ " for "+StringManipulation.CutToLength(removeOldCommand.Unit.Name, 20); } } public override string UndoDescription { get { return "Replace "+StringManipulation.CutToLength(addNewCommand.EquipItem.Name, 20)+" with "+StringManipulation.CutToLength(removeOldCommand.EquipItem.Name, 20)+ " for "+StringManipulation.CutToLength(removeOldCommand.Unit.Name, 20); } } public override bool Execute() { this.Redo(); return true; } public override void Redo() { removeOldCommand.Redo(); addNewCommand.Redo(); } public override void Undo() { addNewCommand.Undo(); removeOldCommand.Undo(); } public override string Name { get { return "Replace required equipment"; } } } }