aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-05-22 23:41:17 +0100
committergingerBill <bill@gingerbill.org>2020-05-22 23:41:17 +0100
commit26fe9b021293f9da8dd9591272e736f5d6b4d261 (patch)
tree219be5482ebfed4b5c515e8608a2684dc955f04f /src/llvm_backend.cpp
parentfd6e2ed5def71732f9305d54eee012506dfdb38c (diff)
Fix SelectorCallExpr with no return values
Diffstat (limited to 'src/llvm_backend.cpp')
-rw-r--r--src/llvm_backend.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index f3ec62c89..9e0ca6bdb 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -9029,7 +9029,7 @@ lbValue lb_build_expr(lbProcedure *p, Ast *expr) {
GB_ASSERT(se->modified_call);
TypeAndValue tav = type_and_value_of_expr(expr);
GB_ASSERT(tav.mode != Addressing_Invalid);
- return lb_addr_load(p, lb_build_addr(p, se->call));
+ return lb_build_expr(p, se->call);
case_end;
case_ast_node(te, TernaryExpr, expr);
@@ -9571,6 +9571,13 @@ lbAddr lb_build_addr(lbProcedure *p, Ast *expr) {
}
case_end;
+ case_ast_node(se, SelectorCallExpr, expr);
+ GB_ASSERT(se->modified_call);
+ TypeAndValue tav = type_and_value_of_expr(expr);
+ GB_ASSERT(tav.mode != Addressing_Invalid);
+ return lb_build_addr(p, se->call);
+ case_end;
+
case_ast_node(ta, TypeAssertion, expr);
gbAllocator a = heap_allocator();
TokenPos pos = ast_token(expr).pos;