diff options
| author | gingerBill <bill@gingerbill.org> | 2019-01-05 11:15:23 +0000 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2019-01-05 11:15:23 +0000 |
| commit | 9156af2babba8f228173f053e0a8046abb356fff (patch) | |
| tree | 49c7e897da10d5aca9117aaef53ef8e18c4c10c5 /src/checker.cpp | |
| parent | 3a18ae397843ff4ec3f161b28f6473c1945663c8 (diff) | |
Add missing types to minimum dependency checking
Diffstat (limited to 'src/checker.cpp')
| -rw-r--r-- | src/checker.cpp | 30 |
1 files changed, 29 insertions, 1 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"); |