diff options
| author | gingerBill <bill@gingerbill.org> | 2021-04-03 18:03:36 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2021-04-03 18:03:36 +0100 |
| commit | 46bf39cae10ce7f9de6dad413da1a1f95644e947 (patch) | |
| tree | 30337fa82961d36bf1da4175d3898cb0ae6e5cb0 /src/llvm_backend.cpp | |
| parent | 46c5c7d1ec4ea49507d0ef81633f8600b8bb5e8b (diff) | |
Fix lb_emit_array_ep
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 836e9450a..bb59e2f47 100644 --- a/src/llvm_backend.cpp +++ b/src/llvm_backend.cpp @@ -8259,7 +8259,14 @@ lbValue lb_emit_array_ep(lbProcedure *p, lbValue s, lbValue index) { GB_ASSERT(is_type_pointer(t)); Type *st = base_type(type_deref(t)); GB_ASSERT_MSG(is_type_array(st) || is_type_enumerated_array(st), "%s", type_to_string(st)); - GB_ASSERT_MSG(is_type_integer(index.type), "%s", type_to_string(index.type)); + GB_ASSERT_MSG(is_type_integer(core_type(index.type)), "%s", type_to_string(index.type)); + + if (st->kind == Type_EnumeratedArray && + is_type_enum(st->EnumeratedArray.index) && + are_types_identical(st->EnumeratedArray.index, index.type)) { + lbValue min_value = lb_const_value(p->module, index.type, st->EnumeratedArray.min_value, false); + index = lb_emit_arith(p, Token_Sub, index, min_value, index.type); + } LLVMValueRef indices[2] = {}; indices[0] = llvm_zero(p->module); |