checker: simplify argument qualifier errors (#6321)

pull/6337/head
Nick Treleaven 2020-09-08 18:34:17 +01:00 committed by GitHub
parent 90128ed4ee
commit 49c322f120
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 44 additions and 22 deletions

View File

@ -242,7 +242,7 @@ pub struct FnDecl {
pub: pub:
name string name string
mod string mod string
args []table.Arg args []table.Arg // parameters
is_deprecated bool is_deprecated bool
is_pub bool is_pub bool
is_variadic bool is_variadic bool

View File

@ -1331,31 +1331,16 @@ pub fn (mut c Checker) call_fn(mut call_expr ast.CallExpr) table.Type {
if call_arg.is_mut { if call_arg.is_mut {
c.fail_if_immutable(call_arg.expr) c.fail_if_immutable(call_arg.expr)
if !arg.is_mut { if !arg.is_mut {
mut words := 'mutable' tok := call_arg.share.str()
mut tok := 'mut' c.error('`$call_expr.name` parameter `$arg.name` is not `$tok`, `$tok` is not needed`',
if call_arg.share == .shared_t { call_arg.expr.position())
words = 'shared'
tok = 'shared'
} else if call_arg.share == .atomic_t {
words = 'atomic'
tok = 'atomic'
}
c.error('`$arg.name` argument is not $words, `$tok` is not needed`', call_arg.expr.position())
} else if arg.typ.share() != call_arg.share { } else if arg.typ.share() != call_arg.share {
c.error('wrong shared type', call_arg.expr.position()) c.error('wrong shared type', call_arg.expr.position())
} }
} else { } else {
if arg.is_mut && (!call_arg.is_mut || arg.typ.share() != call_arg.share) { if arg.is_mut && (!call_arg.is_mut || arg.typ.share() != call_arg.share) {
mut words := ' mutable' tok := call_arg.share.str()
mut tok := 'mut' c.error('`$call_expr.name` parameter `$arg.name` is `$tok`, you need to provide `$tok` e.g. `$tok arg${i+1}`',
if arg.typ.share() == .shared_t {
words = ' shared'
tok = 'shared'
} else if arg.typ.share() == .atomic_t {
words = 'n atomic'
tok = 'atomic'
}
c.error('`$arg.name` is a$words argument, you need to provide `$tok`: `${call_expr.name}($tok ...)`',
call_arg.expr.position()) call_arg.expr.position())
} }
} }

View File

@ -0,0 +1,25 @@
vlib/v/checker/tests/mut_arg.vv:6:3: error: `f` parameter `par` is `mut`, you need to provide `mut` e.g. `mut arg1`
4 | }
5 |
6 | f([3,4])
| ~~~~~
7 | mut a := [1,2]
8 | f(a)
vlib/v/checker/tests/mut_arg.vv:8:3: error: `f` parameter `par` is `mut`, you need to provide `mut` e.g. `mut arg1`
6 | f([3,4])
7 | mut a := [1,2]
8 | f(a)
| ^
9 |
10 | g(mut [3,4])
vlib/v/checker/tests/mut_arg.vv:10:7: error: `g` parameter `par` is not `mut`, `mut` is not needed`
8 | f(a)
9 |
10 | g(mut [3,4])
| ~~~~~
11 | g(mut a)
vlib/v/checker/tests/mut_arg.vv:11:7: error: `g` parameter `par` is not `mut`, `mut` is not needed`
9 |
10 | g(mut [3,4])
11 | g(mut a)
| ^

View File

@ -0,0 +1,11 @@
fn f(mut par []int) {
}
fn g(par []int) {
}
f([3,4])
mut a := [1,2]
f(a)
g(mut [3,4])
g(mut a)

View File

@ -22,7 +22,7 @@ pub mut:
pub struct Fn { pub struct Fn {
pub: pub:
args []Arg args []Arg // parameters
return_type Type return_type Type
return_type_source_name string return_type_source_name string
is_variadic bool is_variadic bool
@ -39,6 +39,7 @@ pub mut:
name string name string
} }
// parameter
pub struct Arg { pub struct Arg {
pub: pub:
pos token.Position pos token.Position