aboutsummaryrefslogtreecommitdiff
path: root/src/check_expr.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2019-10-20 18:26:30 +0100
committergingerBill <bill@gingerbill.org>2019-10-20 18:26:30 +0100
commite15dfa8eb6c64b9c39fbd8ea0712e31082137d63 (patch)
treef4d67e52bcccdd9ba6234fd266659dda65f9a747 /src/check_expr.cpp
parentf12ded54f2b1a390f556e67a17ff0bf4c301a8e3 (diff)
Fix missing check for zero elements
Diffstat (limited to 'src/check_expr.cpp')
-rw-r--r--src/check_expr.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index 60c057ae9..195443159 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -7076,7 +7076,7 @@ ExprKind check_expr_base_internal(CheckerContext *c, Operand *o, Ast *node, Type
break;
}
- if (cl->elems[0]->kind == Ast_FieldValue) {
+ if (cl->elems.count > 0 && cl->elems[0]->kind == Ast_FieldValue) {
if (is_type_simd_vector(t)) {
error(cl->elems[0], "'field = value' is not allowed for SIMD vector literals");
} else {
@@ -7162,7 +7162,7 @@ ExprKind check_expr_base_internal(CheckerContext *c, Operand *o, Ast *node, Type
if (t->kind == Type_Array) {
if (is_to_be_determined_array_count) {
t->Array.count = max;
- } else if (cl->elems[0]->kind != Ast_FieldValue) {
+ } else if (cl->elems.count > 0 && cl->elems[0]->kind != Ast_FieldValue) {
if (0 < max && max < t->Array.count) {
error(node, "Expected %lld values for this array literal, got %lld", cast(long long)t->Array.count, cast(long long)max);
}