From a386be650569472058e3b0b17418e8eb504489cf Mon Sep 17 00:00:00 2001 From: Delyan Angelov Date: Fri, 19 Mar 2021 22:51:52 +0200 Subject: [PATCH] v.table: correct `table.types` to `table.type_symbols` --- vlib/v/builder/generics.v | 6 +++--- vlib/v/checker/checker.v | 6 +++--- vlib/v/gen/c/cgen.v | 8 ++++---- vlib/v/gen/c/comptime.v | 2 +- vlib/v/gen/c/sql.v | 4 ++-- vlib/v/parser/parser.v | 4 ++-- vlib/v/parser/pratt.v | 4 +++- vlib/v/table/table.v | 42 +++++++++++++++++++-------------------- 8 files changed, 39 insertions(+), 37 deletions(-) diff --git a/vlib/v/builder/generics.v b/vlib/v/builder/generics.v index 7b58c7df18..199e52bba7 100644 --- a/vlib/v/builder/generics.v +++ b/vlib/v/builder/generics.v @@ -7,11 +7,11 @@ import v.table // // generic struct instantiations to concrete types pub fn (b &Builder) generic_struct_insts_to_concrete() { - for idx, _ in b.table.types { - mut typ := unsafe { &b.table.types[idx] } + for idx, _ in b.table.type_symbols { + mut typ := unsafe { &b.table.type_symbols[idx] } if typ.kind == .generic_struct_inst { info := typ.info as table.GenericStructInst - parent := b.table.types[info.parent_idx] + parent := b.table.type_symbols[info.parent_idx] if parent.kind == .placeholder { typ.kind = .placeholder continue diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index 0345132b5e..ebbdbcd80b 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -5954,7 +5954,7 @@ fn (mut c Checker) sql_expr(mut node ast.SqlExpr) table.Type { info := sym.info as table.Struct fields := c.fetch_and_verify_orm_fields(info, node.table_expr.pos, sym.name) mut sub_structs := map[int]ast.SqlExpr{} - for f in fields.filter(c.table.types[int(it.typ)].kind == .struct_) { + for f in fields.filter(c.table.type_symbols[int(it.typ)].kind == .struct_) { mut n := ast.SqlExpr{ pos: node.pos has_where: true @@ -6030,7 +6030,7 @@ fn (mut c Checker) sql_stmt(mut node ast.SqlStmt) table.Type { info := table_sym.info as table.Struct fields := c.fetch_and_verify_orm_fields(info, node.table_expr.pos, table_sym.name) mut sub_structs := map[int]ast.SqlStmt{} - for f in fields.filter(c.table.types[int(it.typ)].kind == .struct_) { + for f in fields.filter(c.table.type_symbols[int(it.typ)].kind == .struct_) { mut n := ast.SqlStmt{ pos: node.pos db_expr: node.db_expr @@ -6061,7 +6061,7 @@ fn (mut c Checker) sql_stmt(mut node ast.SqlStmt) table.Type { fn (mut c Checker) fetch_and_verify_orm_fields(info table.Struct, pos token.Position, table_name string) []table.Field { fields := info.fields.filter((it.typ in [table.string_type, table.int_type, table.bool_type] - || c.table.types[int(it.typ)].kind == .struct_) && !it.attrs.contains('skip')) + || c.table.type_symbols[int(it.typ)].kind == .struct_) && !it.attrs.contains('skip')) if fields.len == 0 { c.error('V orm: select: empty fields in `$table_name`', pos) return []table.Field{} diff --git a/vlib/v/gen/c/cgen.v b/vlib/v/gen/c/cgen.v index 4170fa2e49..3cb0bb07ee 100644 --- a/vlib/v/gen/c/cgen.v +++ b/vlib/v/gen/c/cgen.v @@ -252,14 +252,14 @@ pub fn gen(files []ast.File, table &table.Table, pref &pref.Preferences) string } // to make sure type idx's are the same in cached mods if g.pref.build_mode == .build_module { - for idx, typ in g.table.types { + for idx, typ in g.table.type_symbols { if idx == 0 { continue } g.definitions.writeln('int _v_type_idx_${typ.cname}();') } } else if g.pref.use_cache { - for idx, typ in g.table.types { + for idx, typ in g.table.type_symbols { if idx == 0 { continue } @@ -454,7 +454,7 @@ pub fn (mut g Gen) init() { i++ } // methods - for type_sym in g.table.types { + for type_sym in g.table.type_symbols { if type_sym.mod != 'main' { continue } @@ -491,7 +491,7 @@ pub fn (mut g Gen) finish() { pub fn (mut g Gen) write_typeof_functions() { g.writeln('') g.writeln('// >> typeof() support for sum types / interfaces') - for typ in g.table.types { + for typ in g.table.type_symbols { if typ.kind == .sum_type { sum_info := typ.info as table.SumType g.writeln('static char * v_typeof_sumtype_${typ.cname}(int sidx) { /* $typ.name */ ') diff --git a/vlib/v/gen/c/comptime.v b/vlib/v/gen/c/comptime.v index 7a64e662a4..614dea9238 100644 --- a/vlib/v/gen/c/comptime.v +++ b/vlib/v/gen/c/comptime.v @@ -125,7 +125,7 @@ fn (mut g Gen) comptime_call(node ast.ComptimeCall) { idx := i - node.args.len if m.params[i].typ.is_int() || m.params[i].typ.idx() == table.bool_type_idx { // Gets the type name and cast the string to the type with the string_ function - type_name := g.table.types[int(m.params[i].typ)].str() + type_name := g.table.type_symbols[int(m.params[i].typ)].str() g.write('string_${type_name}(((string*)${node.args[node.args.len - 1]}.data) [$idx])') } else { g.write('((string*)${node.args[node.args.len - 1]}.data) [$idx] ') diff --git a/vlib/v/gen/c/sql.v b/vlib/v/gen/c/sql.v index e1812db7a3..933ddcd77b 100644 --- a/vlib/v/gen/c/sql.v +++ b/vlib/v/gen/c/sql.v @@ -135,7 +135,7 @@ fn (mut g Gen) sqlite3_stmt(node ast.SqlStmt, typ SqlType) { x := '${node.object_var_name}.$field.name' if field.typ == table.string_type { g.writeln('sqlite3_bind_text($g.sql_stmt_name, ${i + 0}, ${x}.str, ${x}.len, 0);') - } else if g.table.types[int(field.typ)].kind == .struct_ { + } else if g.table.type_symbols[int(field.typ)].kind == .struct_ { // insert again expr := node.sub_structs[int(field.typ)] tmp_sql_stmt_name := g.sql_stmt_name @@ -300,7 +300,7 @@ fn (mut g Gen) sqlite3_select_expr(node ast.SqlExpr, sub bool, line string, sql_ g.writeln('if ($string_data != NULL) {') g.writeln('\t${tmp}.$field.name = tos_clone($string_data);') g.writeln('}') - } else if g.table.types[int(field.typ)].kind == .struct_ { + } else if g.table.type_symbols[int(field.typ)].kind == .struct_ { id_name := g.new_tmp_var() g.writeln('//parse struct start') g.writeln('int $id_name = ${func}($g.sql_stmt_name, $i);') diff --git a/vlib/v/parser/parser.v b/vlib/v/parser/parser.v index 1f4bbbe414..94c352ae6c 100644 --- a/vlib/v/parser/parser.v +++ b/vlib/v/parser/parser.v @@ -69,7 +69,7 @@ mut: label_names []string in_generic_params bool // indicates if parsing between `<` and `>` of a method/function name_error bool // indicates if the token is not a name or the name is on another line - n_asm int // controls assembly labels + n_asm int // controls assembly labels inside_asm_template bool inside_asm bool } @@ -877,7 +877,7 @@ fn (mut p Parser) asm_stmt(is_top_level bool) ast.AsmStmt { parent: 0 // you shouldn't be able to reference other variables in assembly blocks detached_from_parent: true start_pos: p.tok.pos - objects: ast.all_registers(mut p.table, arch) // + objects: ast.all_registers(mut p.table, arch) // } mut local_labels := []string{} diff --git a/vlib/v/parser/pratt.v b/vlib/v/parser/pratt.v index 64b08b774e..00be1cf720 100644 --- a/vlib/v/parser/pratt.v +++ b/vlib/v/parser/pratt.v @@ -192,7 +192,9 @@ pub fn (mut p Parser) expr(precedence int) ast.Expr { pos: pos } } else { - p.register_used_import(p.tok.lit) + if p.tok.kind == .name { + p.register_used_import(p.tok.lit) + } save_expr_mod := p.expr_mod p.expr_mod = '' sizeof_type := p.parse_type() diff --git a/vlib/v/table/table.v b/vlib/v/table/table.v index 6a0c6ad587..8ba9421fe0 100644 --- a/vlib/v/table/table.v +++ b/vlib/v/table/table.v @@ -9,7 +9,7 @@ import v.util pub struct Table { pub mut: - types []TypeSymbol + type_symbols []TypeSymbol type_idxs map[string]int fns map[string]Fn dumps map[int]string // needed for efficiently generating all _v_dump_expr_TNAME() functions @@ -92,7 +92,7 @@ mut: pub fn new_table() &Table { mut t := &Table{ - types: []TypeSymbol{cap: 64000} + type_symbols: []TypeSymbol{cap: 64000} } t.register_builtin_type_symbols() t.is_fmt = true @@ -235,7 +235,7 @@ pub fn (t &Table) type_find_method(s &TypeSymbol, name string) ?Fn { if ts.parent_idx == 0 { break } - ts = unsafe { &t.types[ts.parent_idx] } + ts = unsafe { &t.type_symbols[ts.parent_idx] } } return none } @@ -308,7 +308,7 @@ pub fn (t &Table) find_field(s &TypeSymbol, name string) ?Field { if ts.parent_idx == 0 { break } - ts = unsafe { &t.types[ts.parent_idx] } + ts = unsafe { &t.type_symbols[ts.parent_idx] } } return none } @@ -388,7 +388,7 @@ pub fn (t &Table) find_type_idx(name string) int { pub fn (t &Table) find_type(name string) ?TypeSymbol { idx := t.type_idxs[name] if idx > 0 { - return t.types[idx] + return t.type_symbols[idx] } return none } @@ -398,7 +398,7 @@ pub fn (t &Table) get_type_symbol(typ Type) &TypeSymbol { // println('get_type_symbol $typ') idx := typ.idx() if idx > 0 { - return unsafe { &t.types[idx] } + return unsafe { &t.type_symbols[idx] } } // this should never happen panic('get_type_symbol: invalid type (typ=$typ idx=$idx). Compiler bug. This should never happen. Please create a GitHub issue. @@ -410,12 +410,12 @@ pub fn (t &Table) get_type_symbol(typ Type) &TypeSymbol { pub fn (t &Table) get_final_type_symbol(typ Type) &TypeSymbol { idx := typ.idx() if idx > 0 { - current_type := t.types[idx] + current_type := t.type_symbols[idx] if current_type.kind == .alias { alias_info := current_type.info as Alias return t.get_final_type_symbol(alias_info.parent_type) } - return unsafe { &t.types[idx] } + return unsafe { &t.type_symbols[idx] } } // this should never happen panic('get_final_type_symbol: invalid type (typ=$typ idx=$idx). Compiler bug. This should never happen. Please create a GitHub issue.') @@ -444,12 +444,12 @@ pub fn (mut t Table) register_type_symbol(typ TypeSymbol) int { // println('register_type_symbol( $typ.name )') existing_idx := t.type_idxs[typ.name] if existing_idx > 0 { - ex_type := t.types[existing_idx] + ex_type := t.type_symbols[existing_idx] match ex_type.kind { .placeholder { // override placeholder // println('overriding type placeholder `$typ.name`') - t.types[existing_idx] = TypeSymbol{ + t.type_symbols[existing_idx] = TypeSymbol{ ...typ methods: ex_type.methods } @@ -462,13 +462,13 @@ pub fn (mut t Table) register_type_symbol(typ TypeSymbol) int { if (existing_idx >= string_type_idx && existing_idx <= map_type_idx) || existing_idx == error_type_idx { if existing_idx == string_type_idx { - // existing_type := t.types[existing_idx] - t.types[existing_idx] = TypeSymbol{ + // existing_type := t.type_symbols[existing_idx] + t.type_symbols[existing_idx] = TypeSymbol{ ...typ kind: ex_type.kind } } else { - t.types[existing_idx] = typ + t.type_symbols[existing_idx] = typ } return existing_idx } @@ -476,8 +476,8 @@ pub fn (mut t Table) register_type_symbol(typ TypeSymbol) int { } } } - typ_idx := t.types.len - t.types << typ + typ_idx := t.type_symbols.len + t.type_symbols << typ t.type_idxs[typ.name] = typ_idx return typ_idx } @@ -772,7 +772,7 @@ pub fn (mut t Table) find_or_register_fn_type(mod string, f Fn, is_anon bool, ha anon := f.name.len == 0 || is_anon // existing existing_idx := t.type_idxs[name] - if existing_idx > 0 && t.types[existing_idx].kind != .placeholder { + if existing_idx > 0 && t.type_symbols[existing_idx].kind != .placeholder { return existing_idx } return t.register_type_symbol( @@ -906,15 +906,15 @@ pub fn (mytable &Table) has_deep_child_no_ref(ts &TypeSymbol, name string) bool // bitsize_to_type returns a type corresponding to the bit_size // Examples: -// +// // `8 > i8` -// +// // `32 > int` -// +// // `123 > panic()` -// +// // `128 > [16]byte` -// +// // `608 > [76]byte` pub fn (mut t Table) bitsize_to_type(bit_size int) Type { match bit_size {