diff options
| author | gingerBill <bill@gingerbill.org> | 2020-05-22 23:41:17 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2020-05-22 23:41:17 +0100 |
| commit | 26fe9b021293f9da8dd9591272e736f5d6b4d261 (patch) | |
| tree | 219be5482ebfed4b5c515e8608a2684dc955f04f /src/llvm_backend.cpp | |
| parent | fd6e2ed5def71732f9305d54eee012506dfdb38c (diff) | |
Fix SelectorCallExpr with no return values
Diffstat (limited to 'src/llvm_backend.cpp')
| -rw-r--r-- | src/llvm_backend.cpp | 9 |
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; |