diff options
| author | gingerBill <bill@gingerbill.org> | 2022-09-21 13:03:13 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2022-09-21 13:03:13 +0100 |
| commit | ff97a731521dbeb9a6457a889f30f4fa69e080f7 (patch) | |
| tree | 984fa5a3fe7cc9cec973689f2553f0634b37920e /src/llvm_backend_general.cpp | |
| parent | 769d8dd038601d6e7ad0ddb445593e65c4596074 (diff) | |
Reduce unnecessary map gets
Diffstat (limited to 'src/llvm_backend_general.cpp')
| -rw-r--r-- | src/llvm_backend_general.cpp | 20 |
1 files changed, 4 insertions, 16 deletions
diff --git a/src/llvm_backend_general.cpp b/src/llvm_backend_general.cpp index 55b09cbfc..ba1c501ad 100644 --- a/src/llvm_backend_general.cpp +++ b/src/llvm_backend_general.cpp @@ -74,6 +74,9 @@ void lb_init_module(lbModule *m, Checker *c) { string_map_init(&m->objc_classes, a); string_map_init(&m->objc_selectors, a); + + map_init(&m->map_header_table_map, a, 0); + } bool lb_init_generator(lbGenerator *gen, Checker *c) { @@ -383,21 +386,6 @@ Type *lb_addr_type(lbAddr const &addr) { return type_deref(addr.addr.type); } -lbValue lb_internal_dynamic_map_get_ptr(lbProcedure *p, lbValue const &map_ptr, lbValue const &key) { - Type *map_type = base_type(type_deref(map_ptr.type)); - lbValue h = lb_gen_map_header(p, map_ptr, map_type); - - lbValue key_ptr = {}; - auto args = array_make<lbValue>(permanent_allocator(), 3); - args[0] = h; - args[1] = lb_gen_map_key_hash(p, key, map_type->Map.key, &key_ptr); - args[2] = key_ptr; - - lbValue ptr = lb_emit_runtime_call(p, "__dynamic_map_get", args); - - return lb_emit_conv(p, ptr, alloc_type_pointer(map_type->Map.value)); -} - lbValue lb_addr_get_ptr(lbProcedure *p, lbAddr const &addr) { if (addr.addr.value == nullptr) { GB_PANIC("Illegal addr -> nullptr"); @@ -715,7 +703,7 @@ void lb_addr_store(lbProcedure *p, lbAddr addr, lbValue value) { return; } else if (addr.kind == lbAddr_Map) { - lb_insert_dynamic_map_key_and_value(p, addr, addr.map.type, addr.map.key, value, p->curr_stmt); + lb_insert_dynamic_map_key_and_value(p, addr.addr, addr.map.type, addr.map.key, value, p->curr_stmt); return; } else if (addr.kind == lbAddr_Context) { lbAddr old_addr = lb_find_or_generate_context_ptr(p); |