mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
v2: name_expr mod & type & var fixes
This commit is contained in:
parent
7eee5cf116
commit
a707ffc04a
@ -584,7 +584,8 @@ pub fn (p mut Parser) name_expr() ast.Expr {
|
|||||||
map_type := p.parse_map_type()
|
map_type := p.parse_map_type()
|
||||||
return node
|
return node
|
||||||
}
|
}
|
||||||
if p.peek_tok.kind == .dot && (is_c || p.known_import(p.tok.lit) || p.mod.all_after('.') == p.tok.lit) {
|
known_var := p.scope.known_var(p.tok.lit)
|
||||||
|
if p.peek_tok.kind == .dot && !known_var && (is_c || p.known_import(p.tok.lit) || p.mod.all_after('.') == p.tok.lit) {
|
||||||
if is_c {
|
if is_c {
|
||||||
mod = 'C'
|
mod = 'C'
|
||||||
}
|
}
|
||||||
@ -603,9 +604,10 @@ pub fn (p mut Parser) name_expr() ast.Expr {
|
|||||||
if mod.len > 0 {
|
if mod.len > 0 {
|
||||||
name = '${mod}.$name'
|
name = '${mod}.$name'
|
||||||
}
|
}
|
||||||
|
name_w_mod := p.prepend_mod(name)
|
||||||
// type cast. TODO: finish
|
// type cast. TODO: finish
|
||||||
// if name in table.builtin_type_names {
|
// if name in table.builtin_type_names {
|
||||||
if name in p.table.type_idxs && !(name in ['C.stat', 'C.sigaction']) {
|
if (name in p.table.type_idxs || name_w_mod in p.table.type_idxs) && !(name in ['C.stat', 'C.sigaction']) {
|
||||||
// TODO handle C.stat()
|
// TODO handle C.stat()
|
||||||
to_typ := p.parse_type()
|
to_typ := p.parse_type()
|
||||||
p.check(.lpar)
|
p.check(.lpar)
|
||||||
@ -641,9 +643,7 @@ pub fn (p mut Parser) name_expr() ast.Expr {
|
|||||||
// || p.table.known_type(p.tok.lit)) {
|
// || p.table.known_type(p.tok.lit)) {
|
||||||
return p.struct_init()
|
return p.struct_init()
|
||||||
}
|
}
|
||||||
else if p.peek_tok.kind == .dot &&
|
else if p.peek_tok.kind == .dot && (p.tok.lit[0].is_capital() && !known_var) {
|
||||||
//
|
|
||||||
(p.tok.lit[0].is_capital() && !p.scope.known_var(p.tok.lit)) {
|
|
||||||
// `Color.green`
|
// `Color.green`
|
||||||
mut enum_name := p.check_name()
|
mut enum_name := p.check_name()
|
||||||
if mod != '' {
|
if mod != '' {
|
||||||
|
Loading…
Reference in New Issue
Block a user