checker: error on direct map alias init (#10282)

pull/10285/head
Lukas Neubert 2021-05-31 11:14:37 +02:00 committed by GitHub
parent 955dc12523
commit 09e3099580
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 21 additions and 4 deletions

View File

@ -673,10 +673,6 @@ fn (mut c Checker) unwrap_generic_struct(struct_type ast.Type, generic_names []s
} }
pub fn (mut c Checker) struct_init(mut struct_init ast.StructInit) ast.Type { pub fn (mut c Checker) struct_init(mut struct_init ast.StructInit) ast.Type {
// typ := c.table.find_type(struct_init.typ.typ.name) or {
// c.error('unknown struct: $struct_init.typ.typ.name', struct_init.pos)
// panic('')
// }
if struct_init.typ == ast.void_type { if struct_init.typ == ast.void_type {
// Short syntax `({foo: bar})` // Short syntax `({foo: bar})`
if c.expected_type == ast.void_type { if c.expected_type == ast.void_type {
@ -697,6 +693,16 @@ pub fn (mut c Checker) struct_init(mut struct_init ast.StructInit) ast.Type {
c.error('generic struct init must specify type parameter, e.g. Foo<int>', c.error('generic struct init must specify type parameter, e.g. Foo<int>',
struct_init.pos) struct_init.pos)
} }
} else if struct_sym.info is ast.Alias {
parent_sym := c.table.get_type_symbol(struct_sym.info.parent_type)
// e.g. ´x := MyMapAlias{}´, should be a cast to alias type ´x := MyMapAlias(map[...]...)´
if parent_sym.kind == .map {
alias_str := c.table.type_to_str(struct_init.typ)
map_str := c.table.type_to_str(struct_sym.info.parent_type)
c.error('direct map alias init is not possible, use `${alias_str}($map_str{})` instead',
struct_init.pos)
return ast.void_type
}
} }
utyp := c.unwrap_generic_struct(struct_init.typ, c.table.cur_fn.generic_names, c.cur_concrete_types) utyp := c.unwrap_generic_struct(struct_init.typ, c.table.cur_fn.generic_names, c.cur_concrete_types)
c.ensure_type_exists(utyp, struct_init.pos) or {} c.ensure_type_exists(utyp, struct_init.pos) or {}

View File

@ -0,0 +1,6 @@
vlib/v/checker/tests/direct_map_alias_init_err.vv:4:7: error: direct map alias init is not possible, use `WordSet(map[string]bool{})` instead
2 |
3 | fn main() {
4 | _ := WordSet{}
| ~~~~~~~~~
5 | }

View File

@ -0,0 +1,5 @@
type WordSet = map[string]bool
fn main() {
_ := WordSet{}
}