[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