aboutsummaryrefslogtreecommitdiffstats
path: root/askama_parser/src/node.rs
diff options
context:
space:
mode:
Diffstat (limited to 'askama_parser/src/node.rs')
-rw-r--r--askama_parser/src/node.rs24
1 files changed, 20 insertions, 4 deletions
diff --git a/askama_parser/src/node.rs b/askama_parser/src/node.rs
index d11895b..27d4adc 100644
--- a/askama_parser/src/node.rs
+++ b/askama_parser/src/node.rs
@@ -224,7 +224,8 @@ impl<'a> Target<'a> {
}
// neither literal nor struct nor path
- map(identifier, Self::Name)(i)
+ let (new_i, name) = identifier(i)?;
+ Ok((new_i, Self::verify_name(i, name)?))
}
fn lit(i: &'a str) -> ParseResult<'a, Self> {
@@ -236,9 +237,24 @@ impl<'a> Target<'a> {
))(i)
}
- fn named(i: &'a str) -> ParseResult<'a, (&str, Self)> {
- let (i, (src, target)) = pair(identifier, opt(preceded(ws(char(':')), Self::parse)))(i)?;
- Ok((i, (src, target.unwrap_or(Self::Name(src)))))
+ fn named(init_i: &'a str) -> ParseResult<'a, (&str, Self)> {
+ let (i, (src, target)) =
+ pair(identifier, opt(preceded(ws(char(':')), Self::parse)))(init_i)?;
+ let target = match target {
+ Some(target) => target,
+ None => Self::verify_name(init_i, src)?,
+ };
+ Ok((i, (src, target)))
+ }
+
+ fn verify_name(input: &'a str, name: &'a str) -> Result<Self, nom::Err<ErrorContext<'a>>> {
+ match name {
+ "self" | "writer" => Err(nom::Err::Failure(ErrorContext {
+ input,
+ message: Some(Cow::Owned(format!("Cannot use `{name}` as a name"))),
+ })),
+ _ => Ok(Self::Name(name)),
+ }
}
}