From 56383e45a7441fc789cd44c5e0dbaf9b2079a0f1 Mon Sep 17 00:00:00 2001 From: gingerBill Date: Thu, 20 Jun 2024 11:44:00 +0100 Subject: [PATCH] Fix #3768 --- src/check_expr.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/check_expr.cpp b/src/check_expr.cpp index e548eac88..a605957bb 100644 --- a/src/check_expr.cpp +++ b/src/check_expr.cpp @@ -2606,6 +2606,11 @@ gb_internal void check_unary_expr(CheckerContext *c, Operand *o, Token op, Ast * if (o->mode == Addressing_Constant) { Type *type = base_type(o->type); if (!is_type_constant_type(o->type)) { + if (is_type_array_like(o->type)) { + o->mode = Addressing_Value; + return; + } + gbString xt = type_to_string(o->type); gbString err_str = expr_to_string(node); error(op, "Invalid type, '%s', for constant unary expression '%s'", xt, err_str);