From a01e8eb0f8eb64b57a9b5894165b3774a3aa88c2 Mon Sep 17 00:00:00 2001 From: Delyan Angelov Date: Fri, 18 Jun 2021 12:50:51 +0300 Subject: [PATCH] v.checker: implement `-d debug_manualfree`, noticing `[manualfree]fn f(s string){return s}` --- vlib/v/checker/checker.v | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/vlib/v/checker/checker.v b/vlib/v/checker/checker.v index 1635183124..4108bc0f58 100644 --- a/vlib/v/checker/checker.v +++ b/vlib/v/checker/checker.v @@ -3052,6 +3052,20 @@ pub fn (mut c Checker) return_stmt(mut node ast.Return) { } } node.types = got_types + $if debug_manualfree ? { + cfn := c.table.cur_fn + if cfn.is_manualfree { + pnames := cfn.params.map(it.name) + for expr in node.exprs { + if expr is ast.Ident { + if expr.name in pnames { + c.note('returning a parameter in a fn marked with `[manualfree]` can cause double freeing in the caller', + node.pos) + } + } + } + } + } // allow `none` & `error` return types for function that returns optional option_type_idx := c.table.type_idxs['Option'] got_types_0_idx := got_types[0].idx()