From 9720424884d67d61fd4ab7cbcefa2bfcc21d03e1 Mon Sep 17 00:00:00 2001 From: Laurenz Date: Tue, 11 Apr 2023 16:50:26 +0200 Subject: Fix duplicate error message for destructuring --- src/eval/mod.rs | 8 ++++---- src/syntax/parser.rs | 17 ++++++++--------- 2 files changed, 12 insertions(+), 13 deletions(-) (limited to 'src') diff --git a/src/eval/mod.rs b/src/eval/mod.rs index ca69b2d8..55d2a734 100644 --- a/src/eval/mod.rs +++ b/src/eval/mod.rs @@ -1461,16 +1461,16 @@ impl Eval for ast::ForLoop { match (pattern.kind(), iter.clone()) { (ast::PatternKind::Ident(_), Value::Str(string)) => { - // iterate over characters of string + // Iterate over graphemes of string. iter!(for pattern in string.as_str().graphemes(true)); } (_, Value::Dict(dict)) => { - // iterate over keys of dict + // Iterate over pairs of dict. iter!(for pattern in dict.pairs()); } (_, Value::Array(array)) => { - // iterate over values of array and allow destructuring - iter!(for pattern in array.into_iter()); + // Iterate over values of array. + iter!(for pattern in array); } (ast::PatternKind::Ident(_), _) => { bail!(self.iter().span(), "cannot loop over {}", iter.type_name()); diff --git a/src/syntax/parser.rs b/src/syntax/parser.rs index 83d9ae46..16d519fe 100644 --- a/src/syntax/parser.rs +++ b/src/syntax/parser.rs @@ -853,16 +853,9 @@ fn pattern(p: &mut Parser) -> PatternKind { PatternKind::Destructuring } else { - let success = p.expect(SyntaxKind::Ident); - if p.at(SyntaxKind::Comma) { - // TODO: this should only be a warning instead - p.expected("keyword `in`. did you mean to use a destructuring pattern?"); - } - - if success { + if p.expect(SyntaxKind::Ident) { p.wrap(m, SyntaxKind::Pattern); } - PatternKind::Normal } } @@ -964,7 +957,13 @@ fn for_loop(p: &mut Parser) { let m = p.marker(); p.assert(SyntaxKind::For); pattern(p); - p.expect(SyntaxKind::In); + if p.at(SyntaxKind::Comma) { + p.expected("keyword `in`. did you mean to use a destructuring pattern?"); + p.eat_if(SyntaxKind::Ident); + p.eat_if(SyntaxKind::In); + } else { + p.expect(SyntaxKind::In); + } code_expr(p); block(p); p.wrap(m, SyntaxKind::ForLoop); -- cgit v1.2.3