[clang] [clang] Fix segmentation fault caused by stack overflow on deeply nested expressions (PR #111701)

Reid Kleckner via cfe-commits cfe-commits at lists.llvm.org
Fri Oct 11 08:47:01 PDT 2024


================
@@ -0,0 +1,1013 @@
+// RUN: %clang_cc1 %s -emit-llvm -o - -Wstack-exhausted -verify
+
+class AClass {
+public:
+  AClass() {}
+  AClass &foo() { return *this; }
+};
+
+void test_bar() {
+  AClass a;
+  // expected-warning@* {{stack nearly exhausted; compilation time may suffer, and crashes due to stack overflow are likely}}
+  a.foo().foo().foo().foo().foo().foo().foo().foo().foo().foo().foo().foo()
----------------
rnk wrote:

FWIW I like the pre-processor version of this too. I appreciate that size isn't always the most important dimension of testing, but I prefer the tradeoff for the smaller test here.

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


More information about the cfe-commits mailing list