diff options
| author | Laurenz <laurmaedje@gmail.com> | 2023-04-11 16:50:26 +0200 |
|---|---|---|
| committer | Laurenz <laurmaedje@gmail.com> | 2023-04-11 16:50:26 +0200 |
| commit | 9720424884d67d61fd4ab7cbcefa2bfcc21d03e1 (patch) | |
| tree | 0dab729b193a071aaec9c6e0dc2e49547b2f57ec /src | |
| parent | 58e4bdb1b95a7c7f048f38e231328054e753b898 (diff) | |
Fix duplicate error message for destructuring
Diffstat (limited to 'src')
| -rw-r--r-- | src/eval/mod.rs | 8 | ||||
| -rw-r--r-- | src/syntax/parser.rs | 17 |
2 files changed, 12 insertions, 13 deletions
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); |
