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
|
use failure::Error;
use pest::iterators::Pair;
use crate::document_tree::{
ExtraAttributes,
elements as e,
element_categories as c,
attribute_types::{ID,NameToken},
extra_attributes as a,
};
use crate::parser::{
pest_rst::Rule,
// pair_ext_parse::PairExt,
};
pub fn convert_inline(pair: Pair<Rule>) -> Result<c::TextOrInlineElement, Error> {
Ok(match pair.as_rule() {
Rule::str => pair.as_str().into(),
Rule::reference => convert_reference(pair)?.into(),
rule => unimplemented!("unknown rule {:?}", rule),
})
}
fn convert_reference(pair: Pair<Rule>) -> Result<e::Reference, Error> {
let mut name = None;
let mut uri = None;
let mut id = None;
let mut name_tokens = vec![];
let concrete = pair.into_inner().next().unwrap();
match concrete.as_rule() {
Rule::reference_target => {
let rt_inner = concrete.into_inner().next().unwrap(); // reference_target_uq or target_name_qu
//TODO: abstract away
id = Some( ID(rt_inner.as_str().to_owned().replace(' ', "-")));
name = Some(NameToken(rt_inner.as_str().to_owned()));
},
Rule::reference_explicit => unimplemented!("explicit reference"),
Rule::reference_auto => unimplemented!("auto reference"),
_ => unreachable!(),
};
let extra = a::Reference {
name: name,
refuri: uri,
refid: id,
refname: name_tokens,
};
Ok(e::Reference::with_extra(extra))
}
|