forked from CleverRaven/Cataclysm-DDA
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathitem_group.h
56 lines (46 loc) · 1.25 KB
/
item_group.h
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
#ifndef _ITEM_GROUP_H_
#define _ITEM_GROUP_H_
#include <vector>
typedef std::string Item_tag;
class Item_group_entry;
class Item_group_group;
class Item_group
{
public:
Item_group(Item_tag id);
const Item_tag get_id();
const Item_tag get_id(std::vector<Item_tag> recursion_list);
void add_entry(const Item_tag item_id, int chance);
void add_group(Item_group*, int chance);
// Does this item group contain the given item?
bool has_item(const Item_tag item_id);
private:
const Item_tag m_id;
int m_max_odds;
std::vector<Item_group_group*> m_groups;
std::vector<Item_group_entry*> m_entries;
};
//Item group entries involve a string value, and an upper bound
//Since items beforehand have already been checked, there is no need
//to add a lower bound value.
class Item_group_entry
{
public:
Item_group_entry(const Item_tag id, int upper_bound);
bool check(int value) const;
const Item_tag get() const;
private:
const Item_tag m_id;
int m_upper_bound;
};
class Item_group_group
{
public:
Item_group_group(Item_group* group, int upper_bound);
bool check(int value) const;
const Item_tag get(std::vector<Item_tag> recursion_list);
private:
Item_group* m_group;
int m_upper_bound;
};
#endif