[clang] c2f75c7 - [clang][Interp] Handle CXXDefaultInitExpr of composite type
Timm Bäder via cfe-commits
cfe-commits at lists.llvm.org
Mon Mar 18 05:00:07 PDT 2024
Author: Timm Bäder
Date: 2024-03-18T12:59:56+01:00
New Revision: c2f75c7159518e238e0185c0f4e615fedcd8a167
URL: https://github.com/llvm/llvm-project/commit/c2f75c7159518e238e0185c0f4e615fedcd8a167
DIFF: https://github.com/llvm/llvm-project/commit/c2f75c7159518e238e0185c0f4e615fedcd8a167.diff
LOG: [clang][Interp] Handle CXXDefaultInitExpr of composite type
Added:
Modified:
clang/lib/AST/Interp/ByteCodeExprGen.cpp
clang/test/AST/Interp/records.cpp
Removed:
################################################################################
diff --git a/clang/lib/AST/Interp/ByteCodeExprGen.cpp b/clang/lib/AST/Interp/ByteCodeExprGen.cpp
index 6cee3c1af9f66a..d943dcbe06507b 100644
--- a/clang/lib/AST/Interp/ByteCodeExprGen.cpp
+++ b/clang/lib/AST/Interp/ByteCodeExprGen.cpp
@@ -2916,11 +2916,7 @@ template <class Emitter>
bool ByteCodeExprGen<Emitter>::VisitCXXDefaultInitExpr(
const CXXDefaultInitExpr *E) {
SourceLocScope<Emitter> SLS(this, E);
- if (Initializing)
- return this->visitInitializer(E->getExpr());
-
- assert(classify(E->getType()));
- return this->visit(E->getExpr());
+ return this->delegate(E->getExpr());
}
template <class Emitter>
diff --git a/clang/test/AST/Interp/records.cpp b/clang/test/AST/Interp/records.cpp
index d37d4410c763fb..0f76e0cfe99277 100644
--- a/clang/test/AST/Interp/records.cpp
+++ b/clang/test/AST/Interp/records.cpp
@@ -1264,3 +1264,24 @@ namespace {
static_assert(true_type::value, "");
static_assert(true_type::value, "");
}
+
+#if __cplusplus >= 202002L
+namespace {
+ /// Used to crash because the CXXDefaultInitExpr is of compound type.
+ struct A {
+ int &x;
+ constexpr ~A() { --x; }
+ };
+ struct B {
+ int &x;
+ const A &a = A{x};
+ };
+ constexpr int a() {
+ int x = 1;
+ int f = B{x}.x;
+ B{x}; // both-warning {{expression result unused}}
+
+ return 1;
+ }
+}
+#endif
More information about the cfe-commits
mailing list