From 11cabcc6ea048c665e41db5fb210ee9515b0cf29 Mon Sep 17 00:00:00 2001 From: Fuwn Date: Wed, 18 May 2022 02:11:39 +0000 Subject: ci(tests): add convert tests Adding these tests also exposed an issue within the Markdown converter! The issue was that if a Markdown file **did not** have whitespace lines between elements, no whitespace lines were inserted at all into the converted result, leaving everything on one massive line (except lists). --- src/convert/markdown.rs | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) (limited to 'src') diff --git a/src/convert/markdown.rs b/src/convert/markdown.rs index ccd2304..9bc0e6c 100644 --- a/src/convert/markdown.rs +++ b/src/convert/markdown.rs @@ -25,21 +25,21 @@ pub fn convert(source: Vec) -> String { // this AST tree to an alternative markup format. for node in source { match node { - Node::Text(text) => markdown.push_str(&text), + Node::Text(text) => markdown.push_str(&format!("{}\n", text)), Node::Link { to, text, } => markdown.push_str(&*text.map_or_else( - || format!("<{}>", to), - |text| format!("[{}]({})", text, to), + || format!("<{}>\n", to), + |text| format!("[{}]({})\n", text, to), )), Node::Heading { level, text, } => { markdown.push_str(&format!( - "{} {}", + "{} {}\n", match level { 1 => "#", 2 => "##", @@ -50,20 +50,20 @@ pub fn convert(source: Vec) -> String { )); } Node::List(items) => - markdown.push_str( - &items + markdown.push_str(&format!("{}\n", + items .into_iter() .map(|i| format!("- {}", i)) .collect::>() - .join("\n"), + .join("\n"),), ), - Node::Blockquote(text) => markdown.push_str(&format!("> {}", text)), + Node::Blockquote(text) => markdown.push_str(&format!("> {}\n", text)), Node::PreformattedText { alt_text, text, } => { markdown.push_str(&format!( - "```{}\n{}```", + "```{}\n{}```\n", alt_text.unwrap_or_else(|| "".to_string()), text )); -- cgit v1.2.3