From 46b3e7b6fa9477b7feb4389a353f92c7cc4c3d20 Mon Sep 17 00:00:00 2001 From: gingerBill Date: Mon, 20 May 2024 13:36:32 +0100 Subject: Fix `for &v in &fixed_array` --- src/check_stmt.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'src/check_stmt.cpp') diff --git a/src/check_stmt.cpp b/src/check_stmt.cpp index 23a97696d..2083dbf11 100644 --- a/src/check_stmt.cpp +++ b/src/check_stmt.cpp @@ -1663,6 +1663,7 @@ gb_internal void check_range_stmt(CheckerContext *ctx, Ast *node, u32 mod_flags) } } } + bool is_ptr = type_deref(operand.type); Type *t = base_type(type_deref(operand.type)); switch (t->kind) { @@ -1707,7 +1708,7 @@ gb_internal void check_range_stmt(CheckerContext *ctx, Ast *node, u32 mod_flags) break; case Type_Array: - is_possibly_addressable = operand.mode == Addressing_Variable; + is_possibly_addressable = operand.mode == Addressing_Variable || is_ptr; array_add(&vals, t->Array.elem); array_add(&vals, t_int); break; -- cgit v1.2.3