[clang] [alpha.webkit.UncountedLocalVarsChecker] Recursive functions are erroneously treated as non-trivial (PR #110973)

Ryosuke Niwa via cfe-commits cfe-commits at lists.llvm.org
Thu Oct 17 13:38:26 PDT 2024


================
@@ -289,3 +289,32 @@ void foo() {
 }
 
 } // namespace local_assignment_to_global
+
+namespace local_var_in_recursive_function {
+
+struct TreeNode {
+  Ref<TreeNode> create() { return Ref(*new TreeNode); }
+
+  void ref() const { ++refCount; }
+  void deref() const {
+    if (!--refCount)
+      delete this;
+  }
+
+  int recursiveCost();
+
+  int cost { 0 };
+  mutable unsigned refCount { 0 };
+  TreeNode* nextSibling { nullptr };
+  TreeNode* firstChild { nullptr };
+};
+
+int TreeNode::recursiveCost() {
+  // no warnings
+  unsigned totalCost = cost;
+  for (TreeNode* node = firstChild; node; node = node->nextSibling)
+    totalCost += recursiveCost();
+  return totalCost;
+}
+
+} // namespace local_var_in_recursive_function
----------------
rniwa wrote:

https://github.com/llvm/llvm-project/blob/main/clang/test/Analysis/Checkers/WebKit/uncounted-obj-arg.cpp has a whole bunch of non-trivial recursive functions but we can add one here for alpha.webkit.UncountedLocalVarsChecker as well.

https://github.com/llvm/llvm-project/pull/110973


More information about the cfe-commits mailing list