diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2011-10-15 19:18:36 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2011-10-15 19:18:36 +0000 |
commit | 43bcdb2d4d8390aec89e75f4d232b1fb218a59c5 (patch) | |
tree | db29e5c067bcaa4d33d48b9daadbea6faebc7e77 | |
parent | 86d18c56383404f2098c6dbc716852aad60ba060 (diff) |
Avoid duplicate unavailbility diagnostics in objc++.
// rdar://10268422
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@142078 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Sema/SemaExprObjC.cpp | 4 | ||||
-rw-r--r-- | test/SemaObjC/special-dep-unavail-warning.m | 10 |
2 files changed, 13 insertions, 1 deletions
diff --git a/lib/Sema/SemaExprObjC.cpp b/lib/Sema/SemaExprObjC.cpp index 20098b2136..a23ba4921c 100644 --- a/lib/Sema/SemaExprObjC.cpp +++ b/lib/Sema/SemaExprObjC.cpp @@ -1078,7 +1078,9 @@ ExprResult Sema::BuildClassMessage(TypeSourceInfo *ReceiverTypeInfo, return ExprError(); } assert(Class && "We don't know which class we're messaging?"); - (void)DiagnoseUseOfDecl(Class, Loc); + // objc++ diagnoses during typename annotation. + if (!getLangOptions().CPlusPlus) + (void)DiagnoseUseOfDecl(Class, Loc); // Find the method we are messaging. if (!Method) { if (Class->isForwardDecl()) { diff --git a/test/SemaObjC/special-dep-unavail-warning.m b/test/SemaObjC/special-dep-unavail-warning.m index 57a2fa3465..fb0f6604e6 100644 --- a/test/SemaObjC/special-dep-unavail-warning.m +++ b/test/SemaObjC/special-dep-unavail-warning.m @@ -43,3 +43,13 @@ void test(C *c) { } +// rdar://10268422 +__attribute ((deprecated)) +@interface DEPRECATED ++(id)new; +@end + +void foo() { + [DEPRECATED new]; // expected-warning {{warning: 'DEPRECATED' is deprecated}} +} + |