|
@@ -24,6 +24,7 @@ protected:
|
|
|
|
|
|
private:
|
|
private:
|
|
//personal information
|
|
//personal information
|
|
|
|
+ int cost_;
|
|
double experience_;
|
|
double experience_;
|
|
double level_;
|
|
double level_;
|
|
std::string race_; //lower case
|
|
std::string race_; //lower case
|
|
@@ -52,9 +53,15 @@ private:
|
|
double physic_defence_; //less or equal 40
|
|
double physic_defence_; //less or equal 40
|
|
|
|
|
|
public:
|
|
public:
|
|
- Unit();
|
|
|
|
|
|
+ Unit() = delete;
|
|
|
|
+ Unit(std::string path) {
|
|
|
|
+
|
|
|
|
+ }
|
|
virtual ~Unit() = delete;
|
|
virtual ~Unit() = delete;
|
|
|
|
|
|
|
|
+ int getCost();
|
|
|
|
+ void setCost(int value);
|
|
|
|
+
|
|
double getExperience();
|
|
double getExperience();
|
|
void setExperience(double value);
|
|
void setExperience(double value);
|
|
|
|
|
|
@@ -129,36 +136,4 @@ public:
|
|
virtual bool canAttackToCell(Cell* destination) = 0;
|
|
virtual bool canAttackToCell(Cell* destination) = 0;
|
|
|
|
|
|
virtual bool canAttackUnit(Unit* target) = 0;
|
|
virtual bool canAttackUnit(Unit* target) = 0;
|
|
-};
|
|
|
|
-
|
|
|
|
-class MeleeUnit : public Unit {
|
|
|
|
-protected:
|
|
|
|
-private:
|
|
|
|
-
|
|
|
|
-public:
|
|
|
|
- virtual ~MeleeUnit() = delete;
|
|
|
|
-
|
|
|
|
- virtual bool canAttackForDistance(int distance);
|
|
|
|
-
|
|
|
|
- virtual bool canAttackToCell(Cell* destination);
|
|
|
|
-
|
|
|
|
- virtual bool canAttackUnit(Unit* target);
|
|
|
|
-
|
|
|
|
-};
|
|
|
|
-
|
|
|
|
-class RangeUnit : public Unit {
|
|
|
|
-protected:
|
|
|
|
-private:
|
|
|
|
-
|
|
|
|
-public:
|
|
|
|
- virtual ~RangeUnit() = delete;
|
|
|
|
-};
|
|
|
|
-
|
|
|
|
-template <class Base>
|
|
|
|
-class AbstractUnitCreator {
|
|
|
|
-public:
|
|
|
|
- AbstractUnitCreator() {}
|
|
|
|
- virtual ~AbstractUnitCreator() {}
|
|
|
|
- virtual Base* create() const = 0;
|
|
|
|
-};
|
|
|
|
-
|
|
|
|
|
|
+};
|