diff --git a/src/renderer/html_handlebars/hbs_renderer.rs b/src/renderer/html_handlebars/hbs_renderer.rs
index e8173770dd..0be925622a 100644
--- a/src/renderer/html_handlebars/hbs_renderer.rs
+++ b/src/renderer/html_handlebars/hbs_renderer.rs
@@ -601,7 +601,6 @@ fn fix_code_blocks(html: &str) -> String {
}
fn add_playpen_pre(html: &str, playpen_config: &Playpen) -> String {
- let boring_line_regex = Regex::new(r"^(\s*)#(#|.)(.*)$").unwrap();
let regex = Regex::new(r##"((?s)]?class="([^"]+)".*?>(.*?)
)"##).unwrap();
regex
.replace_all(html, |caps: &Captures<'_>| {
@@ -609,57 +608,37 @@ fn add_playpen_pre(html: &str, playpen_config: &Playpen) -> String {
let classes = &caps[2];
let code = &caps[3];
- if (classes.contains("language-rust")
- && !classes.contains("ignore")
- && !classes.contains("noplaypen"))
- || classes.contains("mdbook-runnable")
- {
- // wrap the contents in an external pre block
- format!(
- "
{}
",
- classes,
- {
- let content: Cow<'_, str> = if playpen_config.editable
- && classes.contains("editable")
- || text.contains("fn main")
- || text.contains("quick_main!")
+ if classes.contains("language-rust") {
+ if (!classes.contains("ignore") && !classes.contains("noplaypen"))
+ || classes.contains("mdbook-runnable")
+ {
+ // wrap the contents in an external pre block
+ format!(
+ "{}
",
+ classes,
{
- code.into()
- } else {
- // we need to inject our own main
- let (attrs, code) = partition_source(code);
-
- format!(
- "\n# #![allow(unused_variables)]\n{}#fn main() {{\n{}#}}",
- attrs, code
- )
- .into()
- };
- let mut prev_line_hidden = false;
- let mut result = String::with_capacity(content.len());
- for line in content.lines() {
- if let Some(caps) = boring_line_regex.captures(line) {
- if !prev_line_hidden && &caps[2] != "#" {
- result += "";
- prev_line_hidden = true;
- }
- result += &caps[1];
- if &caps[2] != " " {
- result += &caps[2];
- }
- result += &caps[3];
+ let content: Cow<'_, str> = if playpen_config.editable
+ && classes.contains("editable")
+ || text.contains("fn main")
+ || text.contains("quick_main!")
+ {
+ code.into()
} else {
- if prev_line_hidden {
- result += "";
- prev_line_hidden = false;
- }
- result += line;
- }
- result += "\n";
+ // we need to inject our own main
+ let (attrs, code) = partition_source(code);
+
+ format!(
+ "\n# #![allow(unused_variables)]\n{}#fn main() {{\n{}#}}",
+ attrs, code
+ )
+ .into()
+ };
+ hide_lines(&content)
}
- result
- }
- )
+ )
+ } else {
+ format!("{}
", classes, hide_lines(code))
+ }
} else {
// not language-rust, so no-op
text.to_owned()
@@ -668,6 +647,38 @@ fn add_playpen_pre(html: &str, playpen_config: &Playpen) -> String {
.into_owned()
}
+lazy_static! {
+ static ref BORING_LINES_REGEX: Regex = Regex::new(r"^(\s*)#(.?)(.*)$").unwrap();
+}
+
+fn hide_lines(content: &str) -> String {
+ let mut result = String::with_capacity(content.len());
+ for line in content.lines() {
+ if let Some(caps) = BORING_LINES_REGEX.captures(line) {
+ if &caps[2] == "#" {
+ result += &caps[1];
+ result += &caps[2];
+ result += &caps[3];
+ result += "\n";
+ continue;
+ } else if &caps[2] != "!" && &caps[2] != "[" {
+ result += "";
+ result += &caps[1];
+ if &caps[2] != " " {
+ result += &caps[2];
+ }
+ result += &caps[3];
+ result += "\n";
+ result += "";
+ continue;
+ }
+ }
+ result += line;
+ result += "\n";
+ }
+ result
+}
+
fn partition_source(s: &str) -> (String, String) {
let mut after_header = false;
let mut before = String::new();
@@ -740,13 +751,19 @@ mod tests {
fn add_playpen() {
let inputs = [
("x()
",
- "\n#![allow(unused_variables)]\nfn main() {\nx()\n}\n
"),
+ "\n#![allow(unused_variables)]\nfn main() {\nx()\n}\n
"),
("fn main() {}
",
"fn main() {}\n
"),
("let s = \"foo\n # bar\n\";
",
"let s = \"foo\n bar\n\";\n
"),
("let s = \"foo\n ## bar\n\";
",
"let s = \"foo\n # bar\n\";\n
"),
+ ("let s = \"foo\n # bar\n#\n\";
",
+ "let s = \"foo\n bar\n\n\";\n
"),
+ ("let s = \"foo\n # bar\n\";
",
+ "let s = \"foo\n bar\n\";\n
"),
+ ("#![no_std]\nlet s = \"foo\";\n #[some_attr]
",
+ "#![no_std]\nlet s = \"foo\";\n #[some_attr]\n
"),
];
for (src, should_be) in &inputs {
let got = add_playpen_pre(
diff --git a/src/theme/book.js b/src/theme/book.js
index 328151ca87..186f9ae111 100644
--- a/src/theme/book.js
+++ b/src/theme/book.js
@@ -16,9 +16,6 @@ function playpen_text(playpen) {
}
(function codeSnippets() {
- // Hide Rust code lines prepended with a specific character
- var hiding_character = "#";
-
function fetch_with_timeout(url, options, timeout = 6000) {
return Promise.race([
fetch(url, options),