aboutsummaryrefslogtreecommitdiff
path: root/src/checker.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2019-01-05 11:15:23 +0000
committergingerBill <bill@gingerbill.org>2019-01-05 11:15:23 +0000
commit9156af2babba8f228173f053e0a8046abb356fff (patch)
tree49c7e897da10d5aca9117aaef53ef8e18c4c10c5 /src/checker.cpp
parent3a18ae397843ff4ec3f161b28f6473c1945663c8 (diff)
Add missing types to minimum dependency checking
Diffstat (limited to 'src/checker.cpp')
-rw-r--r--src/checker.cpp30
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");