aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_debug.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/llvm_backend_debug.cpp')
-rw-r--r--src/llvm_backend_debug.cpp41
1 files changed, 34 insertions, 7 deletions
diff --git a/src/llvm_backend_debug.cpp b/src/llvm_backend_debug.cpp
index 60978d321..8da0697a7 100644
--- a/src/llvm_backend_debug.cpp
+++ b/src/llvm_backend_debug.cpp
@@ -569,14 +569,41 @@ LLVMMetadataRef lb_debug_type(lbModule *m, Type *type) {
case Type_Struct:
case Type_Union:
case Type_BitSet:
- LLVMMetadataRef temp_forward_decl = LLVMDIBuilderCreateReplaceableCompositeType(
- m->debug_builder, tag, name_text, name_len, nullptr, nullptr, 0, 0, size_in_bits, align_in_bits, flags, "", 0
- );
- idt.metadata = temp_forward_decl;
+ {
+ LLVMMetadataRef temp_forward_decl = LLVMDIBuilderCreateReplaceableCompositeType(
+ m->debug_builder, tag, name_text, name_len, nullptr, nullptr, 0, 0, size_in_bits, align_in_bits, flags, "", 0
+ );
+ idt.metadata = temp_forward_decl;
+
+ array_add(&m->debug_incomplete_types, idt);
+ lb_set_llvm_metadata(m, type, temp_forward_decl);
+
+ LLVMMetadataRef dummy = nullptr;
+ switch (bt->kind) {
+ case Type_Slice:
+ dummy = lb_debug_type(m, bt->Slice.elem);
+ dummy = lb_debug_type(m, t_int);
+ break;
+ case Type_DynamicArray:
+ dummy = lb_debug_type(m, bt->DynamicArray.elem);
+ dummy = lb_debug_type(m, t_int);
+ dummy = lb_debug_type(m, t_allocator);
+ break;
+ case Type_Map:
+ dummy = lb_debug_type(m, bt->Map.key);
+ dummy = lb_debug_type(m, bt->Map.value);
+ dummy = lb_debug_type(m, t_int);
+ dummy = lb_debug_type(m, t_allocator);
+ dummy = lb_debug_type(m, t_uintptr);
+ break;
+ case Type_BitSet:
+ if (bt->BitSet.elem) dummy = lb_debug_type(m, bt->BitSet.elem);
+ if (bt->BitSet.underlying) dummy = lb_debug_type(m, bt->BitSet.underlying);
+ break;
+ }
- array_add(&m->debug_incomplete_types, idt);
- lb_set_llvm_metadata(m, type, temp_forward_decl);
- return temp_forward_decl;
+ return temp_forward_decl;
+ }
}
}