tiger_lib/data/
fonts.rs

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
use crate::block::Block;
use crate::db::{Db, DbKind};
use crate::everything::Everything;
use crate::game::GameFlags;
use crate::item::{Item, ItemLoader};
use crate::pdxfile::PdxEncoding;
use crate::report::{untidy, warn, ErrorKey, Severity};
use crate::token::Token;
use crate::validator::Validator;

#[derive(Clone, Debug)]
pub struct Font {}

inventory::submit! {
    ItemLoader::Full(GameFlags::all(), Item::Font, PdxEncoding::Utf8OptionalBom, ".font", false, Font::add)
}

impl Font {
    pub fn add(db: &mut Db, key: Token, block: Block) {
        if key.is("fontfiles") {
            if let Some(name) = block.get_field_value("name") {
                db.add(Item::Fontfiles, name.clone(), block, Box::new(Fontfiles {}));
            } else {
                let msg = "fontfiles entry without name";
                warn(ErrorKey::FieldMissing).msg(msg).loc(key).push();
            }
        } else if key.is("font") {
            if let Some(name) = block.get_field_value("name") {
                db.add(Item::Font, name.clone(), block, Box::new(Self {}));
            } else {
                let msg = "font entry without name";
                warn(ErrorKey::FieldMissing).msg(msg).loc(key).push();
            }
        } else {
            let msg = format!("unknown entry type {key}");
            untidy(ErrorKey::UnknownField).msg(msg).loc(key).push();
        }
    }
}

impl DbKind for Font {
    fn validate(&self, _key: &Token, block: &Block, data: &Everything) {
        let mut vd = Validator::new(block, data);
        vd.set_max_severity(Severity::Warning);
        vd.field_value("name");
        vd.multi_field_validated_block("fontstyle", |block, data| {
            let mut vd = Validator::new(block, data);
            vd.field_validated_value("style", |_, mut vd| {
                for mut vd in vd.split('|') {
                    vd.choice(&["regular", "bold", "extrabold", "italic"]);
                }
            });
            vd.field_item("fontfiles", Item::Fontfiles);
        });
        vd.multi_field_validated_block("underlineformats", |block, data| {
            let mut vd = Validator::new(block, data);
            vd.unknown_block_fields(|_key, block| {
                // only known key is "default" but there may be others
                let mut vd = Validator::new(block, data);
                vd.field_numeric("thickness");
                vd.field_numeric("offset");
            });
        });
    }
}

#[derive(Clone, Debug)]
pub struct Fontfiles {}

impl DbKind for Fontfiles {
    fn validate(&self, _key: &Token, block: &Block, data: &Everything) {
        let mut vd = Validator::new(block, data);
        vd.set_max_severity(Severity::Warning);
        vd.field_value("name");
        vd.field_bool("always_load");

        vd.multi_field_validated_block("group", |block, data| {
            let mut vd = Validator::new(block, data);
            vd.field_list("languages"); // TODO
            vd.field_list_items("files", Item::File);
        });
    }
}