aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2021-06-27 12:21:11 +0100
committergingerBill <bill@gingerbill.org>2021-06-27 12:21:11 +0100
commit76d3bab955d33abb6d4cab0b95beedd6393c96da (patch)
tree48bc6efeab326be54a7b4082d9bd3873ab8440d3 /src
parentabda75feeeed1bbda87a7a9e54bc8794eefc54e6 (diff)
Modify scope finding rules for distinct types in lb_debug_type
Diffstat (limited to 'src')
-rw-r--r--src/llvm_backend.cpp26
1 files changed, 23 insertions, 3 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 129263ecd..47ff21ee8 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -2132,6 +2132,28 @@ LLVMMetadataRef lb_debug_type_internal(lbModule *m, Type *type) {
return nullptr;
}
+LLVMMetadataRef lb_get_base_scope_metadata(lbModule *m, Scope *scope) {
+ LLVMMetadataRef found = nullptr;
+ for (;;) {
+ if (scope == nullptr) {
+ return nullptr;
+ }
+ if (scope->flags & ScopeFlag_Proc) {
+ found = lb_get_llvm_metadata(m, scope->procedure_entity);
+ if (found) {
+ return found;
+ }
+ }
+ if (scope->flags & ScopeFlag_File) {
+ found = lb_get_llvm_metadata(m, scope->file);
+ if (found) {
+ return found;
+ }
+ }
+ scope = scope->parent;
+ }
+}
+
LLVMMetadataRef lb_debug_type(lbModule *m, Type *type) {
GB_ASSERT(type != nullptr);
LLVMMetadataRef found = lb_get_llvm_metadata(m, type);
@@ -2147,7 +2169,7 @@ LLVMMetadataRef lb_debug_type(lbModule *m, Type *type) {
if (type->Named.type_name != nullptr) {
Entity *e = type->Named.type_name;
- scope = lb_get_llvm_metadata(m, e->scope);
+ scope = lb_get_base_scope_metadata(m, e->scope);
if (scope != nullptr) {
file = LLVMDIScopeGetFile(scope);
}
@@ -2174,8 +2196,6 @@ LLVMMetadataRef lb_debug_type(lbModule *m, Type *type) {
switch (bt->kind) {
case Type_Enum:
{
- LLVMMetadataRef scope = nullptr;
- LLVMMetadataRef file = nullptr;
unsigned line = 0;
unsigned element_count = cast(unsigned)bt->Enum.fields.count;
LLVMMetadataRef *elements = gb_alloc_array(permanent_allocator(), LLVMMetadataRef, element_count);