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
#![allow(unused_must_use)]
mod charset;
mod family;
mod font;
mod pitch;
pub use self::{charset::*, family::*, font::*, pitch::*};
use std::io::Write;
use strong_xml::{XmlRead, XmlResult, XmlWrite, XmlWriter};
use crate::__xml_test_suites;
use crate::schema::{SCHEMA_MAIN, SCHEMA_RELATIONSHIPS_DOCUMENT, SCHEMA_XML};
#[derive(Debug, Default, XmlRead, Clone)]
#[cfg_attr(test, derive(PartialEq))]
#[xml(tag = "w:fonts")]
pub struct FontTable<'a> {
#[xml(child = "w:font")]
pub fonts: Vec<Font<'a>>,
}
impl<'a> XmlWrite for FontTable<'a> {
fn to_writer<W: Write>(&self, writer: &mut XmlWriter<W>) -> XmlResult<()> {
let FontTable { fonts } = self;
log::debug!("[FontTable] Started writing.");
let _ = write!(writer.inner, "{}", SCHEMA_XML);
writer.write_element_start("w:fonts")?;
writer.write_attribute("xmlns:w", SCHEMA_MAIN)?;
writer.write_attribute("xmlns:r", SCHEMA_RELATIONSHIPS_DOCUMENT)?;
if fonts.is_empty() {
writer.write_element_end_empty()?;
} else {
writer.write_element_end_open()?;
for ele in fonts {
ele.to_writer(writer)?;
}
writer.write_element_end_close("w:fonts")?;
}
log::debug!("[FontTable] Finished writing.");
Ok(())
}
}
impl<'a> FontTable<'a> {
pub fn push_font<T: Into<Font<'a>>>(&mut self, font: T) -> &mut Self {
self.fonts.push(font.into());
self
}
}
__xml_test_suites!(
FontTable,
FontTable::default(),
format!(
r#"{}<w:fonts xmlns:w="{}" xmlns:r="{}"/>"#,
SCHEMA_XML, SCHEMA_MAIN, SCHEMA_RELATIONSHIPS_DOCUMENT
)
.as_str(),
FontTable {
fonts: vec!["Arial".into()]
},
format!(
r#"{}<w:fonts xmlns:w="{}" xmlns:r="{}"><w:font w:name="Arial"/></w:fonts>"#,
SCHEMA_XML, SCHEMA_MAIN, SCHEMA_RELATIONSHIPS_DOCUMENT
)
.as_str(),
);