aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2021-04-27 13:09:37 +0100
committergingerBill <bill@gingerbill.org>2021-04-27 13:09:37 +0100
commite7e1866e5047a85648e758a2d94c8247c65a6608 (patch)
tree5b837f4cda820adf20f79a78bf86f3c7bd3070a5 /src/llvm_backend.cpp
parent94fd59e6f0e509f823edd3c90130841510cceb70 (diff)
Fix #893
Diffstat (limited to 'src/llvm_backend.cpp')
-rw-r--r--src/llvm_backend.cpp38
1 files changed, 23 insertions, 15 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 758f8e5d1..52c69c7c7 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -3544,16 +3544,14 @@ void lb_build_constant_value_decl(lbProcedure *p, AstValueDecl *vd) {
Ast *ident = vd->names[i];
GB_ASSERT(ident->kind == Ast_Ident);
Entity *e = entity_of_node(ident);
- if (e == nullptr) {
- continue;
- }
+ GB_ASSERT(e != nullptr);
if (e->kind != Entity_TypeName) {
continue;
}
bool polymorphic_struct = false;
if (e->type != nullptr && e->kind == Entity_TypeName) {
- Type *bt = base_type(e->type);
+ Type *bt = base_type(e->type);
if (bt->kind == Type_Struct) {
polymorphic_struct = bt->Struct.is_polymorphic;
}
@@ -3575,12 +3573,16 @@ void lb_build_constant_value_decl(lbProcedure *p, AstValueDecl *vd) {
Ast *ident = vd->names[i];
GB_ASSERT(ident->kind == Ast_Ident);
Entity *e = entity_of_node(ident);
- if (e == nullptr) {
- continue;
- }
+ GB_ASSERT(e != nullptr);
if (e->kind != Entity_Procedure) {
continue;
}
+ GB_ASSERT (vd->values[i] != nullptr);
+
+ Ast *value = unparen_expr(vd->values[i]);
+ if (value->kind != Ast_ProcLit) {
+ continue; // It's an alias
+ }
CheckerInfo *info = p->module->info;
DeclInfo *decl = decl_info_of_entity(e);
@@ -11436,7 +11438,13 @@ lbValue lb_get_using_variable(lbProcedure *p, Entity *e) {
GB_ASSERT(v.value != nullptr);
GB_ASSERT_MSG(parent->type == type_deref(v.type), "%s %s", type_to_string(parent->type), type_to_string(v.type));
lbValue ptr = lb_emit_deep_field_gep(p, v, sel);
- lb_add_debug_local_variable(p, ptr.value, e->type, e->token);
+ if (parent->scope) {
+ if ((parent->scope->flags & (ScopeFlag_File|ScopeFlag_Pkg)) == 0) {
+ lb_add_debug_local_variable(p, ptr.value, e->type, e->token);
+ }
+ } else {
+ lb_add_debug_local_variable(p, ptr.value, e->type, e->token);
+ }
return ptr;
}
@@ -13778,13 +13786,13 @@ void lb_generate_code(lbGenerator *gen) {
}
gbString producer = gb_string_make(heap_allocator(), "odin");
- producer = gb_string_append_fmt(producer, " version %.*s", LIT(ODIN_VERSION));
- #ifdef NIGHTLY
- producer = gb_string_appendc(producer, "-nightly");
- #endif
- #ifdef GIT_SHA
- producer = gb_string_append_fmt(producer, "-%s", GIT_SHA);
- #endif
+ // producer = gb_string_append_fmt(producer, " version %.*s", LIT(ODIN_VERSION));
+ // #ifdef NIGHTLY
+ // producer = gb_string_appendc(producer, "-nightly");
+ // #endif
+ // #ifdef GIT_SHA
+ // producer = gb_string_append_fmt(producer, "-%s", GIT_SHA);
+ // #endif
gbString split_name = gb_string_make(heap_allocator(), "");