From ff94c605e01a20c44e34ebd8469b9ceffbed6f59 Mon Sep 17 00:00:00 2001 From: gingerBill Date: Tue, 9 Aug 2022 18:08:30 +0100 Subject: [PATCH] Minor change to `lb_emit_store` for storing nil to procedure variables --- src/llvm_backend_general.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/llvm_backend_general.cpp b/src/llvm_backend_general.cpp index eb5cf371c..58de9d36a 100644 --- a/src/llvm_backend_general.cpp +++ b/src/llvm_backend_general.cpp @@ -853,7 +853,9 @@ void lb_emit_store(lbProcedure *p, lbValue ptr, lbValue value) { if (LLVMIsNull(value.value)) { LLVMTypeRef src_t = llvm_addr_type(p->module, ptr); - if (lb_sizeof(src_t) <= lb_max_zero_init_size()) { + if (is_type_proc(a)) { + LLVMBuildStore(p->builder, LLVMConstNull(llvm_get_element_type(LLVMTypeOf(ptr.value))), ptr.value); + } else if (lb_sizeof(src_t) <= lb_max_zero_init_size()) { LLVMBuildStore(p->builder, LLVMConstNull(src_t), ptr.value); } else { lb_mem_zero_ptr(p, ptr.value, a, 1);