Skip to main content

ftml/parsing/rule/impls/block/blocks/
del.rs

1/*
2 * parsing/rule/impls/block/blocks/del.rs
3 *
4 * ftml - Library to parse Wikidot text
5 * Copyright (C) 2019-2026 Wikijump Team
6 *
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
16 *
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 */
20
21use super::prelude::*;
22
23pub const BLOCK_DEL: BlockRule = BlockRule {
24    name: "block-del",
25    accepts_names: &["del", "deletion"],
26    accepts_star: false,
27    accepts_score: false,
28    accepts_newlines: false,
29    parse_fn,
30};
31
32fn parse_fn<'r, 't>(
33    parser: &mut Parser<'r, 't>,
34    name: &'t str,
35    flag_star: bool,
36    flag_score: bool,
37    in_head: bool,
38) -> ParseResult<'r, 't, Elements<'t>> {
39    debug!("Parsing deletion block (name '{name}', in-head {in_head})");
40    assert!(!flag_star, "Deletion doesn't allow star flag");
41    assert!(!flag_score, "Deletion doesn't allow score flag");
42    assert_block_name(&BLOCK_DEL, name);
43
44    let arguments = parser.get_head_map(&BLOCK_DEL, in_head)?;
45
46    // Get body content, without paragraphs
47    let (elements, errors, paragraph_safe) =
48        parser.get_body_elements(&BLOCK_DEL, false)?.into();
49
50    // Build and return element
51    let element = Element::Container(Container::new(
52        ContainerType::Deletion,
53        elements,
54        arguments.to_attribute_map(parser.settings()),
55    ));
56
57    ok!(paragraph_safe; element, errors)
58}