mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
cgen: fix sum type assign/push from in match branch & type mod
This commit is contained in:
parent
64ba59590e
commit
1b3cd7abe0
@ -773,7 +773,7 @@ pub fn expr_is_call(expr Expr) bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn (expr Expr) position() token.Position {
|
pub fn (expr Expr) position() token.Position {
|
||||||
// all uncommented have to be implemented
|
// all uncommented have to be implemented
|
||||||
match mut expr {
|
match mut expr {
|
||||||
ArrayInit {
|
ArrayInit {
|
||||||
@ -867,7 +867,7 @@ fn (expr Expr) position() token.Position {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn (stmt Stmt) position() token.Position {
|
pub fn (stmt Stmt) position() token.Position {
|
||||||
match mut stmt {
|
match mut stmt {
|
||||||
AssertStmt {
|
AssertStmt {
|
||||||
return it.pos
|
return it.pos
|
||||||
|
@ -1821,7 +1821,7 @@ pub fn (mut c Checker) ident(ident mut ast.Ident) table.Type {
|
|||||||
}
|
}
|
||||||
// Non-anon-function object (not a call), e.g. `onclick(my_click)`
|
// Non-anon-function object (not a call), e.g. `onclick(my_click)`
|
||||||
if func := c.table.find_fn(name) {
|
if func := c.table.find_fn(name) {
|
||||||
fn_type := table.new_type(c.table.find_or_register_fn_type(func, false, true))
|
fn_type := table.new_type(c.table.find_or_register_fn_type(ident.mod, func, false, true))
|
||||||
ident.name = name
|
ident.name = name
|
||||||
ident.kind = .function
|
ident.kind = .function
|
||||||
ident.info = ast.IdentFn{
|
ident.info = ast.IdentFn{
|
||||||
|
@ -979,10 +979,10 @@ fn (mut g Gen) gen_assign_stmt(assign_stmt ast.AssignStmt) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
g.write(' = ')
|
g.write(' = ')
|
||||||
if !is_decl {
|
if is_decl {
|
||||||
g.expr_with_cast(val, assign_stmt.left_types[i], ident_var_info.typ)
|
|
||||||
} else {
|
|
||||||
g.expr(val)
|
g.expr(val)
|
||||||
|
} else {
|
||||||
|
g.expr_with_cast(val, assign_stmt.left_types[i], ident_var_info.typ)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if gen_or {
|
if gen_or {
|
||||||
|
@ -307,7 +307,7 @@ fn (mut p Parser) anon_fn() ast.AnonFn {
|
|||||||
}
|
}
|
||||||
name := 'anon_${p.tok.pos}_$func.signature()'
|
name := 'anon_${p.tok.pos}_$func.signature()'
|
||||||
func.name = name
|
func.name = name
|
||||||
idx := p.table.find_or_register_fn_type(func, true, false)
|
idx := p.table.find_or_register_fn_type(p.mod, func, true, false)
|
||||||
typ := table.new_type(idx)
|
typ := table.new_type(idx)
|
||||||
// name := p.table.get_type_name(typ)
|
// name := p.table.get_type_name(typ)
|
||||||
return ast.AnonFn{
|
return ast.AnonFn{
|
||||||
|
@ -84,7 +84,7 @@ pub fn (mut p Parser) parse_fn_type(name string) table.Type {
|
|||||||
is_variadic: is_variadic
|
is_variadic: is_variadic
|
||||||
return_type: return_type
|
return_type: return_type
|
||||||
}
|
}
|
||||||
idx := p.table.find_or_register_fn_type(func, false, false)
|
idx := p.table.find_or_register_fn_type(p.mod, func, false, false)
|
||||||
return table.new_type(idx)
|
return table.new_type(idx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1211,6 +1211,7 @@ fn (mut p Parser) enum_decl() ast.EnumDecl {
|
|||||||
p.table.register_type_symbol(table.TypeSymbol{
|
p.table.register_type_symbol(table.TypeSymbol{
|
||||||
kind: .enum_
|
kind: .enum_
|
||||||
name: name
|
name: name
|
||||||
|
mod: p.mod
|
||||||
info: table.Enum{
|
info: table.Enum{
|
||||||
vals: vals
|
vals: vals
|
||||||
}
|
}
|
||||||
@ -1264,6 +1265,7 @@ fn (mut p Parser) type_decl() ast.TypeDecl {
|
|||||||
p.table.register_type_symbol(table.TypeSymbol{
|
p.table.register_type_symbol(table.TypeSymbol{
|
||||||
kind: .sum_type
|
kind: .sum_type
|
||||||
name: p.prepend_mod(name)
|
name: p.prepend_mod(name)
|
||||||
|
mod: p.mod
|
||||||
info: table.SumType{
|
info: table.SumType{
|
||||||
variants: sum_variants
|
variants: sum_variants
|
||||||
}
|
}
|
||||||
@ -1283,6 +1285,7 @@ fn (mut p Parser) type_decl() ast.TypeDecl {
|
|||||||
kind: .alias
|
kind: .alias
|
||||||
name: p.prepend_mod(name)
|
name: p.prepend_mod(name)
|
||||||
parent_idx: pid
|
parent_idx: pid
|
||||||
|
mod: p.mod
|
||||||
info: table.Alias{
|
info: table.Alias{
|
||||||
foo: ''
|
foo: ''
|
||||||
}
|
}
|
||||||
|
@ -275,6 +275,7 @@ fn (mut p Parser) interface_decl() ast.InterfaceDecl {
|
|||||||
t := table.TypeSymbol{
|
t := table.TypeSymbol{
|
||||||
kind: .interface_
|
kind: .interface_
|
||||||
name: interface_name
|
name: interface_name
|
||||||
|
mod: p.mod
|
||||||
info: table.Interface{
|
info: table.Interface{
|
||||||
types: []
|
types: []
|
||||||
}
|
}
|
||||||
|
@ -357,94 +357,117 @@ pub fn (mut t Table) register_builtin_type_symbols() {
|
|||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .void
|
kind: .void
|
||||||
name: 'void'
|
name: 'void'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .voidptr
|
kind: .voidptr
|
||||||
name: 'voidptr'
|
name: 'voidptr'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .byteptr
|
kind: .byteptr
|
||||||
name: 'byteptr'
|
name: 'byteptr'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .charptr
|
kind: .charptr
|
||||||
name: 'charptr'
|
name: 'charptr'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .i8
|
kind: .i8
|
||||||
name: 'i8'
|
name: 'i8'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .i16
|
kind: .i16
|
||||||
name: 'i16'
|
name: 'i16'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .int
|
kind: .int
|
||||||
name: 'int'
|
name: 'int'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .i64
|
kind: .i64
|
||||||
name: 'i64'
|
name: 'i64'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .byte
|
kind: .byte
|
||||||
name: 'byte'
|
name: 'byte'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .u16
|
kind: .u16
|
||||||
name: 'u16'
|
name: 'u16'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .u32
|
kind: .u32
|
||||||
name: 'u32'
|
name: 'u32'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .u64
|
kind: .u64
|
||||||
name: 'u64'
|
name: 'u64'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .f32
|
kind: .f32
|
||||||
name: 'f32'
|
name: 'f32'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .f64
|
kind: .f64
|
||||||
name: 'f64'
|
name: 'f64'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .char
|
kind: .char
|
||||||
name: 'char'
|
name: 'char'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .bool
|
kind: .bool
|
||||||
name: 'bool'
|
name: 'bool'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .none_
|
kind: .none_
|
||||||
name: 'none'
|
name: 'none'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .string
|
kind: .string
|
||||||
name: 'string'
|
name: 'string'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .ustring
|
kind: .ustring
|
||||||
name: 'ustring'
|
name: 'ustring'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .array
|
kind: .array
|
||||||
name: 'array'
|
name: 'array'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .map
|
kind: .map
|
||||||
name: 'map'
|
name: 'map'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .any
|
kind: .any
|
||||||
name: 'any'
|
name: 'any'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .size_t
|
kind: .size_t
|
||||||
name: 'size_t'
|
name: 'size_t'
|
||||||
|
mod: 'builtin'
|
||||||
})
|
})
|
||||||
// TODO: remove. for v1 map compatibility
|
// TODO: remove. for v1 map compatibility
|
||||||
map_string_string_idx := t.find_or_register_map(string_type, string_type)
|
map_string_string_idx := t.find_or_register_map(string_type, string_type)
|
||||||
@ -452,11 +475,13 @@ pub fn (mut t Table) register_builtin_type_symbols() {
|
|||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .alias
|
kind: .alias
|
||||||
name: 'map_string'
|
name: 'map_string'
|
||||||
|
mod: 'builtin'
|
||||||
parent_idx: map_string_string_idx
|
parent_idx: map_string_string_idx
|
||||||
})
|
})
|
||||||
t.register_type_symbol(TypeSymbol{
|
t.register_type_symbol(TypeSymbol{
|
||||||
kind: .alias
|
kind: .alias
|
||||||
name: 'map_int'
|
name: 'map_int'
|
||||||
|
mod: 'builtin'
|
||||||
parent_idx: map_string_int_idx
|
parent_idx: map_string_int_idx
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -374,12 +374,13 @@ pub fn (mut t Table) find_or_register_multi_return(mr_typs []Type) int {
|
|||||||
return t.register_type_symbol(mr_type)
|
return t.register_type_symbol(mr_type)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn (mut t Table) find_or_register_fn_type(f Fn, is_anon, has_decl bool) int {
|
pub fn (mut t Table) find_or_register_fn_type(mod string, f Fn, is_anon, has_decl bool) int {
|
||||||
name := if f.name.len == 0 { 'anon_fn_$f.signature()' } else { f.name }
|
name := if f.name.len == 0 { 'anon_fn_$f.signature()' } else { f.name }
|
||||||
anon := f.name.len == 0 || is_anon
|
anon := f.name.len == 0 || is_anon
|
||||||
return t.register_type_symbol(TypeSymbol{
|
return t.register_type_symbol(TypeSymbol{
|
||||||
kind: .function
|
kind: .function
|
||||||
name: name
|
name: name
|
||||||
|
mod: mod
|
||||||
info: FnType{
|
info: FnType{
|
||||||
is_anon: anon
|
is_anon: anon
|
||||||
has_decl: has_decl
|
has_decl: has_decl
|
||||||
@ -516,13 +517,15 @@ pub fn (t &Table) check(got, expected Type) bool {
|
|||||||
// sum type
|
// sum type
|
||||||
if got_type_sym.kind == .sum_type {
|
if got_type_sym.kind == .sum_type {
|
||||||
sum_info := got_type_sym.info as SumType
|
sum_info := got_type_sym.info as SumType
|
||||||
if expected in sum_info.variants {
|
// TODO: handle `match SumType { &PtrVariant {} }` currently just checking base
|
||||||
|
if expected.set_nr_muls(0) in sum_info.variants {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if exp_type_sym.kind == .sum_type {
|
if exp_type_sym.kind == .sum_type {
|
||||||
sum_info := exp_type_sym.info as SumType
|
sum_info := exp_type_sym.info as SumType
|
||||||
if got in sum_info.variants {
|
// TODO: handle `match SumType { &PtrVariant {} }` currently just checking base
|
||||||
|
if got.set_nr_muls(0) in sum_info.variants {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -33,3 +33,21 @@ fn test_expr() {
|
|||||||
assert handle(expr) == 'int'
|
assert handle(expr) == 'int'
|
||||||
// assert expr is IntegerLiteral // TODO
|
// assert expr is IntegerLiteral // TODO
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn test_assignment_and_push() {
|
||||||
|
mut expr1 := Expr{}
|
||||||
|
mut arr1 := []Expr{}
|
||||||
|
expr := IntegerLiteral{
|
||||||
|
val: '111'
|
||||||
|
}
|
||||||
|
arr1 << expr
|
||||||
|
match arr1[0] {
|
||||||
|
IntegerLiteral {
|
||||||
|
arr1 << it
|
||||||
|
// should ref/dereference on assignent be made automatic?
|
||||||
|
// currently it is done for return stmt and fn args
|
||||||
|
expr1 = *it
|
||||||
|
}
|
||||||
|
else {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user