aboutsummaryrefslogtreecommitdiffstats
path: root/askama_parser
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 /askama_parser
parentc3281e353d8192e6425f903216eeb6ecf9dd39fc (diff)
downloadaskama-c056d6287b0616aea9bc9fab43bcca97d0e86d23.tar.gz
askama-c056d6287b0616aea9bc9fab43bcca97d0e86d23.tar.bz2
askama-c056d6287b0616aea9bc9fab43bcca97d0e86d23.zip
Improve error for invalid name used in `endmacro`
Diffstat (limited to 'askama_parser')
-rw-r--r--askama_parser/src/node.rs8
1 files changed, 7 insertions, 1 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)?;