[clang] [Clang] handle [[warn_unused]] attribute for unused private fields (PR #120734)

Erich Keane via cfe-commits cfe-commits at lists.llvm.org
Fri Dec 20 19:20:20 PST 2024


================
@@ -3307,6 +3307,29 @@ void Sema::CheckShadowInheritedFields(const SourceLocation &Loc,
   }
 }
 
+template <typename AttrType>
+inline static bool HasAttribute(const QualType &T) {
+  if (const TagDecl *TD = T->getAsTagDecl())
+    return TD->hasAttr<AttrType>();
+  if (const TypedefType *TDT = T->getAs<TypedefType>())
+    return TDT->getDecl()->hasAttr<AttrType>();
+  return false;
+}
+
+inline static bool IsUnusedPrivateField(FieldDecl *FD) {
+  if (FD->getAccess() == AS_private && FD->getDeclName()) {
+    QualType FieldType = FD->getType();
----------------
erichkeane wrote:

OK, good thing to check, yuo might be right.

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


More information about the cfe-commits mailing list