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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
use df_st_core::{Filler, HasUnknown};
use df_st_derive::{HasUnknown, HashAndPartialEqById};
use indexmap::IndexMap;
use serde::{Deserialize, Serialize};
use serde_json::Value;
use std::collections::HashMap;
#[derive(Serialize, Deserialize, Clone, Debug, HasUnknown, HashAndPartialEqById)]
pub struct Site {
pub id: i32,
pub civ_id: Option<i32>,
pub cur_owner_id: Option<i32>,
pub structures: Option<Structures>,
#[serde(flatten)]
pub unknown: HashMap<String, Value>,
}
#[derive(Serialize, Deserialize, Clone, Debug, HasUnknown)]
pub struct Sites {
pub site: Option<Vec<Site>>,
#[serde(flatten)]
pub unknown: HashMap<String, Value>,
}
#[derive(Serialize, Deserialize, Clone, Debug, HasUnknown)]
pub struct Structure {
pub id: i32,
#[serde(alias = "type")]
pub type_: Option<String>,
pub name: Option<String>,
pub name2: Option<String>,
pub deity_type: Option<i32>,
pub deity: Option<i32>,
pub religion: Option<i32>,
pub dungeon_type: Option<i32>,
pub inhabitant: Option<Vec<i32>>,
#[serde(flatten)]
pub unknown: HashMap<String, Value>,
}
#[derive(Serialize, Deserialize, Clone, Debug, HasUnknown)]
pub struct Structures {
pub structure: Option<Vec<Structure>>,
#[serde(flatten)]
pub unknown: HashMap<String, Value>,
}
impl Filler<df_st_core::Site, Site> for df_st_core::Site {
fn add_missing_data(&mut self, source: &Site) {
self.id.add_missing_data(&source.id);
if let Some(civ_id) = &source.civ_id {
if civ_id >= &0 {
self.civ_id.add_missing_data(&source.civ_id);
}
}
if let Some(cur_owner_id) = &source.cur_owner_id {
if cur_owner_id >= &0 {
self.cur_owner_id.add_missing_data(&source.cur_owner_id);
}
}
if let Some(structures) = &source.structures {
self.structures.add_missing_data(&structures.structure);
}
}
}
impl Filler<df_st_core::Structure, Structure> for df_st_core::Structure {
fn add_missing_data(&mut self, source: &Structure) {
self.local_id.add_missing_data(&source.id);
let mut source_type = source.type_.clone();
if let Some(type_) = &source.type_ {
source_type = Some(type_.replace("_", " "));
}
self.type_.add_missing_data(&source_type);
self.name.replace_data(&source.name);
self.name2.add_missing_data(&source.name2);
self.deity_type.add_missing_data(&source.deity_type);
self.deity_id.add_missing_data(&source.deity);
self.religion_id.add_missing_data(&source.religion);
self.dungeon_type.add_missing_data(&source.dungeon_type);
self.inhabitant.add_missing_data(&source.inhabitant);
}
}
impl PartialEq<df_st_core::Site> for Site {
fn eq(&self, other: &df_st_core::Site) -> bool {
self.id == other.id
}
}
impl PartialEq<df_st_core::Structure> for Structure {
fn eq(&self, other: &df_st_core::Structure) -> bool {
self.id == other.local_id
}
}
impl Filler<Vec<df_st_core::Site>, Sites> for Vec<df_st_core::Site> {
fn add_missing_data(&mut self, source: &Sites) {
self.add_missing_data(&source.site);
}
}
impl Filler<IndexMap<u64, df_st_core::Site>, Sites> for IndexMap<u64, df_st_core::Site> {
fn add_missing_data(&mut self, source: &Sites) {
self.add_missing_data(&source.site);
}
}