aboutsummaryrefslogtreecommitdiff
path: root/src/openvic-simulation/map/MapInstance.hpp
blob: d2d9a2694f167ac8d88582eb69f6f0c358c76975 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#pragma once

#include "openvic-simulation/map/ProvinceDefinition.hpp"
#include "openvic-simulation/map/ProvinceInstance.hpp"
#include "openvic-simulation/map/State.hpp"
#include "openvic-simulation/types/Date.hpp"
#include "openvic-simulation/types/IdentifierRegistry.hpp"

namespace OpenVic {
   struct MapDefinition;
   struct BuildingTypeManager;
   struct ProvinceHistoryManager;
   struct IssueManager;

   /* REQUIREMENTS:
    * MAP-4
    */
   struct MapInstance {
      MapDefinition const& PROPERTY(map_definition);

      IdentifierRegistry<ProvinceInstance> IDENTIFIER_REGISTRY_CUSTOM_INDEX_OFFSET(province_instance, 1);

      ProvinceInstance* PROPERTY(selected_province); // is it right for this to be mutable? how about using an index instead?
      Pop::pop_size_t PROPERTY(highest_province_population);
      Pop::pop_size_t PROPERTY(total_map_population);

      StateManager PROPERTY_REF(state_manager);

   public:
      MapInstance(MapDefinition const& new_map_definition);

      inline explicit constexpr operator MapDefinition const&() const {
         return map_definition;
      }

      IDENTIFIER_REGISTRY_NON_CONST_ACCESSORS_CUSTOM_INDEX_OFFSET(province_instance, 1);

      ProvinceInstance& get_province_instance_from_definition(ProvinceDefinition const& province);
      ProvinceInstance const& get_province_instance_from_definition(ProvinceDefinition const& province) const;

      void set_selected_province(ProvinceDefinition::index_t index);
      ProvinceInstance* get_selected_province();
      ProvinceDefinition::index_t get_selected_province_index() const;

      bool setup(
         BuildingTypeManager const& building_type_manager,
         decltype(ProvinceInstance::pop_type_distribution)::keys_t const& pop_type_keys,
         decltype(ProvinceInstance::ideology_distribution)::keys_t const& ideology_keys
      );
      bool apply_history_to_provinces(
         ProvinceHistoryManager const& history_manager, Date date, CountryInstanceManager& country_manager,
         IssueManager const& issue_manager
      );

      void update_gamestate(Date today);
      void tick(Date today);
   };
}