aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Dirkjan Ochtman <dirkjan@ochtman.nl>2018-04-02 21:31:46 +0200
committerLibravatar Dirkjan Ochtman <dirkjan@ochtman.nl>2018-04-02 21:31:46 +0200
commitc023c35a1a4795ebe7e700823c880566007c4c76 (patch)
tree52180eec30930494422a606ffd455dc9556735e8
parent0bc388145046750760e6a722629cb78b1e656652 (diff)
downloadaskama-c023c35a1a4795ebe7e700823c880566007c4c76.tar.gz
askama-c023c35a1a4795ebe7e700823c880566007c4c76.tar.bz2
askama-c023c35a1a4795ebe7e700823c880566007c4c76.zip
Fix whitespace handling for include blocks (fixes #69)
Diffstat (limited to '')
-rw-r--r--askama_shared/src/generator.rs4
-rw-r--r--testing/templates/include.html2
-rw-r--r--testing/tests/include.rs2
3 files changed, 4 insertions, 4 deletions
diff --git a/askama_shared/src/generator.rs b/askama_shared/src/generator.rs
index 7462af9..bec3437 100644
--- a/askama_shared/src/generator.rs
+++ b/askama_shared/src/generator.rs
@@ -512,7 +512,7 @@ impl<'a> Generator<'a> {
}
fn handle_include(&mut self, state: &'a State, ws: &WS, path: &str) {
- self.prepare_ws(ws);
+ self.flush_ws(ws);
let path = path::find_template_from_path(path, Some(&state.input.path));
let src = path::get_template_source(&path);
let nodes = parser::parse(&src);
@@ -522,7 +522,7 @@ impl<'a> Generator<'a> {
gen.buf
};
self.buf.push_str(&nested);
- self.flush_ws(ws);
+ self.prepare_ws(ws);
}
fn write_let_decl(&mut self, ws: &WS, var: &'a Target) {
diff --git a/testing/templates/include.html b/testing/templates/include.html
index cdafbad..561bcac 100644
--- a/testing/templates/include.html
+++ b/testing/templates/include.html
@@ -1,3 +1,3 @@
-{% for s in strs -%}
+{% for s in strs %}
{% include "included.html" %}
{%- endfor %}
diff --git a/testing/tests/include.rs b/testing/tests/include.rs
index f474c55..f0158d7 100644
--- a/testing/tests/include.rs
+++ b/testing/tests/include.rs
@@ -13,5 +13,5 @@ struct IncludeTemplate<'a> {
fn test_include() {
let strs = vec!["foo", "bar"];
let s = IncludeTemplate { strs: &strs };
- assert_eq!(s.render().unwrap(), "INCLUDED: fooINCLUDED: bar")
+ assert_eq!(s.render().unwrap(), "\n INCLUDED: foo\n INCLUDED: bar")
}