parser: fix panic when single letter receiver parsed (#8381)
parent
5fc7eadd8b
commit
93b0d8ca64
|
@ -5296,7 +5296,7 @@ fn (mut c Checker) fn_decl(mut node ast.FnDecl) {
|
|||
sym := c.table.get_type_symbol(arg.typ)
|
||||
if sym.kind == .placeholder
|
||||
|| (sym.kind in [table.Kind.int_literal, .float_literal] && !c.is_builtin_mod) {
|
||||
c.error('unknown type `$sym.name`', node.pos)
|
||||
c.error('unknown type `$sym.name`', node.receiver_pos)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
vlib/v/checker/tests/receiver_unknown_type_single_letter.vv:1:5: error: unknown type `A`
|
||||
1 | fn (p A) foo() {}
|
||||
| ~~~
|
|
@ -0,0 +1 @@
|
|||
fn (p A) foo() {}
|
|
@ -190,6 +190,7 @@ fn (mut p Parser) fn_decl() ast.FnDecl {
|
|||
mut rec_mut := false
|
||||
mut params := []table.Param{}
|
||||
if p.tok.kind == .lpar {
|
||||
p.is_parsing_receiver = true
|
||||
lpar_pos := p.tok.position()
|
||||
p.next() // (
|
||||
is_method = true
|
||||
|
@ -246,6 +247,7 @@ fn (mut p Parser) fn_decl() ast.FnDecl {
|
|||
typ: rec_type
|
||||
}
|
||||
p.check(.rpar)
|
||||
p.is_parsing_receiver = false
|
||||
}
|
||||
mut name := ''
|
||||
if p.tok.kind == .name {
|
||||
|
|
|
@ -373,7 +373,7 @@ pub fn (mut p Parser) parse_any_type(language table.Language, is_ptr bool, check
|
|||
return table.int_literal_type
|
||||
}
|
||||
else {
|
||||
if name.len == 1 && name[0].is_capital() {
|
||||
if name.len == 1 && name[0].is_capital() && !p.is_parsing_receiver {
|
||||
return p.parse_generic_template_type(name)
|
||||
}
|
||||
if p.peek_tok.kind == .lt {
|
||||
|
|
|
@ -71,6 +71,7 @@ mut:
|
|||
cur_fn_name string
|
||||
in_generic_params bool // indicates if parsing between `<` and `>` of a method/function
|
||||
name_error bool // indicates if the token is not a name or the name is on another line
|
||||
is_parsing_receiver bool // indicates if parser is parsing receiver fn (x Xxx)
|
||||
}
|
||||
|
||||
// for tests
|
||||
|
|
Loading…
Reference in New Issue