From 6aca36050727e0ffe5d548d046421db3b9fe62cc Mon Sep 17 00:00:00 2001 From: yuyi Date: Tue, 19 Oct 2021 17:27:59 +0800 Subject: [PATCH] parser: fix checking unexpected name (#12233) --- .../v/checker/tests/error_with_comment_with_crlf_ending.out | 4 ++-- vlib/v/checker/tests/error_with_comment_with_lf_ending.out | 4 ++-- vlib/v/checker/tests/multi_names_err.out | 4 ++-- vlib/v/parser/parser.v | 2 +- vlib/v/parser/tests/unexpected_name_err.out | 6 ++++++ vlib/v/parser/tests/unexpected_name_err.vv | 4 ++++ 6 files changed, 17 insertions(+), 7 deletions(-) create mode 100644 vlib/v/parser/tests/unexpected_name_err.out create mode 100644 vlib/v/parser/tests/unexpected_name_err.vv diff --git a/vlib/v/checker/tests/error_with_comment_with_crlf_ending.out b/vlib/v/checker/tests/error_with_comment_with_crlf_ending.out index 5e4630e384..11317c80f4 100644 --- a/vlib/v/checker/tests/error_with_comment_with_crlf_ending.out +++ b/vlib/v/checker/tests/error_with_comment_with_crlf_ending.out @@ -1,4 +1,4 @@ -vlib/v/checker/tests/error_with_comment_with_crlf_ending.vv:2:6: error: unexpected name `should` +vlib/v/checker/tests/error_with_comment_with_crlf_ending.vv:2:1: error: unexpected name `This` 1 | // Empty lines don't cause an issue but as soon as there's a comment with a CRLF ending, it fails 2 | This should cause an error! - | ~~~~~~ + | ~~~~ diff --git a/vlib/v/checker/tests/error_with_comment_with_lf_ending.out b/vlib/v/checker/tests/error_with_comment_with_lf_ending.out index fcf35240d1..2d94b5eafd 100644 --- a/vlib/v/checker/tests/error_with_comment_with_lf_ending.out +++ b/vlib/v/checker/tests/error_with_comment_with_lf_ending.out @@ -1,4 +1,4 @@ -vlib/v/checker/tests/error_with_comment_with_lf_ending.vv:2:6: error: unexpected name `should` +vlib/v/checker/tests/error_with_comment_with_lf_ending.vv:2:1: error: unexpected name `This` 1 | // Empty lines don't cause an issue but as soon as there's a comment with a CRLF ending, it fails 2 | This should cause an error! - | ~~~~~~ + | ~~~~ diff --git a/vlib/v/checker/tests/multi_names_err.out b/vlib/v/checker/tests/multi_names_err.out index a022208f11..d7c30ad9d1 100644 --- a/vlib/v/checker/tests/multi_names_err.out +++ b/vlib/v/checker/tests/multi_names_err.out @@ -1,5 +1,5 @@ -vlib/v/checker/tests/multi_names_err.vv:2:4: error: unexpected name `a` +vlib/v/checker/tests/multi_names_err.vv:2:2: error: unexpected name `a` 1 | fn main() { 2 | a a a a := 1 - | ^ + | ^ 3 | } diff --git a/vlib/v/parser/parser.v b/vlib/v/parser/parser.v index 1552c66d6a..6d4ef106a1 100644 --- a/vlib/v/parser/parser.v +++ b/vlib/v/parser/parser.v @@ -734,7 +734,7 @@ pub fn (mut p Parser) stmt(is_top_level bool) ast.Stmt { pos: spos.extend(p.tok.position()) } } else if p.peek_tok.kind == .name { - return p.error_with_pos('unexpected name `$p.peek_tok.lit`', p.peek_tok.position()) + return p.error_with_pos('unexpected name `$p.tok.lit`', p.tok.position()) } else if !p.inside_if_expr && !p.inside_match_body && !p.inside_or_expr && p.peek_tok.kind in [.rcbr, .eof] && !p.mark_var_as_used(p.tok.lit) { return p.error_with_pos('`$p.tok.lit` evaluated but not used', p.tok.position()) diff --git a/vlib/v/parser/tests/unexpected_name_err.out b/vlib/v/parser/tests/unexpected_name_err.out new file mode 100644 index 0000000000..634e8927c3 --- /dev/null +++ b/vlib/v/parser/tests/unexpected_name_err.out @@ -0,0 +1,6 @@ +vlib/v/parser/tests/unexpected_name_err.vv:2:2: error: unexpected name `asfasfasfsfa` + 1 | fn main() { + 2 | asfasfasfsfa + | ~~~~~~~~~~~~ + 3 | println('text') + 4 | } diff --git a/vlib/v/parser/tests/unexpected_name_err.vv b/vlib/v/parser/tests/unexpected_name_err.vv new file mode 100644 index 0000000000..e67d2d10e5 --- /dev/null +++ b/vlib/v/parser/tests/unexpected_name_err.vv @@ -0,0 +1,4 @@ +fn main() { + asfasfasfsfa + println('text') +}