From 67ab5b858b4c374d4089977ea9a212dcdb89d431 Mon Sep 17 00:00:00 2001 From: yuyi Date: Fri, 3 Sep 2021 17:26:46 +0800 Subject: [PATCH] checker: fix checking fn prototype mismatch (#11369) --- vlib/v/checker/check_types.v | 4 +++- vlib/v/checker/tests/fn_type_mismatch.out | 7 +++++++ vlib/v/checker/tests/fn_type_mismatch.vv | 14 ++++++++++++++ 3 files changed, 24 insertions(+), 1 deletion(-) create mode 100644 vlib/v/checker/tests/fn_type_mismatch.out create mode 100644 vlib/v/checker/tests/fn_type_mismatch.vv diff --git a/vlib/v/checker/check_types.v b/vlib/v/checker/check_types.v index ddbcfe82a0..a292508a7b 100644 --- a/vlib/v/checker/check_types.v +++ b/vlib/v/checker/check_types.v @@ -164,8 +164,10 @@ pub fn (mut c Checker) check_matching_function_symbols(got_type_sym &ast.TypeSym got_arg_pointedness := if got_arg_is_ptr { 'a pointer' } else { 'NOT a pointer' } c.add_error_detail('`$exp_fn.name`\'s expected fn argument: `$exp_arg.name` is $exp_arg_pointedness, but the passed fn argument: `$got_arg.name` is $got_arg_pointedness') return false + } else if exp_arg_is_ptr && got_arg_is_ptr { + continue } - if !c.check_basic(got_arg.typ, exp_arg.typ) { + if got_arg.typ != exp_arg.typ { return false } } diff --git a/vlib/v/checker/tests/fn_type_mismatch.out b/vlib/v/checker/tests/fn_type_mismatch.out new file mode 100644 index 0000000000..0a2932d956 --- /dev/null +++ b/vlib/v/checker/tests/fn_type_mismatch.out @@ -0,0 +1,7 @@ +vlib/v/checker/tests/fn_type_mismatch.vv:11:15: error: invalid array element: expected `fn (int, int) f32`, not `fn (f32, f32) f32` + 9 | + 10 | fn main() { + 11 | fns := [add, div] + | ~~~ + 12 | println(fns[0](10.0, 5.0)) + 13 | println(fns[1](10.0, 5.0)) diff --git a/vlib/v/checker/tests/fn_type_mismatch.vv b/vlib/v/checker/tests/fn_type_mismatch.vv new file mode 100644 index 0000000000..a2f4ebbf7d --- /dev/null +++ b/vlib/v/checker/tests/fn_type_mismatch.vv @@ -0,0 +1,14 @@ +fn add(a int, b int) f32 { + return (a + b) +} + +fn div(a f32, b f32) f32 { + println('div: $a $b') + return (a / b) +} + +fn main() { + fns := [add, div] + println(fns[0](10.0, 5.0)) + println(fns[1](10.0, 5.0)) +}