mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
parser: fix parse error in the type of a ref array when the element type is a structure of another mod(fix #19033) (#19039)
This commit is contained in:
parent
fe9bdd4168
commit
b556f1302f
@ -182,7 +182,14 @@ fn (mut p Parser) check_expr(precedence int) !ast.Expr {
|
||||
if p.expecting_type {
|
||||
// parse json.decode type (`json.decode([]User, s)`)
|
||||
node = p.name_expr()
|
||||
} else if p.is_amp && p.peek_tok.kind == .rsbr && p.peek_token(3).kind != .lcbr {
|
||||
} else if p.is_amp && p.peek_tok.kind == .rsbr {
|
||||
mut n := 2
|
||||
mut peek_n_tok := p.peek_token(n)
|
||||
for peek_n_tok.kind in [.name, .dot] {
|
||||
n++
|
||||
peek_n_tok = p.peek_token(n)
|
||||
}
|
||||
if peek_n_tok.kind != .lcbr {
|
||||
pos := p.tok.pos()
|
||||
typ := p.parse_type()
|
||||
typname := p.table.sym(typ).name
|
||||
@ -198,6 +205,9 @@ fn (mut p Parser) check_expr(precedence int) !ast.Expr {
|
||||
} else {
|
||||
node = p.array_init(false)
|
||||
}
|
||||
} else {
|
||||
node = p.array_init(false)
|
||||
}
|
||||
}
|
||||
.key_none {
|
||||
pos := p.tok.pos()
|
||||
|
17
vlib/v/tests/parse_type_of_ref_array_from_another_mod_test.v
Normal file
17
vlib/v/tests/parse_type_of_ref_array_from_another_mod_test.v
Normal file
@ -0,0 +1,17 @@
|
||||
import another_module
|
||||
|
||||
struct SomeStruct {}
|
||||
|
||||
fn type_from_another_mod() {
|
||||
_ = &[]another_module.SomeStruct{}
|
||||
}
|
||||
|
||||
fn type_from_current_mod() {
|
||||
_ = &[]SomeStruct{}
|
||||
}
|
||||
|
||||
fn test_parse_type_of_ref_array() {
|
||||
type_from_another_mod()
|
||||
type_from_current_mod()
|
||||
assert true
|
||||
}
|
Loading…
Reference in New Issue
Block a user