aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_utility.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2025-04-03 09:54:44 +0100
committergingerBill <bill@gingerbill.org>2025-04-03 09:54:44 +0100
commit4ebaed1fddd21a42623bfeff32558496e424326c (patch)
treed866ea8bfe77893347312d88444df1b473636d83 /src/llvm_backend_utility.cpp
parente412d3b4c15d24c644723ea89960f3507a0b6618 (diff)
Remove refactor
Diffstat (limited to 'src/llvm_backend_utility.cpp')
-rw-r--r--src/llvm_backend_utility.cpp49
1 files changed, 34 insertions, 15 deletions
diff --git a/src/llvm_backend_utility.cpp b/src/llvm_backend_utility.cpp
index 4064b3134..bfeebfcbe 100644
--- a/src/llvm_backend_utility.cpp
+++ b/src/llvm_backend_utility.cpp
@@ -2094,23 +2094,22 @@ gb_internal void lb_set_wasm_export_attributes(LLVMValueRef value, String export
}
-gb_internal lbAddr lb_handle_objc_find_or_register_internal(lbProcedure *p, StringMap<lbAddr> *objc_map, String const &name, char const *prefix, Type *type) {
+gb_internal lbAddr lb_handle_objc_find_or_register_selector(lbProcedure *p, String const &name) {
lbModule *m = p->module;
- lbAddr *found = string_map_get(objc_map, name);
+ lbAddr *found = string_map_get(&m->objc_selectors, name);
if (found) {
return *found;
}
lbModule *default_module = &p->module->gen->default_module;
-
- gbString global_name = gb_string_make(permanent_allocator(), prefix);
+ gbString global_name = gb_string_make(permanent_allocator(), "__$objc_SEL::");
global_name = gb_string_append_length(global_name, name.text, name.len);
- LLVMTypeRef t = lb_type(m, type);
+ LLVMTypeRef t = lb_type(m, t_objc_SEL);
lbValue g = {};
g.value = LLVMAddGlobal(m->mod, t, global_name);
- g.type = alloc_type_pointer(type);
+ g.type = alloc_type_pointer(t_objc_SEL);
if (default_module == m) {
LLVMSetInitializer(g.value, LLVMConstNull(t));
@@ -2119,21 +2118,41 @@ gb_internal lbAddr lb_handle_objc_find_or_register_internal(lbProcedure *p, Stri
LLVMSetLinkage(g.value, LLVMExternalLinkage);
}
- mpsc_enqueue(&m->gen->objc_selectors, lbObjCGlobal{m, global_name, name, type});
+ mpsc_enqueue(&m->gen->objc_selectors, lbObjCGlobal{m, global_name, name, t_objc_SEL});
lbAddr addr = lb_addr(g);
-
- string_map_set(objc_map, name, addr);
-
+ string_map_set(&m->objc_selectors, name, addr);
return addr;
}
-gb_internal lbAddr lb_handle_objc_find_or_register_selector(lbProcedure *p, String const &name) {
- return lb_handle_objc_find_or_register_internal(p, &p->module->objc_selectors, name, "__$objc_SEL::", t_objc_SEL);
-}
-
gb_internal lbAddr lb_handle_objc_find_or_register_class(lbProcedure *p, String const &name) {
- return lb_handle_objc_find_or_register_internal(p, &p->module->objc_classes, name, "__$objc_Class::", t_objc_Class);
+ lbModule *m = p->module;
+ lbAddr *found = string_map_get(&m->objc_classes, name);
+ if (found) {
+ return *found;
+ }
+
+ lbModule *default_module = &p->module->gen->default_module;
+
+ gbString global_name = gb_string_make(permanent_allocator(), "__$objc_Class::");
+ global_name = gb_string_append_length(global_name, name.text, name.len);
+
+ LLVMTypeRef t = lb_type(m, t_objc_Class);
+ lbValue g = {};
+ g.value = LLVMAddGlobal(m->mod, t, global_name);
+ g.type = alloc_type_pointer(t_objc_Class);
+
+ if (default_module == m) {
+ LLVMSetInitializer(g.value, LLVMConstNull(t));
+ lb_add_member(m, make_string_c(global_name), g);
+ } else {
+ LLVMSetLinkage(g.value, LLVMExternalLinkage);
+ }
+ mpsc_enqueue(&m->gen->objc_classes, lbObjCGlobal{m, global_name, name, t_objc_Class});
+
+ lbAddr addr = lb_addr(g);
+ string_map_set(&m->objc_classes, name, addr);
+ return addr;
}
gb_internal lbValue lb_handle_objc_find_selector(lbProcedure *p, Ast *expr) {