diff options
| author | gingerBill <bill@gingerbill.org> | 2021-09-12 16:47:17 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2021-09-12 16:47:17 +0100 |
| commit | 3195fac92bab087e4b741e08204c00b49caa065b (patch) | |
| tree | 770639e3ddc243e8c911447f34d5826a2ce2ae19 /src/llvm_backend_expr.cpp | |
| parent | a5b4b735449413ae58e2213a75dd4356afb0e33d (diff) | |
Fix slice indices endianness
Diffstat (limited to 'src/llvm_backend_expr.cpp')
| -rw-r--r-- | src/llvm_backend_expr.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp index 8189aec68..a4b4564c0 100644 --- a/src/llvm_backend_expr.cpp +++ b/src/llvm_backend_expr.cpp @@ -888,7 +888,6 @@ lbValue lb_build_binary_expr(lbProcedure *p, Ast *expr) { return {}; } - lbValue lb_emit_conv(lbProcedure *p, lbValue value, Type *t) { lbModule *m = p->module; t = reduce_tuple_to_single_type(t); @@ -2981,8 +2980,12 @@ lbAddr lb_build_addr(lbProcedure *p, Ast *expr) { lbValue low = lb_const_int(p->module, t_int, 0); lbValue high = {}; - if (se->low != nullptr) low = lb_build_expr(p, se->low); - if (se->high != nullptr) high = lb_build_expr(p, se->high); + if (se->low != nullptr) { + low = lb_correct_endianness(p, lb_build_expr(p, se->low)); + } + if (se->high != nullptr) { + high = lb_correct_endianness(p, lb_build_expr(p, se->high)); + } bool no_indices = se->low == nullptr && se->high == nullptr; |