From 236a1d0255182ea7bf4c5550810221c143f60bab Mon Sep 17 00:00:00 2001 From: yuyi Date: Mon, 10 Jan 2022 01:00:23 +0800 Subject: [PATCH] cgen: fix error for print comptime for method call (#13108) --- vlib/v/gen/c/fn.v | 16 +++++++++ ...ptime_for_method_call_in_print_call_test.v | 34 +++++++++++++++++++ 2 files changed, 50 insertions(+) create mode 100644 vlib/v/tests/comptime_for_method_call_in_print_call_test.v diff --git a/vlib/v/gen/c/fn.v b/vlib/v/gen/c/fn.v index 1432e966a8..39c791a3a4 100644 --- a/vlib/v/gen/c/fn.v +++ b/vlib/v/gen/c/fn.v @@ -869,6 +869,15 @@ fn (mut g Gen) method_call(node ast.CallExpr) { return } } + } else if node.left is ast.ComptimeCall { + if node.left.method_name == 'method' { + sym := g.table.sym(g.unwrap_generic(node.left.left_type)) + if m := sym.find_method(g.comptime_for_method) { + rec_type = m.return_type + g.gen_expr_to_string(node.left, rec_type) + return + } + } } else if node.left is ast.Ident { if node.left.obj is ast.Var { if g.comptime_var_type_map.len > 0 { @@ -1219,6 +1228,13 @@ fn (mut g Gen) fn_call(node ast.CallExpr) { typ = g.comptime_var_type_map[key_str] or { typ } } } + } else if expr is ast.ComptimeCall { + if expr.method_name == 'method' { + sym := g.table.sym(g.unwrap_generic(expr.left_type)) + if m := sym.find_method(g.comptime_for_method) { + typ = m.return_type + } + } } else if expr is ast.Ident { if expr.obj is ast.Var { typ = expr.obj.typ diff --git a/vlib/v/tests/comptime_for_method_call_in_print_call_test.v b/vlib/v/tests/comptime_for_method_call_in_print_call_test.v new file mode 100644 index 0000000000..349a4dc2b9 --- /dev/null +++ b/vlib/v/tests/comptime_for_method_call_in_print_call_test.v @@ -0,0 +1,34 @@ +module main + +struct S1 {} + +fn test_comptime_for_method_call_str() { + s1 := S1{} + mut rets := []string{} + + $for method in S1.methods { + println(s1.$method('ll')) + rets << s1.$method('ll').str() + } + assert rets.len == 4 + assert rets[0] == '7' + assert rets[1] == '7.7' + assert rets[2] == 'foo' + assert rets[3] == 'true' +} + +fn (t S1) m1(s string) int { + return 7 +} + +fn (t S1) m2(s string) f64 { + return 7.7 +} + +fn (t S1) m3(s string) string { + return 'foo' +} + +fn (t S1) m4(s string) bool { + return true +}