From 7a0726bcffb26806c0bd975a57aa77dd0db255ff Mon Sep 17 00:00:00 2001 From: Ivan Savenko Date: Wed, 4 Sep 2024 19:46:15 +0000 Subject: [PATCH 1/3] Apply x2 bonus only to creature growth of affected creature on new month --- server/processors/NewTurnProcessor.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/processors/NewTurnProcessor.cpp b/server/processors/NewTurnProcessor.cpp index be883645a..a81481987 100644 --- a/server/processors/NewTurnProcessor.cpp +++ b/server/processors/NewTurnProcessor.cpp @@ -280,7 +280,7 @@ SetAvailableCreatures NewTurnProcessor::generateTownGrowth(const CGTownInstance if (weekType == EWeekType::PLAGUE) resultingCreatures = creaturesBefore / 2; - else if (weekType == EWeekType::DOUBLE_GROWTH) + else if (weekType == EWeekType::DOUBLE_GROWTH && vstd::contains(t->creatures.at(k).second, creatureWeek)) resultingCreatures = (creaturesBefore + creatureGrowth) * 2; else resultingCreatures = creaturesBefore + creatureGrowth; From dae9e1e31669cc307b8ac5dace0c7e3f0397699f Mon Sep 17 00:00:00 2001 From: Ivan Savenko Date: Wed, 4 Sep 2024 19:46:36 +0000 Subject: [PATCH 2/3] Implement IOwnableObject interface for shipyard --- lib/mapObjects/MiscObjects.cpp | 15 +++++++++++++++ lib/mapObjects/MiscObjects.h | 6 +++++- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/lib/mapObjects/MiscObjects.cpp b/lib/mapObjects/MiscObjects.cpp index a9f18cb55..4a9b589d4 100644 --- a/lib/mapObjects/MiscObjects.cpp +++ b/lib/mapObjects/MiscObjects.cpp @@ -1227,6 +1227,21 @@ BoatId CGShipyard::getBoatType() const return createdBoat; } +const IOwnableObject * CGShipyard::asOwnable() const +{ + return this; +} + +ResourceSet CGShipyard::dailyIncome() const +{ + return {}; +} + +std::vector CGShipyard::providedCreatures() const +{ + return {}; +} + void CGDenOfthieves::onHeroVisit (const CGHeroInstance * h) const { cb->showObjectWindow(this, EOpenWindowMode::THIEVES_GUILD, h, false); diff --git a/lib/mapObjects/MiscObjects.h b/lib/mapObjects/MiscObjects.h index 58366c167..862d52596 100644 --- a/lib/mapObjects/MiscObjects.h +++ b/lib/mapObjects/MiscObjects.h @@ -346,7 +346,7 @@ public: } }; -class DLL_LINKAGE CGShipyard : public CGObjectInstance, public IShipyard +class DLL_LINKAGE CGShipyard : public CGObjectInstance, public IShipyard, public IOwnableObject { friend class ShipyardInstanceConstructor; @@ -358,6 +358,10 @@ protected: const IObjectInterface * getObject() const override; BoatId getBoatType() const override; + const IOwnableObject * asOwnable() const final; + ResourceSet dailyIncome() const override; + std::vector providedCreatures() const override; + public: using CGObjectInstance::CGObjectInstance; From 44fdb719336a59c6b440abe19d3ebb356735a4d9 Mon Sep 17 00:00:00 2001 From: Ivan Savenko Date: Wed, 4 Sep 2024 19:46:58 +0000 Subject: [PATCH 3/3] Machine Factory and Refugee Camp can't be owned --- lib/mapObjects/CGDwelling.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/lib/mapObjects/CGDwelling.cpp b/lib/mapObjects/CGDwelling.cpp index 4c8e473fb..983194342 100644 --- a/lib/mapObjects/CGDwelling.cpp +++ b/lib/mapObjects/CGDwelling.cpp @@ -536,7 +536,14 @@ void CGDwelling::serializeJsonOptions(JsonSerializeFormat & handler) const IOwnableObject * CGDwelling::asOwnable() const { - return this; + switch (ID.toEnum()) + { + case Obj::WAR_MACHINE_FACTORY: + case Obj::REFUGEE_CAMP: + return nullptr; // can't be owned + default: + return this; + } } ResourceSet CGDwelling::dailyIncome() const