aboutsummaryrefslogtreecommitdiff
path: root/src/openvic-simulation/country/Country.hpp
diff options
context:
space:
mode:
author hop311 <hop3114@gmail.com>2024-06-15 00:06:19 +0200
committer hop311 <hop3114@gmail.com>2024-06-20 20:33:02 +0200
commit41d50b15ac978530a53ed99eea36f180e1d27b16 (patch)
tree236036a544c54d678fc79344677566c3b060d335 /src/openvic-simulation/country/Country.hpp
parentbfd539513af435564daf70f94f6cce146dd5c948 (diff)
Renamed Country to CountryDefinitioncountry-definition
Diffstat (limited to 'src/openvic-simulation/country/Country.hpp')
-rw-r--r--src/openvic-simulation/country/Country.hpp99
1 files changed, 0 insertions, 99 deletions
diff --git a/src/openvic-simulation/country/Country.hpp b/src/openvic-simulation/country/Country.hpp
deleted file mode 100644
index 001f1ff..0000000
--- a/src/openvic-simulation/country/Country.hpp
+++ /dev/null
@@ -1,99 +0,0 @@
-#pragma once
-
-#include <string_view>
-
-#include <openvic-dataloader/v2script/AbstractSyntaxTree.hpp>
-
-#include "openvic-simulation/dataloader/Dataloader.hpp"
-#include "openvic-simulation/military/UnitType.hpp"
-#include "openvic-simulation/politics/Government.hpp"
-#include "openvic-simulation/politics/Ideology.hpp"
-#include "openvic-simulation/politics/Issue.hpp"
-#include "openvic-simulation/politics/PoliticsManager.hpp"
-#include "openvic-simulation/pop/Culture.hpp"
-#include "openvic-simulation/types/Colour.hpp"
-#include "openvic-simulation/types/Date.hpp"
-#include "openvic-simulation/types/IdentifierRegistry.hpp"
-#include "openvic-simulation/types/OrderedContainers.hpp"
-
-namespace OpenVic {
- struct DefinitionManager;
- struct CountryManager;
-
- struct CountryParty : HasIdentifierAndColour {
- friend struct CountryManager;
-
- using policy_map_t = ordered_map<IssueGroup const*, Issue const*>;
-
- private:
- const Date PROPERTY(start_date);
- const Date PROPERTY(end_date);
- Ideology const& PROPERTY(ideology);
- policy_map_t PROPERTY(policies);
-
- CountryParty(
- std::string_view new_identifier, Date new_start_date, Date new_end_date, Ideology const& new_ideology,
- policy_map_t&& new_policies
- );
-
- public:
- CountryParty(CountryParty&&) = default;
- };
-
- /* Generic information about a TAG */
- struct Country : HasIdentifierAndColour {
- friend struct CountryManager;
-
- using unit_names_map_t = ordered_map<UnitType const*, name_list_t>;
- using government_colour_map_t = ordered_map<GovernmentType const*, colour_t>;
-
- private:
- const size_t PROPERTY(index);
- GraphicalCultureType const& PROPERTY(graphical_culture);
- /* Not const to allow elements to be moved, otherwise a copy is forced
- * which causes a compile error as the copy constructor has been deleted. */
- IdentifierRegistry<CountryParty> IDENTIFIER_REGISTRY_CUSTOM_PLURAL(party, parties);
- unit_names_map_t PROPERTY(unit_names);
- const bool PROPERTY_CUSTOM_PREFIX(dynamic_tag, is);
- government_colour_map_t PROPERTY(alternative_colours);
- colour_t PROPERTY(primary_unit_colour);
- colour_t PROPERTY(secondary_unit_colour);
- colour_t PROPERTY(tertiary_unit_colour);
- // Unit colours not const due to being added after construction
-
- Country(
- std::string_view new_identifier, colour_t new_colour, size_t new_index,
- GraphicalCultureType const& new_graphical_culture, IdentifierRegistry<CountryParty>&& new_parties,
- unit_names_map_t&& new_unit_names, bool new_dynamic_tag, government_colour_map_t&& new_alternative_colours,
- colour_t new_primary_unit_colour, colour_t new_secondary_unit_colour, colour_t new_tertiary_unit_colour
- );
-
- public:
- Country(Country&&) = default;
-
- // TODO - get_colour including alternative colours
- };
-
- struct CountryManager {
- private:
- IdentifierRegistry<Country> IDENTIFIER_REGISTRY_CUSTOM_PLURAL(country, countries);
-
- NodeTools::node_callback_t load_country_party(
- PoliticsManager const& politics_manager, IdentifierRegistry<CountryParty>& country_parties
- ) const;
-
- public:
- bool add_country(
- std::string_view identifier, colour_t colour, GraphicalCultureType const* graphical_culture,
- IdentifierRegistry<CountryParty>&& parties, Country::unit_names_map_t&& unit_names, bool dynamic_tag,
- Country::government_colour_map_t&& alternative_colours
- );
-
- bool load_country_colours(ast::NodeCPtr root);
-
- bool load_countries(DefinitionManager const& definition_manager, Dataloader const& dataloader, ast::NodeCPtr root);
- bool load_country_data_file(
- DefinitionManager const& definition_manager, std::string_view name, bool is_dynamic, ast::NodeCPtr root
- );
- };
-}