Mercurial > repos > IBBoard.WarFoundry.API
comparison api/Commands/AbstractReplaceUnitEquipmentCommand.cs @ 101:f7b9423c2a5a
Big mess of updates, breaking our rules on "commit little and often" because the code was so ugly.
This revision will be broken for the WinForms UI, but as MonoDevelop/eSVN don't have a way of committing multiple projects in one go it can't be helped (Eclipse's Team Sync view could handle it)
Fixes #122: Make usage of percentage or ratio common
* All usage of ratio amounts for equipment items should now assume percentage
* Properly calculate number taken for ratio selection (divide by 0 now we're using percentages)
Fixes #118: Allow equipment amounts of "ratio" equipment to be define as absolute or ratio amounts
* Added extra commands that differentiate between ratio and absolute amounts
Fixes #120: Numeric limit equipment items show large percentages
* Now made formatting treat ratios as percentages (don't multiply by 100)
* Move string formatting to UnitEquipmentItem...Selection classes
* Add method to Unit to say whether an equipment item is a numeric or ratio amount
author | IBBoard <dev@ibboard.co.uk> |
---|---|
date | Thu, 13 Aug 2009 21:09:20 +0000 |
parents | |
children | 2f3cafb69799 |
comparison
equal
deleted
inserted
replaced
100:38e788859199 | 101:f7b9423c2a5a |
---|---|
1 // This file (AbstractReplaceUnitEquipmentCommand.cs) is a part of the IBBoard.WarFoundry.API project and is copyright 2009 IBBoard. | |
2 // | |
3 // The file and the library/program it is in are licensed under the GNU LGPL license, either version 3 of the License or (at your option) any later version. Please see COPYING.LGPL for more information and the full license. | |
4 | |
5 using System; | |
6 using IBBoard.Commands; | |
7 using IBBoard.Lang; | |
8 using IBBoard.WarFoundry.API.Objects; | |
9 | |
10 namespace IBBoard.WarFoundry.API.Commands | |
11 { | |
12 /// <summary> | |
13 /// An abstract implementation of the core method for replacing one equipment item with another | |
14 /// </summary> | |
15 public abstract class AbstractReplaceUnitEquipmentCommand : Command | |
16 { | |
17 private SetUnitEquipmentNumericAmountCommand removeOldCommand; | |
18 private AbstractSetUnitEquipmentAmountCommand addNewCommand; | |
19 | |
20 public AbstractReplaceUnitEquipmentCommand(Unit unit, UnitEquipmentItem oldItem, AbstractSetUnitEquipmentAmountCommand addNewEquipmentCommand) | |
21 { | |
22 //We can get away with a numeric amount here even if it is a ratio item because we're setting it to 0 | |
23 removeOldCommand = new SetUnitEquipmentNumericAmountCommand(unit, oldItem, 0); | |
24 addNewCommand = addNewEquipmentCommand; | |
25 } | |
26 | |
27 public override bool CanExecute() | |
28 { | |
29 return removeOldCommand.CanExecute() && addNewCommand.CanExecute(); | |
30 } | |
31 | |
32 public override string Description | |
33 { | |
34 get { return "Replace "+StringManipulation.CutToLength(removeOldCommand.EquipItem.Name, 20)+" with "+StringManipulation.CutToLength(addNewCommand.EquipItem.Name, 20)+ " for "+StringManipulation.CutToLength(removeOldCommand.Unit.Name, 20); } | |
35 } | |
36 | |
37 public override string UndoDescription | |
38 { | |
39 get { return "Replace "+StringManipulation.CutToLength(addNewCommand.EquipItem.Name, 20)+" with "+StringManipulation.CutToLength(removeOldCommand.EquipItem.Name, 20)+ " for "+StringManipulation.CutToLength(removeOldCommand.Unit.Name, 20); } | |
40 } | |
41 | |
42 public override bool Execute() | |
43 { | |
44 this.Redo(); | |
45 return true; | |
46 } | |
47 | |
48 public override void Redo() | |
49 { | |
50 removeOldCommand.Redo(); | |
51 addNewCommand.Redo(); | |
52 } | |
53 | |
54 public override void Undo() | |
55 { | |
56 addNewCommand.Undo(); | |
57 removeOldCommand.Undo(); | |
58 } | |
59 | |
60 | |
61 public override string Name | |
62 { | |
63 get { return "Replace required equipment"; } | |
64 } | |
65 } | |
66 } |