diff options
| author | Fuwn <[email protected]> | 2022-05-18 02:11:39 +0000 |
|---|---|---|
| committer | Fuwn <[email protected]> | 2022-05-18 02:11:39 +0000 |
| commit | 11cabcc6ea048c665e41db5fb210ee9515b0cf29 (patch) | |
| tree | fa63b8678bac6d66ed1e195bd3af7f8795284b21 /src | |
| parent | ci(tests): add ast tests (diff) | |
| download | germ-0.2.1.tar.xz germ-0.2.1.zip | |
ci(tests): add convert tests0.2.1
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).
Diffstat (limited to 'src')
| -rw-r--r-- | src/convert/markdown.rs | 18 |
1 files changed, 9 insertions, 9 deletions
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<Node>) -> 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<Node>) -> String { )); } Node::List(items) => - markdown.push_str( - &items + markdown.push_str(&format!("{}\n", + items .into_iter() .map(|i| format!("- {}", i)) .collect::<Vec<String>>() - .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 )); |