fix windows EOL in markdown files (#1911)
* add a test * CodeBlock text may be split on multiple parts The CodeBlock text events are now concatenated and processed in a single stream at the end. cf https://github.com/raphlinus/pulldown-cmark/issues/457
This commit is contained in:
parent
4f6a1c6bcc
commit
18e8246fbc
@ -317,13 +317,12 @@ pub fn markdown_to_html(
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let mut accumulated_block = String::new();
|
||||||
for (event, mut range) in Parser::new_ext(content, opts).into_offset_iter() {
|
for (event, mut range) in Parser::new_ext(content, opts).into_offset_iter() {
|
||||||
match event {
|
match event {
|
||||||
Event::Text(text) => {
|
Event::Text(text) => {
|
||||||
if let Some(ref mut code_block) = code_block {
|
if let Some(ref mut _code_block) = code_block {
|
||||||
let html;
|
|
||||||
if contains_shortcode(text.as_ref()) {
|
if contains_shortcode(text.as_ref()) {
|
||||||
let mut accumulated_block = String::new();
|
|
||||||
// mark the start of the code block events
|
// mark the start of the code block events
|
||||||
let stack_start = events.len();
|
let stack_start = events.len();
|
||||||
render_shortcodes!(true, text, range);
|
render_shortcodes!(true, text, range);
|
||||||
@ -341,13 +340,12 @@ pub fn markdown_to_html(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
html = code_block.highlight(&accumulated_block);
|
|
||||||
// remove all the original events from shortcode rendering
|
// remove all the original events from shortcode rendering
|
||||||
events.truncate(stack_start);
|
events.truncate(stack_start);
|
||||||
} else {
|
} else {
|
||||||
html = code_block.highlight(&text);
|
accumulated_block += &text;
|
||||||
}
|
}
|
||||||
events.push(Event::Html(html.into()));
|
|
||||||
} else {
|
} else {
|
||||||
let text = if context.config.markdown.render_emoji {
|
let text = if context.config.markdown.render_emoji {
|
||||||
EMOJI_REPLACER.replace_all(&text).to_string().into()
|
EMOJI_REPLACER.replace_all(&text).to_string().into()
|
||||||
@ -373,6 +371,12 @@ pub fn markdown_to_html(
|
|||||||
events.push(Event::Html(begin.into()));
|
events.push(Event::Html(begin.into()));
|
||||||
}
|
}
|
||||||
Event::End(Tag::CodeBlock(_)) => {
|
Event::End(Tag::CodeBlock(_)) => {
|
||||||
|
if let Some(ref mut code_block) = code_block {
|
||||||
|
let html = code_block.highlight(&accumulated_block);
|
||||||
|
events.push(Event::Html(html.into()));
|
||||||
|
accumulated_block.clear();
|
||||||
|
}
|
||||||
|
|
||||||
// reset highlight and close the code block
|
// reset highlight and close the code block
|
||||||
code_block = None;
|
code_block = None;
|
||||||
events.push(Event::Html("</code></pre>\n".into()));
|
events.push(Event::Html("</code></pre>\n".into()));
|
||||||
|
@ -239,6 +239,16 @@ bar
|
|||||||
insta::assert_snapshot!(body);
|
insta::assert_snapshot!(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn can_add_line_numbers_windows_eol() {
|
||||||
|
let body = render_codeblock(
|
||||||
|
"```linenos\r\nfoo\r\nbar\r\n```\r\n",
|
||||||
|
true,
|
||||||
|
);
|
||||||
|
insta::assert_snapshot!(body);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn can_add_line_numbers_with_lineno_start() {
|
fn can_add_line_numbers_with_lineno_start() {
|
||||||
let body = render_codeblock(
|
let body = render_codeblock(
|
||||||
|
@ -0,0 +1,9 @@
|
|||||||
|
---
|
||||||
|
source: components/markdown/tests/codeblocks.rs
|
||||||
|
assertion_line: 248
|
||||||
|
expression: body
|
||||||
|
---
|
||||||
|
<pre data-linenos style="background-color:#2b303b;color:#c0c5ce;"><code><table><tbody><tr><td>1</td><td><span>foo
|
||||||
|
</span></td></tr><tr><td>2</td><td><span>bar
|
||||||
|
</span></td></tr></tbody></table></code></pre>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user