From 9156af2babba8f228173f053e0a8046abb356fff Mon Sep 17 00:00:00 2001 From: gingerBill Date: Sat, 5 Jan 2019 11:15:23 +0000 Subject: [PATCH] Add missing types to minimum dependency checking --- src/checker.cpp | 30 +++++++++++++++++++++++++++++- src/ir.cpp | 10 ++++++++-- 2 files changed, 37 insertions(+), 3 deletions(-) diff --git a/src/checker.cpp b/src/checker.cpp index 24539354b..d2a500bae 100644 --- a/src/checker.cpp +++ b/src/checker.cpp @@ -1143,6 +1143,8 @@ void add_type_info_type(CheckerContext *c, Type *t) { add_type_info_type(c, bt); switch (bt->kind) { + case Type_Invalid: + break; case Type_Basic: switch (bt->Basic.kind) { case Basic_string: @@ -1194,6 +1196,7 @@ void add_type_info_type(CheckerContext *c, Type *t) { case Type_BitSet: add_type_info_type(c, bt->BitSet.elem); + add_type_info_type(c, bt->BitSet.underlying); break; case Type_Opaque: @@ -1239,6 +1242,10 @@ void add_type_info_type(CheckerContext *c, Type *t) { add_type_info_type(c, bt->Proc.params); add_type_info_type(c, bt->Proc.results); break; + + default: + GB_PANIC("Unhandled type: %*.s", LIT(type_strings[bt->kind])); + break; } } @@ -1304,6 +1311,8 @@ void add_min_dep_type_info(Checker *c, Type *t) { add_min_dep_type_info(c, bt); switch (bt->kind) { + case Type_Invalid: + break; case Type_Basic: switch (bt->Basic.kind) { case Basic_string: @@ -1311,8 +1320,8 @@ void add_min_dep_type_info(Checker *c, Type *t) { add_min_dep_type_info(c, t_int); break; case Basic_any: - add_min_dep_type_info(c, t_type_info_ptr); add_min_dep_type_info(c, t_rawptr); + add_min_dep_type_info(c, t_typeid); break; case Basic_complex64: @@ -1326,6 +1335,15 @@ void add_min_dep_type_info(Checker *c, Type *t) { } break; + case Type_Opaque: + add_min_dep_type_info(c, bt->Opaque.elem); + break; + + case Type_BitSet: + add_min_dep_type_info(c, bt->BitSet.elem); + add_min_dep_type_info(c, bt->BitSet.underlying); + break; + case Type_Pointer: add_min_dep_type_info(c, bt->Pointer.elem); break; @@ -1390,6 +1408,10 @@ void add_min_dep_type_info(Checker *c, Type *t) { add_min_dep_type_info(c, bt->Proc.params); add_min_dep_type_info(c, bt->Proc.results); break; + + default: + GB_PANIC("Unhandled type: %*.s", LIT(type_strings[bt->kind])); + break; } } @@ -3518,6 +3540,12 @@ void check_parsed_files(Checker *c) { TIME_SECTION("generate minimum dependency set"); generate_minimum_dependency_set(c, c->info.entry_point); + for_array(i, c->info.minimum_dependency_set.entries) { + Entity *e = c->info.minimum_dependency_set.entries[i].ptr; + if (is_type_bit_set(e->type)) { + gb_printf("%.*s\n", LIT(e->token.string)); + } + } TIME_SECTION("calculate global init order"); diff --git a/src/ir.cpp b/src/ir.cpp index 604e61d4b..757b5adf3 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -4567,6 +4567,12 @@ irValue *ir_emit_conv(irProcedure *proc, irValue *value, Type *t) { if (is_type_u8_ptr(src) && is_type_cstring(dst)) { return ir_emit_bitcast(proc, value, dst); } + if (is_type_cstring(src) && is_type_rawptr(dst)) { + return ir_emit_bitcast(proc, value, dst); + } + if (is_type_rawptr(src) && is_type_cstring(dst)) { + return ir_emit_bitcast(proc, value, dst); + } if (are_types_identical(src, t_cstring) && are_types_identical(dst, t_string)) { irValue *c = ir_emit_conv(proc, value, t_cstring); @@ -4842,7 +4848,7 @@ irValue *ir_emit_transmute(irProcedure *proc, irValue *value, Type *t) { if (is_type_integer(src) && (is_type_pointer(dst) || is_type_cstring(dst))) { Type *vt = core_type(ir_type(value)); return ir_emit(proc, ir_instr_conv(proc, irConv_inttoptr, value, vt, t)); - }else if ((is_type_pointer(src) || is_type_cstring(src)) && is_type_integer(dst)) { + } else if ((is_type_pointer(src) || is_type_cstring(src)) && is_type_integer(dst)) { Type *vt = core_type(ir_type(value)); return ir_emit(proc, ir_instr_conv(proc, irConv_ptrtoint, value, vt, t)); } @@ -5014,7 +5020,7 @@ isize ir_type_info_index(CheckerInfo *info, Type *type, bool err_on_not_found=tr } } if (err_on_not_found) { - GB_PANIC("NOT FOUND ir_type_info_index %s", type_to_string(type)); + GB_PANIC("NOT FOUND ir_type_info_index %s @ index %td", type_to_string(type), index); } return -1; }