X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fbattle%2FAttackChoice.h;h=8cba2353a164bccfd155672dd9c9fc5df291aa0c;hb=8639675fbf1d232ab8188dd283149ab650e10336;hp=b11a81da0f2f689ce18b9bfbbfe3c4e998ae3048;hpb=4d0a650b178d81387caa36953ed06cc5d6c28213;p=l2e.git diff --git a/src/battle/AttackChoice.h b/src/battle/AttackChoice.h index b11a81d..8cba235 100644 --- a/src/battle/AttackChoice.h +++ b/src/battle/AttackChoice.h @@ -8,6 +8,14 @@ #ifndef BATTLE_ATTACKCHOICE_H_ #define BATTLE_ATTACKCHOICE_H_ +#include "TargetSelection.h" + +namespace common { + class Ikari; + class Item; + class Spell; +} + namespace battle { class AttackChoice { @@ -23,14 +31,24 @@ public: }; public: - AttackChoice() : type(UNDECIDED) { } + explicit AttackChoice(BattleState *b = 0) : thing(0), selection(b), type(UNDECIDED) { } ~AttackChoice() { } public: Type GetType() const { return type; } void SetType(Type t) { type = t; } + const common::Item *GetItem() const { return (const common::Item *)thing; } + void SetItem(const common::Item *i) { thing = i; } + const common::Spell *GetSpell() const { return (const common::Spell *)thing; } + void SetSpell(const common::Spell *s) { thing = s; } + TargetSelection &Selection() { return selection; } + const TargetSelection &Selection() const { return selection; } + + void Reset(); private: + const void *thing; + TargetSelection selection; Type type; };