aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-03-26 17:33:54 +0000
committergingerBill <bill@gingerbill.org>2020-03-26 17:33:54 +0000
commitb21993a1c470a533a83e5b01274d3b026fb34f9b (patch)
treea86e716cb2a519a7bff7a320821fbde7abd8673e /src/llvm_backend.cpp
parentdd69fcba07aaeefad04ca0b44715ec9d570b46d5 (diff)
Allow ability to reference compound literals like C99 for -llvm-api
Diffstat (limited to 'src/llvm_backend.cpp')
-rw-r--r--src/llvm_backend.cpp19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 47c55f769..520eff313 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -8145,7 +8145,20 @@ lbValue lb_build_expr(lbProcedure *p, Ast *expr) {
switch (ue->op.kind) {
case Token_And: {
Ast *ue_expr = unparen_expr(ue->expr);
- if (ue_expr->kind == Ast_TypeAssertion) {
+ if (ue_expr->kind == Ast_CompoundLit) {
+ lbValue v = lb_build_expr(p, ue->expr);
+
+ Type *type = v.type;
+ lbAddr addr = {};
+ if (p->is_startup) {
+ addr = lb_add_global_generated(p->module, type, v);
+ } else {
+ addr = lb_add_local_generated(p, type, false);
+ }
+ lb_addr_store(p, addr, v);
+ return addr.addr;
+
+ } else if (ue_expr->kind == Ast_TypeAssertion) {
gbAllocator a = heap_allocator();
GB_ASSERT(is_type_pointer(tv.type));
@@ -10797,6 +10810,7 @@ void lb_generate_code(lbGenerator *gen) {
Type *proc_type = alloc_type_proc(nullptr, nullptr, 0, nullptr, 0, false, ProcCC_CDecl);
lbProcedure *p = lb_create_dummy_procedure(m, str_lit(LB_STARTUP_TYPE_INFO_PROC_NAME), proc_type);
+ p->is_startup = true;
startup_type_info = p;
lb_begin_procedure_body(p);
@@ -10821,6 +10835,7 @@ void lb_generate_code(lbGenerator *gen) {
Type *proc_type = alloc_type_proc(nullptr, nullptr, 0, nullptr, 0, false, ProcCC_CDecl);
lbProcedure *p = lb_create_dummy_procedure(m, str_lit(LB_STARTUP_CONTEXT_PROC_NAME), proc_type);
+ p->is_startup = true;
startup_context = p;
lb_begin_procedure_body(p);
@@ -10845,6 +10860,7 @@ void lb_generate_code(lbGenerator *gen) {
Type *proc_type = alloc_type_proc(nullptr, nullptr, 0, nullptr, 0, false, ProcCC_CDecl);
lbProcedure *p = lb_create_dummy_procedure(m, str_lit(LB_STARTUP_RUNTIME_PROC_NAME), proc_type);
+ p->is_startup = true;
startup_runtime = p;
lb_begin_procedure_body(p);
@@ -10933,6 +10949,7 @@ void lb_generate_code(lbGenerator *gen) {
Type *proc_type = alloc_type_proc(nullptr, params, 2, results, 1, false, ProcCC_CDecl);
lbProcedure *p = lb_create_dummy_procedure(m, str_lit("main"), proc_type);
+ p->is_startup = true;
lb_begin_procedure_body(p);