checker, cgen: minor cleanup of last expr stmt expression (#14057)

master
yuyi 2022-04-17 19:08:43 +08:00 committed by GitHub
parent cb44f5981e
commit 17c34b09a6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 13 additions and 17 deletions

View File

@ -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.typ == ast.void_type {
if stmt.expr is ast.IfExpr { if stmt.expr is ast.IfExpr {
for branch in stmt.expr.branches { for branch in stmt.expr.branches {
last_stmt := branch.stmts[branch.stmts.len - 1] c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type)
c.check_or_last_stmt(last_stmt, ret_type, expr_return_type)
} }
return return
} else if stmt.expr is ast.MatchExpr { } else if stmt.expr is ast.MatchExpr {
for branch in stmt.expr.branches { for branch in stmt.expr.branches {
last_stmt := branch.stmts[branch.stmts.len - 1] c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type)
c.check_or_last_stmt(last_stmt, ret_type, expr_return_type)
} }
return 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 { match stmt.expr {
ast.IfExpr { ast.IfExpr {
for branch in stmt.expr.branches { for branch in stmt.expr.branches {
last_stmt := branch.stmts[branch.stmts.len - 1] c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type)
c.check_or_last_stmt(last_stmt, ret_type, expr_return_type)
} }
} }
ast.MatchExpr { ast.MatchExpr {
for branch in stmt.expr.branches { for branch in stmt.expr.branches {
last_stmt := branch.stmts[branch.stmts.len - 1] c.check_or_last_stmt(branch.stmts.last(), ret_type, expr_return_type)
c.check_or_last_stmt(last_stmt, ret_type, expr_return_type)
} }
} }
else { else {

View File

@ -156,8 +156,8 @@ pub fn (mut c Checker) if_expr(mut node ast.IfExpr) ast.Type {
c.smartcast_cond_pos = token.Pos{} c.smartcast_cond_pos = token.Pos{}
} }
if expr_required { if expr_required {
if branch.stmts.len > 0 && branch.stmts[branch.stmts.len - 1] is ast.ExprStmt { if branch.stmts.len > 0 && branch.stmts.last() is ast.ExprStmt {
mut last_expr := branch.stmts[branch.stmts.len - 1] as ast.ExprStmt mut last_expr := branch.stmts.last() as ast.ExprStmt
c.expected_type = former_expected_type c.expected_type = former_expected_type
if c.expected_type.has_flag(.optional) { if c.expected_type.has_flag(.optional) {
if node.typ == ast.void_type { if node.typ == ast.void_type {

View File

@ -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 // currently the last statement in a match branch does not have an
// expected value set, so e.g. IfExpr.is_expr is not set. // expected value set, so e.g. IfExpr.is_expr is not set.
// probably any mismatch will be caught by not producing a value instead // 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 // must not contain C statements
st.check_c_expr() or { st.check_c_expr() or {
c.error('`match` expression branch has $err.msg()', st.pos) 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 the last statement is an expression, return its type
if branch.stmts.len > 0 { 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 mut stmt is ast.ExprStmt {
if node.is_expr { if node.is_expr {
c.expected_type = node.expected_type c.expected_type = node.expected_type

View File

@ -263,14 +263,14 @@ fn (mut g Gen) comptime_if(node ast.IfExpr) {
if node.is_expr { if node.is_expr {
len := branch.stmts.len len := branch.stmts.len
if len > 0 { if len > 0 {
last := branch.stmts[len - 1] as ast.ExprStmt last := branch.stmts.last() as ast.ExprStmt
if len > 1 { if len > 1 {
tmp := g.new_tmp_var() tmp := g.new_tmp_var()
styp := g.typ(last.typ) styp := g.typ(last.typ)
g.indent++ g.indent++
g.writeln('$styp $tmp;') g.writeln('$styp $tmp;')
g.writeln('{') g.writeln('{')
g.stmts(branch.stmts[0..len - 1]) g.stmts(branch.stmts[..len - 1])
g.write('\t$tmp = ') g.write('\t$tmp = ')
g.stmt(last) g.stmt(last)
g.writeln('}') g.writeln('}')

View File

@ -148,7 +148,7 @@ fn (mut g Gen) if_expr(node ast.IfExpr) {
} else { } else {
mut is_auto_heap := false mut is_auto_heap := false
if branch.stmts.len > 0 { 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) { if v := scope.find_var(branch.cond.vars[0].name) {
is_auto_heap = v.is_auto_heap is_auto_heap = v.is_auto_heap
} }

View File

@ -28,13 +28,13 @@ fn (mut g JsGen) comptime_if(node ast.IfExpr) {
print('$branch.stmts') print('$branch.stmts')
len := branch.stmts.len len := branch.stmts.len
if len > 0 { if len > 0 {
last := branch.stmts[len - 1] as ast.ExprStmt last := branch.stmts.last() as ast.ExprStmt
if len > 1 { if len > 1 {
tmp := g.new_tmp_var() tmp := g.new_tmp_var()
g.inc_indent() g.inc_indent()
g.writeln('let $tmp;') g.writeln('let $tmp;')
g.writeln('{') g.writeln('{')
g.stmts(branch.stmts[0..len - 1]) g.stmts(branch.stmts[..len - 1])
g.write('\t$tmp = ') g.write('\t$tmp = ')
g.stmt(last) g.stmt(last)
g.writeln('}') g.writeln('}')