From 09e30995802b7f6b43205ff1b806b02efbdd60c0 Mon Sep 17 00:00:00 2001 From: Lukas Neubert Date: Mon, 31 May 2021 11:14:37 +0200 Subject: [PATCH] checker: error on direct map alias init (#10282) --- vlib/v/checker/checker.v | 14 ++++++++++---- vlib/v/checker/tests/direct_map_alias_init_err.out | 6 ++++++ vlib/v/checker/tests/direct_map_alias_init_err.vv | 5 +++++ 3 files changed, 21 insertions(+), 4 deletions(-) create mode 100644 vlib/v/checker/tests/direct_map_alias_init_err.out create mode 100644 vlib/v/checker/tests/direct_map_alias_init_err.vv diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index eac50c5936..0be5cdb743 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -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 { - // 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 { // Short syntax `({foo: bar})` 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', 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) c.ensure_type_exists(utyp, struct_init.pos) or {} diff --git a/vlib/v/checker/tests/direct_map_alias_init_err.out b/vlib/v/checker/tests/direct_map_alias_init_err.out new file mode 100644 index 0000000000..d198c66357 --- /dev/null +++ b/vlib/v/checker/tests/direct_map_alias_init_err.out @@ -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 | } diff --git a/vlib/v/checker/tests/direct_map_alias_init_err.vv b/vlib/v/checker/tests/direct_map_alias_init_err.vv new file mode 100644 index 0000000000..5921f5bf44 --- /dev/null +++ b/vlib/v/checker/tests/direct_map_alias_init_err.vv @@ -0,0 +1,5 @@ +type WordSet = map[string]bool + +fn main() { + _ := WordSet{} +}