#include "Region.hpp" using namespace OpenVic; ProvinceSet::ProvinceSet(provinces_t&& new_provinces) : provinces { std::move(new_provinces) } {} bool ProvinceSet::add_province(Province* province) { if (locked) { Logger::error("Cannot add province to province set - locked!"); return false; } if (province == nullptr) { Logger::error("Cannot add province to province set - null province!"); return false; } if (contains_province(province)) { Logger::error("Cannot add province ", province->get_identifier(), " to province set - already in the set!"); return false; } provinces.push_back(province); return true; } void ProvinceSet::lock(bool log) { if (locked) { Logger::error("Failed to lock province set - already locked!"); } else { locked = true; if (log) Logger::info("Locked province set with ", size(), " provinces"); } } bool ProvinceSet::is_locked() const { return locked; } void ProvinceSet::reset() { provinces.clear(); locked = false; } bool ProvinceSet::empty() const { return provinces.empty(); } size_t ProvinceSet::size() const { return provinces.size(); } void ProvinceSet::reserve(size_t size) { if (locked) { Logger::error("Failed to reserve space for ", size, " items in province set - already locked!"); } else { provinces.reserve(size); } } bool ProvinceSet::contains_province(Province const* province) const { return province && std::find(provinces.begin(), provinces.end(), province) != provinces.end(); } ProvinceSet::provinces_t const& ProvinceSet::get_provinces() const { return provinces; } Region::Region(const std::string_view new_identifier, provinces_t&& new_provinces, bool new_meta) : HasIdentifier { new_identifier }, ProvinceSet { std::move(new_provinces) }, meta { new_meta } { lock(); } bool Region::get_meta() const { return meta; } colour_t Region::get_colour() const { if (empty()) return FULL_COLOUR << 16; return get_provinces().front()->get_colour(); }