use markdown_it::{generics::inline::emph_pair, MarkdownIt, Node, NodeValue, Renderer};
#[derive(Debug)]
pub struct Sup;
impl NodeValue for Sup {
fn render(&self, node: &Node, fmt: &mut dyn Renderer) {
fmt.open("sup", &node.attrs);
fmt.contents(&node.children);
fmt.close("sup");
}
}
pub fn add(md: &mut MarkdownIt) {
emph_pair::add_with::<'^', 1, true>(md, || Node::new(Sup));
}
#[cfg(test)]
mod test {
use super::add;
use markdown_it::{
plugins::{cmark, extra},
MarkdownIt,
};
use rstest::rstest;
use std::sync::LazyLock;
static MARKDOWN_PARSER: LazyLock<MarkdownIt> = LazyLock::new(|| {
let mut parser = MarkdownIt::new();
cmark::add(&mut parser);
extra::add(&mut parser);
add(&mut parser);
parser
});
#[rstest]
#[case("^foo^", "<p><sup>foo</sup></p>\n")]
#[case("foo^", "<p>foo^</p>\n")]
#[case("^foo", "<p>^foo</p>\n")]
#[case("foo^bar^", "<p>foo<sup>bar</sup></p>\n")]
#[case("\\^foo^", "<p>^foo^</p>\n")]
#[case("^foo\\^", "<p>^foo^</p>\n")]
fn test(#[case] md_str: &str, #[case] expected: &str) {
let result = MARKDOWN_PARSER.parse(md_str).xrender();
assert_eq!(result, String::from(expected));
}
}