From 9c88317ca68dd018692090e1b52812202e12d540 Mon Sep 17 00:00:00 2001 From: Leo Developer Date: Sun, 28 Nov 2021 17:46:52 +0100 Subject: [PATCH] checker: add a warning if start value is higher than end value (#12602) --- vlib/v/checker/checker.v | 6 ++++++ .../tests/match_expr_range_low_higher_than_high.out | 7 +++++++ .../tests/match_expr_range_low_higher_than_high.vv | 8 ++++++++ 3 files changed, 21 insertions(+) create mode 100644 vlib/v/checker/tests/match_expr_range_low_higher_than_high.out create mode 100644 vlib/v/checker/tests/match_expr_range_low_higher_than_high.vv diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index 40a2903385..839cc72291 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -6365,6 +6365,9 @@ fn (mut c Checker) match_exprs(mut node ast.MatchExpr, cond_type_sym ast.TypeSym && (cond_type_sym.is_int() || cond_type_sym.info is ast.Enum) { low = low_expr.val.i64() high = high_expr.val.i64() + if low > high { + c.error('start value is higher than end value', branch.pos) + } } else { c.error('mismatched range types', low_expr.pos) } @@ -6372,6 +6375,9 @@ fn (mut c Checker) match_exprs(mut node ast.MatchExpr, cond_type_sym ast.TypeSym if high_expr is ast.CharLiteral && cond_type_sym.kind in [.byte, .char, .rune] { low = low_expr.val[0] high = high_expr.val[0] + if low > high { + c.error('start value is higher than end value', branch.pos) + } } else { c.error('mismatched range types', low_expr.pos) } diff --git a/vlib/v/checker/tests/match_expr_range_low_higher_than_high.out b/vlib/v/checker/tests/match_expr_range_low_higher_than_high.out new file mode 100644 index 0000000000..85228d2227 --- /dev/null +++ b/vlib/v/checker/tests/match_expr_range_low_higher_than_high.out @@ -0,0 +1,7 @@ +vlib/v/checker/tests/match_expr_range_low_higher_than_high.vv:5:3: error: start value is higher than end value + 3 | value := 10 + 4 | match value { + 5 | 20...10 {} + | ~~~~~~~ + 6 | else {} + 7 | } diff --git a/vlib/v/checker/tests/match_expr_range_low_higher_than_high.vv b/vlib/v/checker/tests/match_expr_range_low_higher_than_high.vv new file mode 100644 index 0000000000..589e8272c4 --- /dev/null +++ b/vlib/v/checker/tests/match_expr_range_low_higher_than_high.vv @@ -0,0 +1,8 @@ + +fn main() { + value := 10 + match value { + 20...10 {} + else {} + } +}