diff options
| author | gingerBill <gingerBill@users.noreply.github.com> | 2024-04-04 13:03:27 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-04-04 13:03:27 +0100 |
| commit | 99aff7e3fbf77e3165054edbf84a507c776e34ce (patch) | |
| tree | eaf544ddb87d1f616d4bf89da8245828859df974 /src | |
| parent | 5fe0788cffcbcfd153ea23954b5a11a853ef50b4 (diff) | |
| parent | 5339e1e1b6824b67fbbe195e18d1122bda3dd6f7 (diff) | |
Merge pull request #3370 from laytan/fix-objc-proc-group-edge-case
fix objc proc group edge case
Diffstat (limited to 'src')
| -rw-r--r-- | src/llvm_backend_expr.cpp | 6 | ||||
| -rw-r--r-- | src/types.cpp | 2 |
2 files changed, 5 insertions, 3 deletions
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp index f6f36e861..0649150ca 100644 --- a/src/llvm_backend_expr.cpp +++ b/src/llvm_backend_expr.cpp @@ -4677,8 +4677,10 @@ gb_internal lbAddr lb_build_addr_internal(lbProcedure *p, Ast *expr) { if (tav.mode == Addressing_Type) { // Addressing_Type Selection sel = lookup_field(tav.type, selector, true); if (sel.pseudo_field) { - GB_ASSERT(sel.entity->kind == Entity_Procedure); - return lb_addr(lb_find_value_from_entity(p->module, sel.entity)); + GB_ASSERT(sel.entity->kind == Entity_Procedure || sel.entity->kind == Entity_ProcGroup); + Entity *e = entity_of_node(sel_node); + GB_ASSERT(e->kind == Entity_Procedure); + return lb_addr(lb_find_value_from_entity(p->module, e)); } GB_PANIC("Unreachable %.*s", LIT(selector)); } diff --git a/src/types.cpp b/src/types.cpp index 0bf28a28c..97512d29b 100644 --- a/src/types.cpp +++ b/src/types.cpp @@ -3158,7 +3158,7 @@ gb_internal Selection lookup_field_with_selection(Type *type_, String field_name mutex_lock(md->mutex); defer (mutex_unlock(md->mutex)); for (TypeNameObjCMetadataEntry const &entry : md->type_entries) { - GB_ASSERT(entry.entity->kind == Entity_Procedure); + GB_ASSERT(entry.entity->kind == Entity_Procedure || entry.entity->kind == Entity_ProcGroup); if (entry.name == field_name) { sel.entity = entry.entity; sel.pseudo_field = true; |