aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Andrew Dona-Couch -- GitHub drop ICE <hi@andrewcou.ch>2023-03-06 16:18:45 -0500
committerLibravatar GitHub <noreply@github.com>2023-03-06 22:18:45 +0100
commitdc864486ec8c258388b4e006d9517e6e30c34a4d (patch)
tree4419a02845917440f2846880ddf872a649b50373
parent417cb924ae1f94d54e2eb13ebc7e9fab91b84588 (diff)
downloadaskama-dc864486ec8c258388b4e006d9517e6e30c34a4d.tar.gz
askama-dc864486ec8c258388b4e006d9517e6e30c34a4d.tar.bz2
askama-dc864486ec8c258388b4e006d9517e6e30c34a4d.zip
Propogate size_hint from sub-blocks (#788)
Closes #786
-rw-r--r--askama_derive/src/generator.rs8
-rw-r--r--testing/templates/size-child-super.txt2
-rw-r--r--testing/templates/size-child.txt2
-rw-r--r--testing/templates/size-parent.txt1
-rw-r--r--testing/tests/size_hint.rs47
5 files changed, 56 insertions, 4 deletions
diff --git a/askama_derive/src/generator.rs b/askama_derive/src/generator.rs
index fc74f34..d8093c3 100644
--- a/askama_derive/src/generator.rs
+++ b/askama_derive/src/generator.rs
@@ -630,16 +630,16 @@ impl<'a> Generator<'a> {
self.write_let(buf, ws, var, val)?;
}
Node::Cond(ref conds, ws) => {
- self.write_cond(ctx, buf, conds, ws)?;
+ size_hint += self.write_cond(ctx, buf, conds, ws)?;
}
Node::Match(ws1, ref expr, ref arms, ws2) => {
- self.write_match(ctx, buf, ws1, expr, arms, ws2)?;
+ size_hint += self.write_match(ctx, buf, ws1, expr, arms, ws2)?;
}
Node::Loop(ref loop_block) => {
- self.write_loop(ctx, buf, loop_block)?;
+ size_hint += self.write_loop(ctx, buf, loop_block)?;
}
Node::BlockDef(ws1, name, _, ws2) => {
- self.write_block(buf, Some(name), Ws(ws1.0, ws2.1))?;
+ size_hint += self.write_block(buf, Some(name), Ws(ws1.0, ws2.1))?;
}
Node::Include(ws, path) => {
size_hint += self.handle_include(ctx, buf, ws, path)?;
diff --git a/testing/templates/size-child-super.txt b/testing/templates/size-child-super.txt
new file mode 100644
index 0000000..77c2916
--- /dev/null
+++ b/testing/templates/size-child-super.txt
@@ -0,0 +1,2 @@
+{% extends "size-parent.txt" %}
+{% block main %}{% call super() %}{% endblock %}
diff --git a/testing/templates/size-child.txt b/testing/templates/size-child.txt
new file mode 100644
index 0000000..86adbf8
--- /dev/null
+++ b/testing/templates/size-child.txt
@@ -0,0 +1,2 @@
+{% extends "size-parent.txt" %}
+{% block main %}{% if true %}123{% endif %}{% endblock %}
diff --git a/testing/templates/size-parent.txt b/testing/templates/size-parent.txt
new file mode 100644
index 0000000..e277a24
--- /dev/null
+++ b/testing/templates/size-parent.txt
@@ -0,0 +1 @@
+{% block main %}{% if true %}12345{% endif %}{% endblock %}
diff --git a/testing/tests/size_hint.rs b/testing/tests/size_hint.rs
new file mode 100644
index 0000000..a9f8428
--- /dev/null
+++ b/testing/tests/size_hint.rs
@@ -0,0 +1,47 @@
+use askama::Template;
+
+macro_rules! test_size {
+ ($source:literal, $expected:expr) => {{
+ #[derive(Template)]
+ #[template(source = $source, ext = "txt")]
+ struct T(bool);
+
+ assert_eq!(T::SIZE_HINT, $expected);
+ }};
+}
+
+#[test]
+fn test_cond_size_hint() {
+ test_size!("{% if self.0 %}12345{% else %}12345{% endif %}", 10);
+}
+
+#[test]
+fn test_match_size_hint() {
+ test_size!(
+ "{% match self.0 %}{% when true %}12345{% else %}12345{% endmatch %}",
+ 5
+ );
+}
+
+#[test]
+fn test_loop_size_hint() {
+ test_size!("{% for i in 0..1 %}12345{% endfor %}", 7);
+}
+
+#[test]
+fn test_block_size_hint() {
+ #[derive(Template)]
+ #[template(path = "size-child.txt")]
+ struct T;
+
+ assert_eq!(T::SIZE_HINT, 3);
+}
+
+#[test]
+fn test_super_size_hint() {
+ #[derive(Template)]
+ #[template(path = "size-child-super.txt")]
+ struct T;
+
+ assert_eq!(T::SIZE_HINT, 5);
+}