blob: 47ae45b690be337f628cde5c3d1a33fe2814eb0f (
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
|
#pragma once
#include "openvic-simulation/types/IdentifierRegistry.hpp"
namespace OpenVic {
struct IdeologyManager;
struct IdeologyGroup : HasIdentifier {
friend struct IdeologyManager;
private:
IdeologyGroup(std::string_view new_identifier);
public:
IdeologyGroup(IdeologyGroup&&) = default;
};
struct Ideology : HasIdentifierAndColour {
friend struct IdeologyManager;
private:
IdeologyGroup const& PROPERTY(group);
const bool PROPERTY_CUSTOM_NAME(uncivilised, is_uncivilised);
const bool PROPERTY(can_reduce_militancy);
const Date PROPERTY(spawn_date);
// TODO - willingness to repeal/pass reforms (and its modifiers)
Ideology(
std::string_view new_identifier, colour_t new_colour, IdeologyGroup const& new_group, bool new_uncivilised,
bool new_can_reduce_militancy, Date new_spawn_date
);
public:
Ideology(Ideology&&) = default;
};
struct IdeologyManager {
private:
IdentifierRegistry<IdeologyGroup> ideology_groups;
IdentifierRegistry<Ideology> ideologies;
public:
IdeologyManager();
bool add_ideology_group(std::string_view identifier);
IDENTIFIER_REGISTRY_ACCESSORS(ideology_group)
bool add_ideology(
std::string_view identifier, colour_t colour, IdeologyGroup const* group, bool uncivilised,
bool can_reduce_militancy, Date spawn_date
);
IDENTIFIER_REGISTRY_ACCESSORS_CUSTOM_PLURAL(ideology, ideologies)
bool load_ideology_file(ast::NodeCPtr root);
};
}
|