cgen: fix swap assign of prefix and postfix expr

pull/5086/head
yuyi 2020-05-28 07:22:09 +08:00 committed by GitHub
parent cecb7d29c7
commit 9cbd9db4e7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 48 additions and 17 deletions

View File

@ -1078,6 +1078,14 @@ fn (mut g Gen) gen_cross_tmp_variable(idents []ast.Ident, val ast.Expr) {
g.write(it.op.str()) g.write(it.op.str())
g.gen_cross_tmp_variable(idents, it.right) g.gen_cross_tmp_variable(idents, it.right)
} }
ast.PrefixExpr {
g.write(it.op.str())
g.gen_cross_tmp_variable(idents, it.right)
}
ast.PostfixExpr {
g.gen_cross_tmp_variable(idents, it.expr)
g.write(it.op.str())
}
else { else {
g.expr(val) g.expr(val)
} }
@ -2200,7 +2208,7 @@ fn (g Gen) expr_is_multi_return_call(expr ast.Expr) bool {
else { else {
return false return false
} }
} }
} }
@ -2245,7 +2253,7 @@ fn (mut g Gen) return_statement(node ast.Return) {
g.write('($styp){') g.write('($styp){')
mut arg_idx := 0 mut arg_idx := 0
for i, expr in node.exprs { for i, expr in node.exprs {
// Check if we are dealing with a multi return and handle it seperately // Check if we are dealing with a multi return and handle it seperately

View File

@ -35,25 +35,18 @@ fn (mut p Parser) check_cross_variables(idents []ast.Ident, expr ast.Expr) bool
match expr { match expr {
ast.Ident { ast.Ident {
for ident in idents { for ident in idents {
if ident.name == it.name { if ident.name == it.name { return true }
return true
}
} }
} }
ast.InfixExpr { ast.InfixExpr {
if p.check_cross_variables(idents, it.left) { if p.check_cross_variables(idents, it.left) { return true }
return true if p.check_cross_variables(idents, it.right) { return true }
}
if p.check_cross_variables(idents, it.right) {
return true
}
} }
ast.StringInterLiteral { ast.PrefixExpr {
for expr_ in it.exprs { if p.check_cross_variables(idents, it.right) { return true }
if p.check_cross_variables(idents, expr_) { }
return true ast.PostfixExpr {
} if p.check_cross_variables(idents, it.expr) { return true }
}
} }
else {} else {}
} }

View File

@ -34,3 +34,33 @@ fn test_multiple_assign_infix_expr() {
assert b == 22 assert b == 22
assert c == 22 assert c == 22
} }
fn test_multiple_assign_prefix_expr() {
mut a := 11
mut b := 22
mut c := 33
a, b, c = -b, -c, -a
assert a == -22
assert b == -33
assert c == -11
}
fn test_multiple_assign_postfix_expr() {
mut a := 11
mut b := 22
mut c := 33
a, b, c = b++, c++, a--
assert a == 22
assert b == 33
assert c == 11
}
fn test_multiple_assign_complex_expr() {
mut a := 11
mut b := 22
mut c := 33
a, b, c = -b + 1, -c * 2, a++
assert a == -21
assert b == -66
assert c == 11
}