From 17c34b09a65f8159f936498640e2324a97165d9d Mon Sep 17 00:00:00 2001 From: yuyi Date: Sun, 17 Apr 2022 19:08:43 +0800 Subject: [PATCH] checker, cgen: minor cleanup of last expr stmt expression (#14057) --- vlib/v/checker/checker.v | 12 ++++-------- vlib/v/checker/if.v | 4 ++-- vlib/v/checker/match.v | 4 ++-- vlib/v/gen/c/comptime.v | 4 ++-- vlib/v/gen/c/if.v | 2 +- vlib/v/gen/js/comptime.v | 4 ++-- 6 files changed, 13 insertions(+), 17 deletions(-) diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index 8d3fcc3e50..3535646ea8 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -1533,14 +1533,12 @@ fn (mut c Checker) check_or_last_stmt(stmt ast.Stmt, ret_type ast.Type, expr_ret if stmt.typ == ast.void_type { if stmt.expr is ast.IfExpr { for branch in stmt.expr.branches { - last_stmt := branch.stmts[branch.stmts.len - 1] - c.check_or_last_stmt(last_stmt, ret_type, expr_return_type) + c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type) } return } else if stmt.expr is ast.MatchExpr { for branch in stmt.expr.branches { - last_stmt := branch.stmts[branch.stmts.len - 1] - c.check_or_last_stmt(last_stmt, ret_type, expr_return_type) + c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type) } return } @@ -1570,14 +1568,12 @@ fn (mut c Checker) check_or_last_stmt(stmt ast.Stmt, ret_type ast.Type, expr_ret match stmt.expr { ast.IfExpr { for branch in stmt.expr.branches { - last_stmt := branch.stmts[branch.stmts.len - 1] - c.check_or_last_stmt(last_stmt, ret_type, expr_return_type) + c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type) } } ast.MatchExpr { for branch in stmt.expr.branches { - last_stmt := branch.stmts[branch.stmts.len - 1] - c.check_or_last_stmt(last_stmt, ret_type, expr_return_type) + c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type) } } else { diff --git a/vlib/v/checker/if.v b/vlib/v/checker/if.v index 142d27ca62..abf5616e5d 100644 --- a/vlib/v/checker/if.v +++ b/vlib/v/checker/if.v @@ -156,8 +156,8 @@ pub fn (mut c Checker) if_expr(mut node ast.IfExpr) ast.Type { c.smartcast_cond_pos = token.Pos{} } if expr_required { - if branch.stmts.len > 0 && branch.stmts[branch.stmts.len - 1] is ast.ExprStmt { - mut last_expr := branch.stmts[branch.stmts.len - 1] as ast.ExprStmt + if branch.stmts.len > 0 && branch.stmts.last() is ast.ExprStmt { + mut last_expr := branch.stmts.last() as ast.ExprStmt c.expected_type = former_expected_type if c.expected_type.has_flag(.optional) { if node.typ == ast.void_type { diff --git a/vlib/v/checker/match.v b/vlib/v/checker/match.v index ae03dea745..5b56ef86d4 100644 --- a/vlib/v/checker/match.v +++ b/vlib/v/checker/match.v @@ -51,7 +51,7 @@ pub fn (mut c Checker) match_expr(mut node ast.MatchExpr) ast.Type { // currently the last statement in a match branch does not have an // expected value set, so e.g. IfExpr.is_expr is not set. // probably any mismatch will be caught by not producing a value instead - for st in branch.stmts[0..branch.stmts.len - 1] { + for st in branch.stmts[..branch.stmts.len - 1] { // must not contain C statements st.check_c_expr() or { c.error('`match` expression branch has $err.msg()', st.pos) @@ -64,7 +64,7 @@ pub fn (mut c Checker) match_expr(mut node ast.MatchExpr) ast.Type { } // If the last statement is an expression, return its type if branch.stmts.len > 0 { - mut stmt := branch.stmts[branch.stmts.len - 1] + mut stmt := branch.stmts.last() if mut stmt is ast.ExprStmt { if node.is_expr { c.expected_type = node.expected_type diff --git a/vlib/v/gen/c/comptime.v b/vlib/v/gen/c/comptime.v index ba14095c68..8195694afd 100644 --- a/vlib/v/gen/c/comptime.v +++ b/vlib/v/gen/c/comptime.v @@ -263,14 +263,14 @@ fn (mut g Gen) comptime_if(node ast.IfExpr) { if node.is_expr { len := branch.stmts.len if len > 0 { - last := branch.stmts[len - 1] as ast.ExprStmt + last := branch.stmts.last() as ast.ExprStmt if len > 1 { tmp := g.new_tmp_var() styp := g.typ(last.typ) g.indent++ g.writeln('$styp $tmp;') g.writeln('{') - g.stmts(branch.stmts[0..len - 1]) + g.stmts(branch.stmts[..len - 1]) g.write('\t$tmp = ') g.stmt(last) g.writeln('}') diff --git a/vlib/v/gen/c/if.v b/vlib/v/gen/c/if.v index 3b730b8a8c..74fec1f85e 100644 --- a/vlib/v/gen/c/if.v +++ b/vlib/v/gen/c/if.v @@ -148,7 +148,7 @@ fn (mut g Gen) if_expr(node ast.IfExpr) { } else { mut is_auto_heap := false if branch.stmts.len > 0 { - scope := g.file.scope.innermost(ast.Node(branch.stmts[branch.stmts.len - 1]).pos().pos) + scope := g.file.scope.innermost(ast.Node(branch.stmts.last()).pos().pos) if v := scope.find_var(branch.cond.vars[0].name) { is_auto_heap = v.is_auto_heap } diff --git a/vlib/v/gen/js/comptime.v b/vlib/v/gen/js/comptime.v index 378f1e044d..2bbcf0a568 100644 --- a/vlib/v/gen/js/comptime.v +++ b/vlib/v/gen/js/comptime.v @@ -28,13 +28,13 @@ fn (mut g JsGen) comptime_if(node ast.IfExpr) { print('$branch.stmts') len := branch.stmts.len if len > 0 { - last := branch.stmts[len - 1] as ast.ExprStmt + last := branch.stmts.last() as ast.ExprStmt if len > 1 { tmp := g.new_tmp_var() g.inc_indent() g.writeln('let $tmp;') g.writeln('{') - g.stmts(branch.stmts[0..len - 1]) + g.stmts(branch.stmts[..len - 1]) g.write('\t$tmp = ') g.stmt(last) g.writeln('}')