aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2017-11-21 22:32:41 +0000
committergingerBill <bill@gingerbill.org>2017-11-21 22:32:41 +0000
commit976415ff9df68ef8b6ecd06d271bef14d63ea90c (patch)
tree4a5c134f79e0b91f16e7da4f1ff458a0a3379c88 /src
parentbcca3bf3221e1b83f804029e53855cbfc2450baf (diff)
Fix key lookup of pointer to map
Diffstat (limited to 'src')
-rw-r--r--src/check_stmt.cpp2
-rw-r--r--src/ir.cpp4
2 files changed, 5 insertions, 1 deletions
diff --git a/src/check_stmt.cpp b/src/check_stmt.cpp
index 13c3f2624..a04679b3a 100644
--- a/src/check_stmt.cpp
+++ b/src/check_stmt.cpp
@@ -1281,7 +1281,7 @@ void check_stmt_internal(Checker *c, AstNode *node, u32 flags) {
if (!is_type_ordered(x.type)) {
gbString str = type_to_string(x.type);
- error(x.expr, "Unordered type '%s', is invalid for an interval expression", str);
+ error(expr, "Unordered type '%s', is invalid for an interval expression", str);
gb_string_free(str);
continue;
}
diff --git a/src/ir.cpp b/src/ir.cpp
index aa4bd86b0..bf7c8c260 100644
--- a/src/ir.cpp
+++ b/src/ir.cpp
@@ -5531,6 +5531,10 @@ irAddr ir_build_addr(irProcedure *proc, AstNode *expr) {
if (is_type_map(t)) {
irValue *map_val = ir_build_addr_ptr(proc, ie->expr);
+ if (deref) {
+ map_val = ir_emit_load(proc, map_val);
+ }
+
irValue *key = ir_build_expr(proc, ie->index);
key = ir_emit_conv(proc, key, t->Map.key);