aboutsummaryrefslogtreecommitdiff
path: root/map/Province.cpp
diff options
context:
space:
mode:
author ClarkeCode <clarke.john.robert@gmail.com>2023-05-01 02:48:35 +0200
committer ClarkeCode <clarke.john.robert@gmail.com>2023-05-01 02:48:35 +0200
commitc92481448159d3a363d6a99b3025bd2358c3dab6 (patch)
tree3ee57808029036a7edab750f4454aeb6c50f3df3 /map/Province.cpp
Initial commit
Diffstat (limited to 'map/Province.cpp')
-rw-r--r--map/Province.cpp68
1 files changed, 68 insertions, 0 deletions
diff --git a/map/Province.cpp b/map/Province.cpp
new file mode 100644
index 0000000..b3d455b
--- /dev/null
+++ b/map/Province.cpp
@@ -0,0 +1,68 @@
+#include "Province.hpp"
+
+#include <cassert>
+#include <sstream>
+#include <iomanip>
+
+using namespace OpenVic2;
+
+Province::Province(index_t new_index, std::string const& new_identifier, colour_t new_colour) :
+ HasIdentifier{ new_identifier }, HasColour{ new_colour }, index{ new_index }, buildings{ "buildings" } {
+ assert(index != NULL_INDEX);
+ assert(new_colour != NULL_COLOUR);
+}
+
+index_t Province::get_index() const {
+ return index;
+}
+
+Region* Province::get_region() const {
+ return region;
+}
+
+bool Province::is_water() const {
+ return water;
+}
+
+Province::life_rating_t Province::get_life_rating() const {
+ return life_rating;
+}
+
+return_t Province::add_building(BuildingType const& type) {
+ return buildings.add_item({ type });
+}
+
+void Province::lock_buildings() {
+ buildings.lock(false);
+}
+
+void Province::reset_buildings() {
+ buildings.reset();
+}
+
+std::vector<Building> const& Province::get_buildings() const {
+ return buildings.get_items();
+}
+
+return_t Province::expand_building(std::string const& building_type_identifier) {
+ Building* building = buildings.get_item_by_identifier(building_type_identifier);
+ if (building == nullptr) return FAILURE;
+ return building->expand();
+}
+
+std::string Province::to_string() const {
+ std::stringstream stream;
+ stream << "(#" << std::to_string(index) << ", " << get_identifier() << ", 0x" << colour_to_hex_string() << ")";
+ return stream.str();
+}
+
+void Province::update_state(Date const& today) {
+ for (Building& building : buildings.get_items())
+ building.update_state(today);
+
+}
+
+void Province::tick(Date const& today) {
+ for (Building& building : buildings.get_items())
+ building.tick(today);
+}