From 634b2930f5a8fc4b153437657ce786ca3fba5b1e Mon Sep 17 00:00:00 2001 From: DeLesley Hutchins Date: Thu, 16 Feb 2012 17:15:51 +0000 Subject: [PATCH] Thread safety analysis: Don't check for lockable on undefined types. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@150702 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Sema/SemaDeclAttr.cpp | 3 +++ 1 file changed, 3 insertions(+) diff --git a/lib/Sema/SemaDeclAttr.cpp b/lib/Sema/SemaDeclAttr.cpp index 54e7969e0d..f0830b8861 100644 --- a/lib/Sema/SemaDeclAttr.cpp +++ b/lib/Sema/SemaDeclAttr.cpp @@ -283,6 +283,9 @@ static bool checkForLockableRecord(Sema &S, Decl *D, const AttributeList &Attr, << Attr.getName(); return false; } + // Don't check for lockable if the class hasn't been defined yet. + if (RT->isIncompleteType()) + return true; // Flag error if the type is not lockable. if (!RT->getDecl()->getAttr()) { S.Diag(Attr.getLoc(), diag::err_attribute_argument_not_lockable) -- 2.50.1