From cab054c1ba6a8a6ab77d33a2c2ac3096a1e356bd Mon Sep 17 00:00:00 2001 From: yuyi Date: Sun, 13 Jun 2021 11:29:40 +0800 Subject: [PATCH] checker: simplify checking array append type mismatch (#10422) --- vlib/v/checker/check_types.v | 7 ------- vlib/v/checker/checker.v | 11 +++-------- 2 files changed, 3 insertions(+), 15 deletions(-) diff --git a/vlib/v/checker/check_types.v b/vlib/v/checker/check_types.v index 524cc1f375..1c8874f486 100644 --- a/vlib/v/checker/check_types.v +++ b/vlib/v/checker/check_types.v @@ -331,13 +331,6 @@ pub fn (mut c Checker) check_types(got ast.Type, expected ast.Type) bool { return true } -fn (mut c Checker) check_array_value_types(got ast.Type, expected ast.Type) bool { - if expected.is_number() && got.is_number() && expected != c.table.mktyp(got) { - return false - } - return c.check_types(got, expected) -} - pub fn (mut c Checker) check_expected(got ast.Type, expected ast.Type) ? { if c.check_types(got, expected) { return diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index db52b7d05c..7753c2452c 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -1235,14 +1235,9 @@ pub fn (mut c Checker) infix_expr(mut node ast.InfixExpr) ast.Type { } return ast.void_type } - // the expressions have different types (array_x and x) - if c.check_types(right_type, left_value_type) { // , right_type) { - // []T << T - return ast.void_type - } - if right_final.kind == .array - && c.check_array_value_types(left_value_type, c.table.value_type(right_type)) { - // []T << []T + // []T << T or []T << []T + if c.check_types(right_type, left_value_type) + || c.check_types(right_type, left_type) { return ast.void_type } c.error('cannot append `$right_sym.name` to `$left_sym.name`', right_pos)