From 7ecdc47b9173c24a5787c8554649a25f863bfe04 Mon Sep 17 00:00:00 2001 From: Vincent Prouillet Date: Wed, 10 Oct 2018 15:26:31 +0200 Subject: [PATCH] Remove line trimming for shortcode bodies Can't remember why it was doing that even with the comment and the test added in the commit still pass so... Fix #462 --- components/rendering/src/shortcode.rs | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/components/rendering/src/shortcode.rs b/components/rendering/src/shortcode.rs index e1d6476e..45cd6b89 100644 --- a/components/rendering/src/shortcode.rs +++ b/components/rendering/src/shortcode.rs @@ -100,9 +100,7 @@ fn render_shortcode(name: &str, args: &Map, context: &RenderConte .render(&tpl_name, &tera_context) .chain_err(|| format!("Failed to render {} shortcode", name))?; - // We trim left every single line of a shortcode to avoid the accidental - // shortcode counted as code block because of 4 spaces left padding - Ok(res.lines().map(|s| s.trim_left()).collect()) + Ok(res) } pub fn render_shortcodes(content: &str, context: &RenderContext) -> Result { @@ -387,4 +385,13 @@ Some body {{ hello() }}{%/* end */%}"#, &Tera::default()); let res = render_shortcodes("Body\n {% youtube() %}Hey!{% end %}", &tera); assert_eq!(res, "Body\n Hey!"); } + + // https://github.com/Keats/gutenberg/issues/462 + #[test] + fn shortcodes_with_body_do_not_eat_newlines() { + let mut tera = Tera::default(); + tera.add_raw_template("shortcodes/youtube.html", "{{body | safe}}").unwrap(); + let res = render_shortcodes("Body\n {% youtube() %}\nHello \n World{% end %}", &tera); + assert_eq!(res, "Body\n Hello \n World"); + } }