diff options
| author | gingerBill <bill@gingerbill.org> | 2018-12-02 20:59:08 +0000 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2018-12-02 20:59:08 +0000 |
| commit | 304c7594cd2d904072917bb79d0aa340090d8296 (patch) | |
| tree | 2e5e06962f8d54c72d8b29026306bebb861eaa0e /src/checker.cpp | |
| parent | d02b0508508dd92e6cb72bd610f33ae37a999ede (diff) | |
Ignore `ir_emit_byte_swap` for constant values
Diffstat (limited to 'src/checker.cpp')
| -rw-r--r-- | src/checker.cpp | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/src/checker.cpp b/src/checker.cpp index 75ff5ea65..44a76db67 100644 --- a/src/checker.cpp +++ b/src/checker.cpp @@ -1812,11 +1812,23 @@ void init_core_source_code_location(Checker *c) { void init_core_map_type(Checker *c) { if (t_map_key == nullptr) { - t_map_key = find_core_type(c, str_lit("Map_Key")); + Entity *e = find_core_entity(c, str_lit("Map_Key")); + if (e->state == EntityState_Unresolved) { + auto ctx = c->init_ctx; + check_entity_decl(&ctx, e, nullptr, nullptr); + } + t_map_key = e->type; + GB_ASSERT(t_map_key != nullptr); } if (t_map_header == nullptr) { - t_map_header = find_core_type(c, str_lit("Map_Header")); + Entity *e = find_core_entity(c, str_lit("Map_Header")); + if (e->state == EntityState_Unresolved) { + auto ctx = c->init_ctx; + check_entity_decl(&ctx, e, nullptr, nullptr); + } + t_map_header = e->type; + GB_ASSERT(t_map_header != nullptr); } } |