diff --git a/vlib/v/ast/types.v b/vlib/v/ast/types.v index bf010299d0..deccf01c0e 100644 --- a/vlib/v/ast/types.v +++ b/vlib/v/ast/types.v @@ -16,7 +16,7 @@ import v.pref pub type Type = int -pub type TypeInfo = Aggregate | Alias | Array | ArrayFixed | Chan | Enum | FnType | GenericStructInst | +pub type TypeInfo = Aggregate | Alias | Array | ArrayFixed | Chan | Enum | FnType | GenericInst | Interface | Map | MultiReturn | Struct | SumType | Thread pub enum Language { @@ -517,7 +517,7 @@ pub enum Kind { chan any struct_ - generic_struct_inst + generic_inst multi_return sum_type alias @@ -750,7 +750,7 @@ pub fn (k Kind) str() string { .any { 'any' } .function { 'function' } .interface_ { 'interface' } - .generic_struct_inst { 'generic_struct_inst' } + .generic_inst { 'generic_inst' } .rune { 'rune' } .aggregate { 'aggregate' } .thread { 'thread' } @@ -785,7 +785,7 @@ pub mut: } // instantiation of a generic struct -pub struct GenericStructInst { +pub struct GenericInst { pub mut: parent_idx int // idx of the base generic struct concrete_types []Type // concrete types, e.g. @@ -1030,8 +1030,8 @@ pub fn (t &Table) type_to_str_using_aliases(typ Type, import_aliases map[string] res = t.shorten_user_defined_typenames(res, import_aliases) } } - .generic_struct_inst { - info := sym.info as GenericStructInst + .generic_inst { + info := sym.info as GenericInst res = sym.name.all_before('<') res += '<' for i, ctyp in info.concrete_types { diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index 42c6b50c7d..3090585341 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -793,8 +793,8 @@ fn (mut c Checker) unwrap_generic_type(typ ast.Type, generic_names []string, con // generic struct instantiations to concrete types pub fn (mut c Checker) generic_insts_to_concrete() { for mut typ in c.table.type_symbols { - if typ.kind == .generic_struct_inst { - info := typ.info as ast.GenericStructInst + if typ.kind == .generic_inst { + info := typ.info as ast.GenericInst parent := c.table.type_symbols[info.parent_idx] if parent.kind == .placeholder { typ.kind = .placeholder diff --git a/vlib/v/gen/js/builtin_types.v b/vlib/v/gen/js/builtin_types.v index 1bd1c15d47..0b16fc006c 100644 --- a/vlib/v/gen/js/builtin_types.v +++ b/vlib/v/gen/js/builtin_types.v @@ -171,7 +171,7 @@ pub fn (mut g JsGen) typ(t ast.Type) string { .struct_ { styp = g.struct_typ(sym.name) } - .generic_struct_inst {} + .generic_inst {} // 'multi_return_int_int' => '[number, number]' .multi_return { info := sym.info as ast.MultiReturn diff --git a/vlib/v/parser/fn.v b/vlib/v/parser/fn.v index b97fa4f1df..f24e1572b9 100644 --- a/vlib/v/parser/fn.v +++ b/vlib/v/parser/fn.v @@ -912,8 +912,9 @@ fn (mut p Parser) fn_args() ([]ast.Param, bool, bool) { fn (mut p Parser) check_fn_mutable_arguments(typ ast.Type, pos token.Position) { sym := p.table.get_type_symbol(typ) - if sym.kind in [.array, .array_fixed, .interface_, .map, .placeholder, .struct_, - .generic_struct_inst, .sum_type] { + if sym.kind in [.array, .array_fixed, .interface_, .map, .placeholder, .struct_, .generic_inst, + .sum_type, + ] { return } if typ.is_ptr() || typ.is_pointer() { diff --git a/vlib/v/parser/parse_type.v b/vlib/v/parser/parse_type.v index 718e78c85f..08a89d9395 100644 --- a/vlib/v/parser/parse_type.v +++ b/vlib/v/parser/parse_type.v @@ -562,11 +562,11 @@ pub fn (mut p Parser) parse_generic_struct_inst_type(name string) ast.Type { parent_idx = p.table.add_placeholder_type(name, .v) } idx := p.table.register_type_symbol(ast.TypeSymbol{ - kind: .generic_struct_inst + kind: .generic_inst name: bs_name cname: util.no_dots(bs_cname) mod: p.mod - info: ast.GenericStructInst{ + info: ast.GenericInst{ parent_idx: parent_idx concrete_types: concrete_types }