checker: forbid non-reference mut arg or receiver of go function
parent
993cd1467b
commit
8fe70a24a8
|
@ -1826,6 +1826,19 @@ fn (mut c Checker) stmt(node ast.Stmt) {
|
||||||
c.error('expression in `go` must be a function call', it.call_expr.position())
|
c.error('expression in `go` must be a function call', it.call_expr.position())
|
||||||
}
|
}
|
||||||
c.expr(it.call_expr)
|
c.expr(it.call_expr)
|
||||||
|
if it.call_expr is ast.CallExpr {
|
||||||
|
call_expr := it.call_expr as ast.CallExpr
|
||||||
|
|
||||||
|
// Make sure there are no mutable arguments
|
||||||
|
for arg in call_expr.args {
|
||||||
|
if arg.is_mut && !arg.typ.is_ptr() {
|
||||||
|
c.error('function in `go` statement cannot contain mutable non-reference arguments', arg.expr.position())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if call_expr.is_method && call_expr.receiver_type.is_ptr() && !call_expr.left_type.is_ptr() {
|
||||||
|
c.error('method in `go` statement cannot have non-reference mutable receiver', call_expr.left.position())
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// ast.HashStmt {}
|
// ast.HashStmt {}
|
||||||
ast.Import {}
|
ast.Import {}
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
vlib/v/checker/tests/go_mut_arg.v:14:16: error: function in `go` statement cannot contain mutable non-reference arguments
|
||||||
|
12 | a: 0
|
||||||
|
13 | }
|
||||||
|
14 | go change(mut x)
|
||||||
|
| ^
|
||||||
|
15 | }
|
|
@ -0,0 +1,15 @@
|
||||||
|
struct St {
|
||||||
|
mut:
|
||||||
|
a int
|
||||||
|
}
|
||||||
|
|
||||||
|
fn change(mut a St) {
|
||||||
|
a.a++
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
mut x := St{
|
||||||
|
a: 0
|
||||||
|
}
|
||||||
|
go change(mut x)
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
vlib/v/checker/tests/go_mut_receiver.v:14:5: error: method in `go` statement cannot have non-reference mutable receiver
|
||||||
|
12 | a: 0
|
||||||
|
13 | }
|
||||||
|
14 | go x.change()
|
||||||
|
| ^
|
||||||
|
15 | }
|
|
@ -0,0 +1,15 @@
|
||||||
|
struct St {
|
||||||
|
mut:
|
||||||
|
a int
|
||||||
|
}
|
||||||
|
|
||||||
|
fn (mut a St) change() {
|
||||||
|
a.a++
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
mut x := St{
|
||||||
|
a: 0
|
||||||
|
}
|
||||||
|
go x.change()
|
||||||
|
}
|
Loading…
Reference in New Issue