checker: check invalid fn parameter name (#12540)

pull/12550/head
yuyi 2021-11-22 22:51:58 +08:00 committed by GitHub
parent 6914763493
commit f37eb6a932
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 46 additions and 10 deletions

View File

@ -31,8 +31,8 @@ const (
valid_comptime_not_user_defined = all_valid_comptime_idents() valid_comptime_not_user_defined = all_valid_comptime_idents()
array_builtin_methods = ['filter', 'clone', 'repeat', 'reverse', 'map', 'slice', array_builtin_methods = ['filter', 'clone', 'repeat', 'reverse', 'map', 'slice',
'sort', 'contains', 'index', 'wait', 'any', 'all', 'first', 'last', 'pop'] 'sort', 'contains', 'index', 'wait', 'any', 'all', 'first', 'last', 'pop']
reserved_type_names = ['bool', 'i8', 'i16', 'int', 'i64', 'byte', 'u16', 'u32', reserved_type_names = ['bool', 'char', 'i8', 'i16', 'int', 'i64', 'byte', 'u16',
'u64', 'f32', 'f64', 'map', 'string', 'rune'] 'u32', 'u64', 'f32', 'f64', 'map', 'string', 'rune']
vroot_is_deprecated_message = '@VROOT is deprecated, use @VMODROOT or @VEXEROOT instead' vroot_is_deprecated_message = '@VROOT is deprecated, use @VMODROOT or @VEXEROOT instead'
) )
@ -566,6 +566,10 @@ pub fn (mut c Checker) interface_decl(mut node ast.InterfaceDecl) {
continue // no need to check first param continue // no need to check first param
} }
c.ensure_type_exists(param.typ, param.pos) or { return } c.ensure_type_exists(param.typ, param.pos) or { return }
if param.name in checker.reserved_type_names {
c.error('invalid use of reserved type `$param.name` as a parameter name',
param.pos)
}
if is_js { if is_js {
ptyp := c.table.get_type_symbol(param.typ) ptyp := c.table.get_type_symbol(param.typ)
if !ptyp.is_js_compatible() && !(j == method.params.len - 1 if !ptyp.is_js_compatible() && !(j == method.params.len - 1
@ -8242,6 +8246,10 @@ fn (mut c Checker) fn_decl(mut node ast.FnDecl) {
// Make sure all types are valid // Make sure all types are valid
for mut param in node.params { for mut param in node.params {
c.ensure_type_exists(param.typ, param.type_pos) or { return } c.ensure_type_exists(param.typ, param.type_pos) or { return }
if param.name in checker.reserved_type_names {
c.error('invalid use of reserved type `$param.name` as a parameter name',
param.pos)
}
if !param.typ.is_ptr() { // value parameter, i.e. on stack - check for `[heap]` if !param.typ.is_ptr() { // value parameter, i.e. on stack - check for `[heap]`
arg_typ_sym := c.table.get_type_symbol(param.typ) arg_typ_sym := c.table.get_type_symbol(param.typ)
if arg_typ_sym.kind == .struct_ { if arg_typ_sym.kind == .struct_ {

View File

@ -0,0 +1,14 @@
vlib/v/checker/tests/invalid_parameter_name_err.vv:4:24: error: invalid use of reserved type `char` as a parameter name
2 | }
3 |
4 | fn (mut b Buffer) put8(char u8) ? {
| ~~~~
5 | return error('-')
6 | }
vlib/v/checker/tests/invalid_parameter_name_err.vv:10:6: error: invalid use of reserved type `char` as a parameter name
8 | interface Writer {
9 | mut:
10 | put(char u8) ?
| ~~~~
11 | }
12 |

View File

@ -0,0 +1,14 @@
struct Buffer {
}
fn (mut b Buffer) put8(char u8) ? {
return error('-')
}
interface Writer {
mut:
put(char u8) ?
}
fn main() {
}

View File

@ -4,16 +4,16 @@ const (
fn test_for_char_in() { fn test_for_char_in() {
mut sum := 0 mut sum := 0
for char in nums { for ch in nums {
sum += char sum += ch
} }
assert sum == 6 assert sum == 6
} }
fn test_for_char_in_range() { fn test_for_char_in_range() {
mut sum := 0 mut sum := 0
for char in 0 .. nums.len { for ch in 0 .. nums.len {
sum += nums[char] sum += nums[ch]
} }
assert sum == 6 assert sum == 6
} }
@ -28,8 +28,8 @@ fn test_for_blank_in_range() {
fn test_for_char_complex() { fn test_for_char_complex() {
mut sum := 0 mut sum := 0
for char := 0; char < nums.len; char++ { for ch := 0; ch < nums.len; ch++ {
sum += nums[char] sum += nums[ch]
} }
assert sum == 6 assert sum == 6
} }
@ -37,8 +37,8 @@ fn test_for_char_complex() {
fn test_for_char_in_string() { fn test_for_char_in_string() {
s := 'abcd' s := 'abcd'
mut sum := 0 mut sum := 0
for char in s { for ch in s {
sum += char sum += ch
} }
assert sum == 394 // ascii codes of `a` + `b` + `c` + `d` assert sum == 394 // ascii codes of `a` + `b` + `c` + `d`
} }