[clang] [Clang] Deleting an incomplete enum type is not an error (PR #118455)

via cfe-commits cfe-commits at lists.llvm.org
Tue Dec 3 02:49:14 PST 2024


================
@@ -540,6 +540,14 @@ namespace PR10504 {
   void f(A *x) { delete x; } // expected-warning {{delete called on 'PR10504::A' that is abstract but has non-virtual destructor}}
 }
 
+#if __cplusplus >= 201103L
+enum GH99278_1 { // expected-note {{definition of 'GH99278_1' is not complete until the closing '}'}}
+    zero = decltype(delete static_cast<GH99278_1*>(nullptr), 0){}
----------------
cor3ntin wrote:

Good question - I focused on restoring the previous behavior - and I think it's still UB if you could do it, but maybe hard/impossible to do in practice.

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


More information about the cfe-commits mailing list