[clang] [clang] Implement `__builtin_is_implicit_lifetime()` (PR #101807)

Aaron Ballman via cfe-commits cfe-commits at lists.llvm.org
Wed Aug 14 06:11:18 PDT 2024


================
@@ -5637,6 +5638,38 @@ static bool EvaluateUnaryTypeTrait(Sema &Self, TypeTrait UTT,
     return false;
   case UTT_IsTriviallyEqualityComparable:
     return isTriviallyEqualityComparableType(Self, T, KeyLoc);
+  case UTT_IsImplicitLifetime: {
+    DiagnoseVLAInCXXTypeTrait(Self, TInfo,
+                              tok::kw___builtin_is_implicit_lifetime);
+
+    // [basic.types.general] p9
+    // Scalar types, implicit-lifetime class types ([class.prop]),
+    // array types, and cv-qualified versions of these types
+    // are collectively called implicit-lifetime types.
+    QualType UnqualT = T->getCanonicalTypeUnqualified();
----------------
AaronBallman wrote:

I think we should reject use of `_Atomic` so that we don't give a true or false answer; that leaves the door open for us to better define the behavior in the future without risk of breaking code.

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


More information about the cfe-commits mailing list