aboutsummaryrefslogtreecommitdiff
path: root/src/convert
diff options
context:
space:
mode:
authorFuwn <[email protected]>2022-05-18 02:11:39 +0000
committerFuwn <[email protected]>2022-05-18 02:11:39 +0000
commit11cabcc6ea048c665e41db5fb210ee9515b0cf29 (patch)
treefa63b8678bac6d66ed1e195bd3af7f8795284b21 /src/convert
parentci(tests): add ast tests (diff)
downloadgerm-11cabcc6ea048c665e41db5fb210ee9515b0cf29.tar.xz
germ-11cabcc6ea048c665e41db5fb210ee9515b0cf29.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/convert')
-rw-r--r--src/convert/markdown.rs18
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
));