checker/cgen: small generic fixes (mut arg return)
parent
de76ac583f
commit
31d03bb113
|
@ -1226,7 +1226,7 @@ pub fn (mut c Checker) return_stmt(mut return_stmt ast.Return) {
|
||||||
if return_stmt.exprs.len == 0 {
|
if return_stmt.exprs.len == 0 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
expected_type := c.expected_type
|
expected_type := c.unwrap_generic(c.expected_type)
|
||||||
expected_type_sym := c.table.get_type_symbol(expected_type)
|
expected_type_sym := c.table.get_type_symbol(expected_type)
|
||||||
exp_is_optional := expected_type.has_flag(.optional)
|
exp_is_optional := expected_type.has_flag(.optional)
|
||||||
mut expected_types := [expected_type]
|
mut expected_types := [expected_type]
|
||||||
|
@ -1257,23 +1257,16 @@ pub fn (mut c Checker) return_stmt(mut return_stmt ast.Return) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
for i, exp_type in expected_types {
|
for i, exp_type in expected_types {
|
||||||
got_typ := got_types[i]
|
got_typ := c.unwrap_generic(got_types[i])
|
||||||
if got_typ.has_flag(.optional) &&
|
if got_typ.has_flag(.optional) &&
|
||||||
(!exp_type.has_flag(.optional) || c.table.type_to_str(got_typ) != c.table.type_to_str(exp_type)) {
|
(!exp_type.has_flag(.optional) || c.table.type_to_str(got_typ) != c.table.type_to_str(exp_type)) {
|
||||||
pos := return_stmt.exprs[i].position()
|
pos := return_stmt.exprs[i].position()
|
||||||
c.error('cannot use `${c.table.type_to_str(got_typ)}` as type `${c.table.type_to_str(exp_type)}` in return argument', pos)
|
c.error('cannot use `${c.table.type_to_str(got_typ)}` as type `${c.table.type_to_str(exp_type)}` in return argument', pos)
|
||||||
}
|
}
|
||||||
is_generic := exp_type == table.t_type
|
if !c.check_types(got_typ, exp_type) {
|
||||||
ok := if is_generic { c.check_types(got_typ, c.cur_generic_type) || got_typ == exp_type } else { c.check_types(got_typ,
|
|
||||||
exp_type) }
|
|
||||||
// ok := c.check_types(got_typ, exp_type)
|
|
||||||
if !ok { // !c.table.check(got_typ, exp_typ) {
|
|
||||||
got_typ_sym := c.table.get_type_symbol(got_typ)
|
got_typ_sym := c.table.get_type_symbol(got_typ)
|
||||||
mut exp_typ_sym := c.table.get_type_symbol(exp_type)
|
mut exp_typ_sym := c.table.get_type_symbol(exp_type)
|
||||||
pos := return_stmt.exprs[i].position()
|
pos := return_stmt.exprs[i].position()
|
||||||
if is_generic {
|
|
||||||
exp_typ_sym = c.table.get_type_symbol(c.cur_generic_type)
|
|
||||||
}
|
|
||||||
if exp_typ_sym.kind == .interface_ {
|
if exp_typ_sym.kind == .interface_ {
|
||||||
c.type_implements(got_typ, exp_type, return_stmt.pos)
|
c.type_implements(got_typ, exp_type, return_stmt.pos)
|
||||||
continue
|
continue
|
||||||
|
@ -1747,7 +1740,7 @@ fn (mut c Checker) stmts(stmts []ast.Stmt) {
|
||||||
c.expected_type = table.void_type
|
c.expected_type = table.void_type
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn (mut c Checker) unwrap_generic(typ table.Type) table.Type {
|
pub fn (c &Checker) unwrap_generic(typ table.Type) table.Type {
|
||||||
if typ.idx() == table.t_type_idx {
|
if typ.idx() == table.t_type_idx {
|
||||||
// return c.cur_generic_type
|
// return c.cur_generic_type
|
||||||
// its more efficient to set the id rather than to copy flags/nr_muls
|
// its more efficient to set the id rather than to copy flags/nr_muls
|
||||||
|
|
|
@ -328,7 +328,7 @@ fn (mut g Gen) call_expr(node ast.CallExpr) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn (mut g Gen) unwrap_generic(typ table.Type) table.Type {
|
pub fn (g &Gen) unwrap_generic(typ table.Type) table.Type {
|
||||||
if typ.idx() == table.t_type_idx {
|
if typ.idx() == table.t_type_idx {
|
||||||
// return g.cur_generic_type
|
// return g.cur_generic_type
|
||||||
// its more efficient to set the id rather than to copy flags/nr_muls
|
// its more efficient to set the id rather than to copy flags/nr_muls
|
||||||
|
|
|
@ -68,18 +68,18 @@ fn mut_arg<T>(mut x T) {
|
||||||
println(x.foo) // = 'foo'
|
println(x.foo) // = 'foo'
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
fn mut_arg2<T>(mut x T) T {
|
fn mut_arg2<T>(mut x T) T {
|
||||||
println(x.foo) // = 'foo'
|
println(x.foo) // = 'foo'
|
||||||
return x
|
return x
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
fn test_create() {
|
fn test_create() {
|
||||||
create<User>()
|
create<User>()
|
||||||
create<City>()
|
create<City>()
|
||||||
u := User{}
|
u := User{}
|
||||||
mut_arg<User>(mut u)
|
mut_arg<User>(mut u)
|
||||||
// mut_arg2<User>(mut u)
|
mut_arg2<User>(mut u)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in New Issue