aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Guillaume Gomez <guillaume1.gomez@gmail.com>2023-10-24 11:06:16 +0200
committerLibravatar Dirkjan Ochtman <dirkjan@ochtman.nl>2023-10-25 14:30:35 +0200
commitc056d6287b0616aea9bc9fab43bcca97d0e86d23 (patch)
treec2508394ec80082039e6d2fe1c7217f50c0c98af
parentc3281e353d8192e6425f903216eeb6ecf9dd39fc (diff)
downloadaskama-c056d6287b0616aea9bc9fab43bcca97d0e86d23.tar.gz
askama-c056d6287b0616aea9bc9fab43bcca97d0e86d23.tar.bz2
askama-c056d6287b0616aea9bc9fab43bcca97d0e86d23.zip
Improve error for invalid name used in `endmacro`
-rw-r--r--askama_parser/src/node.rs8
-rw-r--r--testing/tests/ui/name_mismatch_endmacro.stderr3
2 files changed, 9 insertions, 2 deletions
diff --git a/askama_parser/src/node.rs b/askama_parser/src/node.rs
index b321c80..93fca73 100644
--- a/askama_parser/src/node.rs
+++ b/askama_parser/src/node.rs
@@ -484,7 +484,13 @@ impl<'a> Macro<'a> {
|i| s.tag_block_start(i),
opt(Whitespace::parse),
ws(keyword("endmacro")),
- cut(preceded(ws(opt(keyword(name))), opt(Whitespace::parse))),
+ cut(preceded(
+ opt(|before| {
+ let (after, end_name) = ws(identifier)(before)?;
+ check_end_name(before, after, name, end_name, "macro")
+ }),
+ opt(Whitespace::parse),
+ )),
))),
)));
let (i, (contents, (_, pws2, _, nws2))) = end(i)?;
diff --git a/testing/tests/ui/name_mismatch_endmacro.stderr b/testing/tests/ui/name_mismatch_endmacro.stderr
index ef389a2..74101a4 100644
--- a/testing/tests/ui/name_mismatch_endmacro.stderr
+++ b/testing/tests/ui/name_mismatch_endmacro.stderr
@@ -1,4 +1,5 @@
-error: problems parsing template source at row 1, column 41 near:
+error: expected name `foo` in `endmacro` tag, found `not_foo`
+ problems parsing template source at row 1, column 41 near:
"not_foo %}"
--> tests/ui/name_mismatch_endmacro.rs:3:10
|