From f41edef4c6c750d0d1b4b5c325fdc4e051f04e84 Mon Sep 17 00:00:00 2001 From: yuyi Date: Mon, 6 Jul 2020 18:32:00 +0800 Subject: [PATCH] checker: add `1/0x0 1/0b0..` division by zero check (#5694) --- vlib/v/checker/checker.v | 19 +++++++++++---- .../tests/division_by_zero_int_err.out | 23 ++++++++++++++++++- .../checker/tests/division_by_zero_int_err.vv | 3 +++ 3 files changed, 39 insertions(+), 6 deletions(-) diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index cdb2202a7d..bd2a92b605 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -552,11 +552,20 @@ pub fn (mut c Checker) infix_expr(mut infix_expr ast.InfixExpr) table.Type { } } if infix_expr.op in [.div, .mod] { - if (infix_expr.right is ast.IntegerLiteral && - infix_expr.right.str() == '0') || - (infix_expr.right is ast.FloatLiteral && infix_expr.right.str().f64() == 0.0) { - oper := if infix_expr.op == .div { 'division' } else { 'modulo' } - c.error('$oper by zero', right_pos) + match infix_expr.right as infix_right { + ast.FloatLiteral { + if infix_right.val.f64() == 0.0 { + oper := if infix_expr.op == .div { 'division' } else { 'modulo' } + c.error('$oper by zero', infix_right.pos) + } + } + ast.IntegerLiteral { + if infix_right.val.int() == 0 { + oper := if infix_expr.op == .div { 'division' } else { 'modulo' } + c.error('$oper by zero', infix_right.pos) + } + } + else {} } } return_type = promoted_type diff --git a/vlib/v/checker/tests/division_by_zero_int_err.out b/vlib/v/checker/tests/division_by_zero_int_err.out index 3e00c2c739..abfb9e4392 100644 --- a/vlib/v/checker/tests/division_by_zero_int_err.out +++ b/vlib/v/checker/tests/division_by_zero_int_err.out @@ -2,4 +2,25 @@ vlib/v/checker/tests/division_by_zero_int_err.v:2:12: error: division by zero 1 | fn main() { 2 | println(1/0) | ^ - 3 | } + 3 | println(1/0x0) + 4 | println(1/0b0) +vlib/v/checker/tests/division_by_zero_int_err.v:3:12: error: division by zero + 1 | fn main() { + 2 | println(1/0) + 3 | println(1/0x0) + | ~~~ + 4 | println(1/0b0) + 5 | println(1/0o0) +vlib/v/checker/tests/division_by_zero_int_err.v:4:12: error: division by zero + 2 | println(1/0) + 3 | println(1/0x0) + 4 | println(1/0b0) + | ~~~ + 5 | println(1/0o0) + 6 | } +vlib/v/checker/tests/division_by_zero_int_err.v:5:12: error: division by zero + 3 | println(1/0x0) + 4 | println(1/0b0) + 5 | println(1/0o0) + | ~~~ + 6 | } diff --git a/vlib/v/checker/tests/division_by_zero_int_err.vv b/vlib/v/checker/tests/division_by_zero_int_err.vv index 996814a9a6..4316fda553 100644 --- a/vlib/v/checker/tests/division_by_zero_int_err.vv +++ b/vlib/v/checker/tests/division_by_zero_int_err.vv @@ -1,3 +1,6 @@ fn main() { println(1/0) + println(1/0x0) + println(1/0b0) + println(1/0o0) }