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
use super::prelude::*;
use crate::data::PageInfo;
use crate::parsing::ElementCondition;
pub const BLOCK_IFTAGS: BlockRule = BlockRule {
name: "block-iftags",
accepts_names: &["iftags"],
accepts_star: false,
accepts_score: false,
accepts_newlines: true,
parse_fn,
};
fn parse_fn<'r, 't>(
parser: &mut Parser<'r, 't>,
name: &'t str,
flag_star: bool,
flag_score: bool,
in_head: bool,
) -> ParseResult<'r, 't, Elements<'t>> {
info!("Parsing iftags block (name '{name}', in-head {in_head})");
assert!(!flag_star, "IfTags doesn't allow star flag");
assert!(!flag_score, "IfTags doesn't allow score flag");
assert_block_name(&BLOCK_IFTAGS, name);
let conditions =
parser.get_head_value(&BLOCK_IFTAGS, in_head, |parser, spec| match spec {
Some(spec) => Ok(ElementCondition::parse(spec)),
None => Err(parser.make_err(ParseErrorKind::BlockMissingArguments)),
})?;
let (elements, errors, paragraph_safe) =
parser.get_body_elements(&BLOCK_IFTAGS, false)?.into();
debug!(
"IfTags conditions parsed (conditions length {}, elements length {})",
conditions.len(),
elements.len(),
);
let elements = if check_iftags(parser.page_info(), &conditions) {
debug!("Conditions passed, including elements");
Elements::Multiple(elements)
} else {
debug!("Conditions failed, excluding elements");
Elements::None
};
ok!(paragraph_safe; elements, errors)
}
pub fn check_iftags(info: &PageInfo, conditions: &[ElementCondition]) -> bool {
debug!("Checking iftags");
ElementCondition::check(conditions, &info.tags)
}