From 3507c5e7ff8eaf499ac8860948a48376a47e399b Mon Sep 17 00:00:00 2001 From: Tom French Date: Mon, 16 Oct 2023 16:12:59 +0100 Subject: [PATCH] fix: modify `assert(x)` span to covert entire statement --- compiler/noirc_frontend/src/parser/parser.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/compiler/noirc_frontend/src/parser/parser.rs b/compiler/noirc_frontend/src/parser/parser.rs index 6b43bd003f3..7c780a9819f 100644 --- a/compiler/noirc_frontend/src/parser/parser.rs +++ b/compiler/noirc_frontend/src/parser/parser.rs @@ -814,9 +814,13 @@ where ignore_then_commit(keyword(Keyword::Assert), parenthesized(argument_parser)) .labelled(ParsingRuleLabel::Statement) .validate(|expressions, span, emit| { - let condition = expressions.get(0).unwrap_or(&Expression::error(span)).clone(); - let mut message_str = None; + let mut condition = + expressions.get(0).cloned().unwrap_or_else(|| Expression::error(span)); + // This is a bit of a hack but we want the span to cover the `assert` keyword as well. + // Perhaps `ConstrainStatement` should have it's own span rather than overloading the condition? + condition.span = span; + let mut message_str = None; if let Some(message) = expressions.get(1) { if let ExpressionKind::Literal(Literal::Str(message)) = &message.kind { message_str = Some(message.clone());