From 983511f21de4d060f345724ab9cc1c6378aa9c80 Mon Sep 17 00:00:00 2001 From: Felipe Pena Date: Mon, 18 Nov 2024 05:34:54 -0300 Subject: [PATCH] v.markused: fix `-skip-unused` error with aggregate method call (fix #22852 - building vsql) (#22883) --- vlib/v/markused/walker.v | 21 +++++++++++++++++++ .../tests/skip_unused/aggregate_call.run.out | 0 .../aggregate_call.skip_unused.run.out | 0 vlib/v/tests/skip_unused/aggregate_call.vv | 20 ++++++++++++++++++ 4 files changed, 41 insertions(+) create mode 100644 vlib/v/tests/skip_unused/aggregate_call.run.out create mode 100644 vlib/v/tests/skip_unused/aggregate_call.skip_unused.run.out create mode 100644 vlib/v/tests/skip_unused/aggregate_call.vv diff --git a/vlib/v/markused/walker.v b/vlib/v/markused/walker.v index 8eefe1bfd631f8..8abcc6666e167e 100644 --- a/vlib/v/markused/walker.v +++ b/vlib/v/markused/walker.v @@ -528,6 +528,17 @@ pub fn (mut w Walker) call_expr(mut node ast.CallExpr) { } return } + if node.is_method && node.left_type != 0 { + left_sym := w.table.sym(node.left_type) + if left_sym.info is ast.Aggregate { + for types in left_sym.info.types { + fn_name := '${types.idx()}.${node.name}' + if !w.used_fns[fn_name] { + w.mark_aggregate_call_used(fn_name, types) + } + } + } + } w.expr(node.left) w.or_block(node.or_block) @@ -566,6 +577,16 @@ pub fn (mut w Walker) call_expr(mut node ast.CallExpr) { } } +// visit aggregate type method declaration +pub fn (mut w Walker) mark_aggregate_call_used(fn_name string, left_type ast.Type) { + if w.used_fns[fn_name] { + return + } + w.mark_fn_as_used(fn_name) + stmt := w.all_fns[fn_name] or { return } + w.stmts(stmt.stmts) +} + pub fn (mut w Walker) fn_by_name(fn_name string) { if w.used_fns[fn_name] { return diff --git a/vlib/v/tests/skip_unused/aggregate_call.run.out b/vlib/v/tests/skip_unused/aggregate_call.run.out new file mode 100644 index 00000000000000..e69de29bb2d1d6 diff --git a/vlib/v/tests/skip_unused/aggregate_call.skip_unused.run.out b/vlib/v/tests/skip_unused/aggregate_call.skip_unused.run.out new file mode 100644 index 00000000000000..e69de29bb2d1d6 diff --git a/vlib/v/tests/skip_unused/aggregate_call.vv b/vlib/v/tests/skip_unused/aggregate_call.vv new file mode 100644 index 00000000000000..76b9c74605c8b5 --- /dev/null +++ b/vlib/v/tests/skip_unused/aggregate_call.vv @@ -0,0 +1,20 @@ +struct Foo {} + +struct Bar {} + +type SumType = Foo | Bar + +fn (f Foo) pstr() { +} + +fn (b Bar) pstr() { +} + +fn main() { + a := SumType(Foo{}) + match a { + Foo, Bar { + a.pstr() + } + } +}