From ec865cfb3702e9671607fd9e7bcd90ec90234921 Mon Sep 17 00:00:00 2001 From: yuyi Date: Fri, 29 Apr 2022 20:48:03 +0800 Subject: [PATCH] parser: check interface methods name (fix #14217) (#14218) --- vlib/v/checker/tests/interface_method_name_err.out | 6 ++++++ vlib/v/checker/tests/interface_method_name_err.vv | 6 ++++++ vlib/v/parser/struct.v | 7 ++----- 3 files changed, 14 insertions(+), 5 deletions(-) create mode 100644 vlib/v/checker/tests/interface_method_name_err.out create mode 100644 vlib/v/checker/tests/interface_method_name_err.vv diff --git a/vlib/v/checker/tests/interface_method_name_err.out b/vlib/v/checker/tests/interface_method_name_err.out new file mode 100644 index 0000000000..71cdc0dca7 --- /dev/null +++ b/vlib/v/checker/tests/interface_method_name_err.out @@ -0,0 +1,6 @@ +vlib/v/checker/tests/interface_method_name_err.vv:2:2: error: method name `Fizz` cannot contain uppercase letters, use snake_case instead + 1 | interface Foo { + 2 | Fizz() + | ~~~~~~ + 3 | } + 4 | diff --git a/vlib/v/checker/tests/interface_method_name_err.vv b/vlib/v/checker/tests/interface_method_name_err.vv new file mode 100644 index 0000000000..b7bcdc1a3f --- /dev/null +++ b/vlib/v/checker/tests/interface_method_name_err.vv @@ -0,0 +1,6 @@ +interface Foo { + Fizz() +} + +fn main() { +} diff --git a/vlib/v/parser/struct.v b/vlib/v/parser/struct.v index e6b81cebe0..016afd3f2f 100644 --- a/vlib/v/parser/struct.v +++ b/vlib/v/parser/struct.v @@ -516,7 +516,8 @@ fn (mut p Parser) interface_decl() ast.InterfaceDecl { mut mut_pos := -1 mut ifaces := []ast.InterfaceEmbedding{} for p.tok.kind != .rcbr && p.tok.kind != .eof { - if p.tok.kind == .name && p.tok.lit.len > 0 && p.tok.lit[0].is_capital() { + if p.tok.kind == .name && p.tok.lit.len > 0 && p.tok.lit[0].is_capital() + && p.peek_tok.kind != .lpar { iface_pos := p.tok.pos() mut iface_name := p.tok.lit iface_type := p.parse_type() @@ -584,10 +585,6 @@ fn (mut p Parser) interface_decl() ast.InterfaceDecl { p.error_with_pos('duplicate method `$name`', method_start_pos) return ast.InterfaceDecl{} } - if language == .v && util.contains_capital(name) { - p.error('interface methods cannot contain uppercase letters, use snake_case instead') - return ast.InterfaceDecl{} - } // field_names << name args2, _, is_variadic := p.fn_args() // TODO merge ast.Param and ast.Arg to avoid this mut args := [