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 crate::*;
#[derive(Clone, Default, Debug)]
pub struct Extra {
pub id: Option<String>,
pub name: Option<String>,
pub ty: Option<String>,
pub asset: Option<Box<Asset>>,
pub technique: Vec<Technique>,
}
impl HasId for Extra {
fn id(&self) -> Option<&str> {
self.id.as_deref()
}
}
impl XNode for Extra {
const NAME: &'static str = "extra";
fn parse(element: &Element) -> Result<Self> {
debug_assert_eq!(element.name(), Self::NAME);
let mut it = element.children().peekable();
let res = Extra {
id: element.attr("id").map(Into::into),
name: element.attr("name").map(Into::into),
ty: element.attr("type").map(Into::into),
asset: Asset::parse_opt_box(&mut it)?,
technique: Technique::parse_list_n::<1>(&mut it)?,
};
finish(res, it)
}
}
impl Extra {
pub(crate) fn parse_many<'a>(it: impl Iterator<Item = &'a Element>) -> Result<Vec<Extra>> {
let mut extras = vec![];
for e in it {
match e.name() {
"extra" => extras.push(Extra::parse(e)?),
k => return Err(format!("unexpected element {}", k).into()),
}
}
Ok(extras)
}
}
#[derive(Clone, Debug)]
pub struct Technique {
pub element: Element,
}
impl XNode for Technique {
const NAME: &'static str = "technique";
fn parse(element: &Element) -> Result<Self> {
debug_assert_eq!(element.name(), Self::NAME);
element.attr("profile").ok_or("expected 'profile' attr")?;
Ok(Technique {
element: element.clone(),
})
}
}
impl Technique {
pub const COMMON: &'static str = "technique_common";
}