|
@@ -60,7 +60,7 @@ protected:
|
|
|
void serializeJsonOptions(JsonSerializeFormat & handler) override;
|
|
void serializeJsonOptions(JsonSerializeFormat & handler) override;
|
|
|
};
|
|
};
|
|
|
|
|
|
|
|
-class DLL_LINKAGE CGGarrison : public CArmedInstance
|
|
|
|
|
|
|
+class DLL_LINKAGE CGGarrison : public CArmedInstance, public IOwnableObject
|
|
|
{
|
|
{
|
|
|
public:
|
|
public:
|
|
|
using CArmedInstance::CArmedInstance;
|
|
using CArmedInstance::CArmedInstance;
|
|
@@ -72,6 +72,10 @@ public:
|
|
|
void onHeroVisit(const CGHeroInstance * h) const override;
|
|
void onHeroVisit(const CGHeroInstance * h) const override;
|
|
|
void battleFinished(const CGHeroInstance *hero, const BattleResult &result) const override;
|
|
void battleFinished(const CGHeroInstance *hero, const BattleResult &result) const override;
|
|
|
|
|
|
|
|
|
|
+ const IOwnableObject * asOwnable() const final;
|
|
|
|
|
+ ResourceSet dailyIncome() const override;
|
|
|
|
|
+ std::vector<CreatureID> providedCreatures() const override;
|
|
|
|
|
+
|
|
|
template <typename Handler> void serialize(Handler &h)
|
|
template <typename Handler> void serialize(Handler &h)
|
|
|
{
|
|
{
|
|
|
h & static_cast<CArmedInstance&>(*this);
|
|
h & static_cast<CArmedInstance&>(*this);
|
|
@@ -80,6 +84,7 @@ public:
|
|
|
protected:
|
|
protected:
|
|
|
void serializeJsonOptions(JsonSerializeFormat & handler) override;
|
|
void serializeJsonOptions(JsonSerializeFormat & handler) override;
|
|
|
void addAntimagicGarrisonBonus();
|
|
void addAntimagicGarrisonBonus();
|
|
|
|
|
+
|
|
|
};
|
|
};
|
|
|
|
|
|
|
|
class DLL_LINKAGE CGArtifact : public CArmedInstance
|
|
class DLL_LINKAGE CGArtifact : public CArmedInstance
|
|
@@ -180,8 +185,9 @@ public:
|
|
|
ui32 defaultResProduction() const;
|
|
ui32 defaultResProduction() const;
|
|
|
ui32 getProducedQuantity() const;
|
|
ui32 getProducedQuantity() const;
|
|
|
|
|
|
|
|
- ResourceSet dailyIncome() const override;
|
|
|
|
|
const IOwnableObject * asOwnable() const final;
|
|
const IOwnableObject * asOwnable() const final;
|
|
|
|
|
+ ResourceSet dailyIncome() const override;
|
|
|
|
|
+ std::vector<CreatureID> providedCreatures() const override;
|
|
|
|
|
|
|
|
protected:
|
|
protected:
|
|
|
void serializeJsonOptions(JsonSerializeFormat & handler) override;
|
|
void serializeJsonOptions(JsonSerializeFormat & handler) override;
|
|
@@ -403,7 +409,7 @@ protected:
|
|
|
void setPropertyDer(ObjProperty what, ObjPropertyID identifier) override;
|
|
void setPropertyDer(ObjProperty what, ObjPropertyID identifier) override;
|
|
|
};
|
|
};
|
|
|
|
|
|
|
|
-class DLL_LINKAGE CGLighthouse : public CGObjectInstance
|
|
|
|
|
|
|
+class DLL_LINKAGE CGLighthouse : public CGObjectInstance, public IOwnableObject
|
|
|
{
|
|
{
|
|
|
public:
|
|
public:
|
|
|
using CGObjectInstance::CGObjectInstance;
|
|
using CGObjectInstance::CGObjectInstance;
|
|
@@ -411,6 +417,10 @@ public:
|
|
|
void onHeroVisit(const CGHeroInstance * h) const override;
|
|
void onHeroVisit(const CGHeroInstance * h) const override;
|
|
|
void initObj(vstd::RNG & rand) override;
|
|
void initObj(vstd::RNG & rand) override;
|
|
|
|
|
|
|
|
|
|
+ const IOwnableObject * asOwnable() const final;
|
|
|
|
|
+ ResourceSet dailyIncome() const override;
|
|
|
|
|
+ std::vector<CreatureID> providedCreatures() const override;
|
|
|
|
|
+
|
|
|
template <typename Handler> void serialize(Handler &h)
|
|
template <typename Handler> void serialize(Handler &h)
|
|
|
{
|
|
{
|
|
|
h & static_cast<CGObjectInstance&>(*this);
|
|
h & static_cast<CGObjectInstance&>(*this);
|