diff options
author | Nico Weber <nicolasweber@gmx.de> | 2014-12-27 07:09:37 +0000 |
---|---|---|
committer | Nico Weber <nicolasweber@gmx.de> | 2014-12-27 07:09:37 +0000 |
commit | e3b11043d0930fb36458e0a693f6ae47546cd08b (patch) | |
tree | 6093a6002d00efac8bed6d3c6f4e407902d5faee | |
parent | dd84ec5fd9b0a2fe6d9611c53bad36291bc97c0e (diff) | |
download | bcm5719-llvm-e3b11043d0930fb36458e0a693f6ae47546cd08b.tar.gz bcm5719-llvm-e3b11043d0930fb36458e0a693f6ae47546cd08b.zip |
Objective-C: Tweak unavailability warning.
Don't warn when a selector has an unavailable and an available variant,
and the first also has an implementation.
llvm-svn: 224881
-rw-r--r-- | clang/lib/Sema/SemaDeclObjC.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaObjC/attr-deprecated.m | 21 |
2 files changed, 18 insertions, 5 deletions
diff --git a/clang/lib/Sema/SemaDeclObjC.cpp b/clang/lib/Sema/SemaDeclObjC.cpp index 90835be722b..7e3da941b33 100644 --- a/clang/lib/Sema/SemaDeclObjC.cpp +++ b/clang/lib/Sema/SemaDeclObjC.cpp @@ -2249,7 +2249,7 @@ void Sema::addMethodToGlobalList(ObjCMethodList *List, // Propagate the 'defined' bit. if (Method->isDefined()) PrevObjCMethod->setDefined(true); - else if (!PrevObjCMethod->isDefined()) { + else { // Objective-C doesn't allow an @interface for a class after its // @implementation. So if Method is not defined and there already is // an entry for this type signature, Method has to be for a different diff --git a/clang/test/SemaObjC/attr-deprecated.m b/clang/test/SemaObjC/attr-deprecated.m index 416e4641011..13ba68db58e 100644 --- a/clang/test/SemaObjC/attr-deprecated.m +++ b/clang/test/SemaObjC/attr-deprecated.m @@ -263,11 +263,24 @@ const char * func() { @end @interface InterfaceWithSameMethodAsUndeclaredImpl -- (void)partiallyUnavailableMethod __attribute__((unavailable)); // expected-note{{explicitly marked unavailable here}} +- (void)partiallyUnavailableMethod __attribute__((unavailable)); @end void f(id a) { - // FIXME: Warning on this looks incorrect, since `a` could be an - // UndeclaredImpl object, where this method isn't inavailable. - [a partiallyUnavailableMethod]; // expected-error{{is unavailable}} + [a partiallyUnavailableMethod]; // no warning, `a` could be an UndeclaredImpl. +} + +@interface InterfaceWithImplementation +- (void)anotherPartiallyUnavailableMethod; +@end +@implementation InterfaceWithImplementation +- (void)anotherPartiallyUnavailableMethod {} +@end + +@interface InterfaceWithSameMethodAsInterfaceWithImplementation +- (void)anotherPartiallyUnavailableMethod __attribute__((unavailable)); +@end + +void g(id a) { + [a anotherPartiallyUnavailableMethod]; // no warning, `a` could be an InterfaceWithImplementation. } |