aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_utility.cpp
diff options
context:
space:
mode:
authorHarold Brenes <harold@hbrenes.com>2025-04-22 19:16:29 -0400
committerHarold Brenes <harold@hbrenes.com>2025-04-22 19:18:53 -0400
commitbca02f81cd5affa288bac0cc0ed08fe730072aec (patch)
tree1a8cea710264b1cbacc079fb516ba800320e4341 /src/llvm_backend_utility.cpp
parentb3b4d501ca6c1af70c0ceef7610f6c5d83a2d296 (diff)
Include the ivar in the Objective-C class unconditionally of it being used or not.
Allow pseudo-fields for ivar access.
Diffstat (limited to 'src/llvm_backend_utility.cpp')
-rw-r--r--src/llvm_backend_utility.cpp31
1 files changed, 18 insertions, 13 deletions
diff --git a/src/llvm_backend_utility.cpp b/src/llvm_backend_utility.cpp
index ae7842ce6..33211395a 100644
--- a/src/llvm_backend_utility.cpp
+++ b/src/llvm_backend_utility.cpp
@@ -2191,25 +2191,30 @@ gb_internal lbAddr lb_handle_objc_find_or_register_ivar(lbModule *m, Type *self_
return addr;
}
-gb_internal lbValue lb_handle_objc_ivar_get(lbProcedure *p, Ast *expr) {
- ast_node(ce, CallExpr, expr);
- lbModule *m = p->module;
+gb_internal lbValue lb_handle_objc_ivar_for_objc_object_pointer(lbProcedure *p, lbValue self) {
+ GB_ASSERT(self.type->kind == Type_Pointer && self.type->Pointer.elem->kind == Type_Named);
- GB_ASSERT(ce->args[0]->tav.type->kind == Type_Pointer);
- Type *self_type = ce->args[0]->tav.type->Pointer.elem;
- Type *ivar_type = self_type->Named.type_name->TypeName.objc_ivar;
+ Type *self_type = self.type->Pointer.elem;
+
+ lbValue self_uptr = lb_emit_conv(p, self, t_uintptr);
+
+ lbValue ivar_offset = lb_addr_load(p, lb_handle_objc_find_or_register_ivar(p->module, self_type));
+ lbValue ivar_offset_uptr = lb_emit_conv(p, ivar_offset, t_uintptr);
- Type* p_ivar = alloc_type_pointer(ivar_type);
- lbValue ivar_offset = lb_addr_load(p, lb_handle_objc_find_or_register_ivar(m, self_type));
- lbValue ivar_offset_uptr = lb_emit_conv(p, ivar_offset, t_uintptr);
+ lbValue ivar_uptr = lb_emit_arith(p, Token_Add, self_uptr, ivar_offset_uptr, t_uintptr);
- lbValue self = lb_build_expr(p, ce->args[0]);
- lbValue self_uptr = lb_emit_conv(p, self, t_uintptr);
+ Type *ivar_type = self_type->Named.type_name->TypeName.objc_ivar;
+ return lb_emit_conv(p, ivar_uptr, alloc_type_pointer(ivar_type));
+}
- lbValue ivar_uptr = lb_emit_arith(p, Token_Add, self_uptr, ivar_offset_uptr, t_uintptr);
+gb_internal lbValue lb_handle_objc_ivar_get(lbProcedure *p, Ast *expr) {
+ ast_node(ce, CallExpr, expr);
+
+ GB_ASSERT(ce->args[0]->tav.type->kind == Type_Pointer);
+ lbValue self = lb_build_expr(p, ce->args[0]);
- return lb_emit_conv(p, ivar_uptr, p_ivar);
+ return lb_handle_objc_ivar_for_objc_object_pointer(p, self);
}
gb_internal lbValue lb_handle_objc_find_selector(lbProcedure *p, Ast *expr) {