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
use df_st_core::{ConvertingUtils, 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 EntityPopulation {
    pub id: i32,
    pub civ_id: Option<i32>,
    pub race: Option<Vec<String>>, // TODO parse further

    #[serde(flatten)]
    pub unknown: HashMap<String, Value>,
}

#[derive(Serialize, Deserialize, Clone, Debug, HasUnknown)]
pub struct EntityPopulations {
    pub entity_population: Option<Vec<EntityPopulation>>,

    #[serde(flatten)]
    pub unknown: HashMap<String, Value>,
}

impl Filler<df_st_core::EntityPopulation, EntityPopulation> for df_st_core::EntityPopulation {
    #[rustfmt::skip]
    fn add_missing_data(&mut self, source: &EntityPopulation) {
        self.id.add_missing_data(&source.id);
        self.civ_id.add_missing_data(&source.civ_id.negative_to_none());
        self.races.add_missing_data(&source.race);
    }
}

impl PartialEq<df_st_core::EntityPopulation> for EntityPopulation {
    fn eq(&self, other: &df_st_core::EntityPopulation) -> bool {
        self.id == other.id
    }
}

impl Filler<Vec<df_st_core::EntityPopulation>, EntityPopulations>
    for Vec<df_st_core::EntityPopulation>
{
    fn add_missing_data(&mut self, source: &EntityPopulations) {
        self.add_missing_data(&source.entity_population);
    }
}

impl Filler<IndexMap<u64, df_st_core::EntityPopulation>, EntityPopulations>
    for IndexMap<u64, df_st_core::EntityPopulation>
{
    fn add_missing_data(&mut self, source: &EntityPopulations) {
        self.add_missing_data(&source.entity_population);
    }
}