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
use df_st_core::{Filler, HasUnknown};
use df_st_derive::{HasUnknown, HashAndPartialEqById};
use indexmap::IndexMap;
#[allow(unused_imports)]
use log::{debug, error, info, trace, warn};
use serde::{Deserialize, Serialize};
use serde_json::Value;
use std::collections::HashMap;
#[derive(Serialize, Deserialize, Clone, Debug, HasUnknown, HashAndPartialEqById)]
pub struct HistoricalFigure {
pub id: i32,
pub sex: Option<i32>,
pub race: Option<String>,
#[serde(flatten)]
pub unknown: HashMap<String, Value>,
}
#[derive(Serialize, Deserialize, Clone, Debug, HasUnknown)]
pub struct HistoricalFigures {
pub historical_figure: Option<Vec<HistoricalFigure>>,
#[serde(flatten)]
pub unknown: HashMap<String, Value>,
}
impl Filler<df_st_core::HistoricalFigure, HistoricalFigure> for df_st_core::HistoricalFigure {
fn add_missing_data(&mut self, source: &HistoricalFigure) {
self.id.add_missing_data(&source.id);
if let Some(sex) = &source.sex {
let new_caste = Some(
match sex {
0 => "female",
1 => "male",
-1 => "default",
_ => {
warn!("HistoricalFigure: Gender could not match: {}", sex);
"default"
}
}
.to_owned(),
);
if self.caste == Some("default".to_owned()) {
self.caste.replace_data(&new_caste);
} else {
self.caste.never_replace_data(&new_caste);
}
}
self.race.replace_data(&source.race);
}
}
impl PartialEq<df_st_core::HistoricalFigure> for HistoricalFigure {
fn eq(&self, other: &df_st_core::HistoricalFigure) -> bool {
self.id == other.id
}
}
impl Filler<Vec<df_st_core::HistoricalFigure>, HistoricalFigures>
for Vec<df_st_core::HistoricalFigure>
{
fn add_missing_data(&mut self, source: &HistoricalFigures) {
self.add_missing_data(&source.historical_figure);
}
}
impl Filler<IndexMap<u64, df_st_core::HistoricalFigure>, HistoricalFigures>
for IndexMap<u64, df_st_core::HistoricalFigure>
{
fn add_missing_data(&mut self, source: &HistoricalFigures) {
self.add_missing_data(&source.historical_figure);
}
}