r195866 - Converts the lockable attributes to use the simple attribute handler because the semantic checking was already automated.
Aaron Ballman
aaron at aaronballman.com
Wed Nov 27 11:35:27 PST 2013
Author: aaronballman
Date: Wed Nov 27 13:35:27 2013
New Revision: 195866
URL: http://llvm.org/viewvc/llvm-project?rev=195866&view=rev
Log:
Converts the lockable attributes to use the simple attribute handler because the semantic checking was already automated.
Modified:
cfe/trunk/lib/Sema/SemaDeclAttr.cpp
Modified: cfe/trunk/lib/Sema/SemaDeclAttr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDeclAttr.cpp?rev=195866&r1=195865&r2=195866&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaDeclAttr.cpp (original)
+++ cfe/trunk/lib/Sema/SemaDeclAttr.cpp Wed Nov 27 13:35:27 2013
@@ -620,35 +620,6 @@ static void handlePtGuardedByAttr(Sema &
S.Context, Arg));
}
-static bool checkLockableAttrCommon(Sema &S, Decl *D,
- const AttributeList &Attr) {
- // FIXME: Lockable structs for C code.
- if (!isa<RecordDecl>(D)) {
- S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
- << Attr.getName() << ExpectedStructOrUnionOrClass;
- return false;
- }
-
- return true;
-}
-
-static void handleLockableAttr(Sema &S, Decl *D, const AttributeList &Attr) {
- if (!checkLockableAttrCommon(S, D, Attr))
- return;
-
- D->addAttr(::new (S.Context) LockableAttr(Attr.getRange(), S.Context));
-}
-
-static void handleScopedLockableAttr(Sema &S, Decl *D,
- const AttributeList &Attr) {
- if (!checkLockableAttrCommon(S, D, Attr))
- return;
-
- D->addAttr(::new (S.Context)
- ScopedLockableAttr(Attr.getRange(), S.Context,
- Attr.getAttributeSpellingListIndex()));
-}
-
static bool checkAcquireOrderAttrCommon(Sema &S, Decl *D,
const AttributeList &Attr,
SmallVectorImpl<Expr *> &Args) {
@@ -4357,8 +4328,7 @@ static void ProcessDeclAttribute(Sema &S
handlePtGuardedVarAttr(S, D, Attr);
break;
case AttributeList::AT_ScopedLockable:
- handleScopedLockableAttr(S, D, Attr);
- break;
+ handleSimpleAttribute<ScopedLockableAttr>(S, D, Attr); break;
case AttributeList::AT_NoSanitizeAddress:
handleSimpleAttribute<NoSanitizeAddressAttr>(S, D, Attr);
break;
@@ -4372,8 +4342,7 @@ static void ProcessDeclAttribute(Sema &S
handleSimpleAttribute<NoSanitizeMemoryAttr>(S, D, Attr);
break;
case AttributeList::AT_Lockable:
- handleLockableAttr(S, D, Attr);
- break;
+ handleSimpleAttribute<LockableAttr>(S, D, Attr); break;
case AttributeList::AT_GuardedBy:
handleGuardedByAttr(S, D, Attr);
break;
More information about the cfe-commits
mailing list