aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_expr.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2021-09-12 16:47:17 +0100
committergingerBill <bill@gingerbill.org>2021-09-12 16:47:17 +0100
commit3195fac92bab087e4b741e08204c00b49caa065b (patch)
tree770639e3ddc243e8c911447f34d5826a2ce2ae19 /src/llvm_backend_expr.cpp
parenta5b4b735449413ae58e2213a75dd4356afb0e33d (diff)
Fix slice indices endianness
Diffstat (limited to 'src/llvm_backend_expr.cpp')
-rw-r--r--src/llvm_backend_expr.cpp9
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;