From: Douglas Gregor Date: Sun, 9 Oct 2011 22:26:49 +0000 (+0000) Subject: For the various CF and NS attributes, don't complain if the parameter X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6c73a2975ba9112787380abd878876336957b3f6;p=clang For the various CF and NS attributes, don't complain if the parameter or return types are dependent. Fixes PR9049. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@141518 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaDeclAttr.cpp b/lib/Sema/SemaDeclAttr.cpp index 38c0c4aef5..f76bb5879a 100644 --- a/lib/Sema/SemaDeclAttr.cpp +++ b/lib/Sema/SemaDeclAttr.cpp @@ -3136,10 +3136,14 @@ static void handleLaunchBoundsAttr(Sema &S, Decl *D, const AttributeList &Attr){ //===----------------------------------------------------------------------===// static bool isValidSubjectOfNSAttribute(Sema &S, QualType type) { - return type->isObjCObjectPointerType() || S.Context.isObjCNSObjectType(type); + return type->isDependentType() || + type->isObjCObjectPointerType() || + S.Context.isObjCNSObjectType(type); } static bool isValidSubjectOfCFAttribute(Sema &S, QualType type) { - return type->isPointerType() || isValidSubjectOfNSAttribute(S, type); + return type->isDependentType() || + type->isPointerType() || + isValidSubjectOfNSAttribute(S, type); } static void handleNSConsumedAttr(Sema &S, Decl *D, const AttributeList &Attr) { diff --git a/test/SemaTemplate/attributes.cpp b/test/SemaTemplate/attributes.cpp index e208bd2b89..495f4a7ad3 100644 --- a/test/SemaTemplate/attributes.cpp +++ b/test/SemaTemplate/attributes.cpp @@ -19,3 +19,16 @@ namespace attribute_aligned { check_alignment<3>::t c3; // expected-note 2 {{in instantiation}} check_alignment<4>::t c4; } + +namespace PR9049 { + extern const void *CFRetain(const void *ref); + + template __attribute__((cf_returns_retained)) + inline T WBCFRetain(T aValue) { return aValue ? (T)CFRetain(aValue) : (T)0; } + + + extern void CFRelease(const void *ref); + + template + inline void WBCFRelease(__attribute__((cf_consumed)) T aValue) { if(aValue) CFRelease(aValue); } +}