summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaDeclObjC.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2013-12-10 19:43:48 +0000
committerTed Kremenek <kremenek@apple.com>2013-12-10 19:43:48 +0000
commitf41cf7f10f76704b7037de9a8a7adcc114db1c46 (patch)
tree0f57c1a4e0271d7ae02d7a70d51f2276d5e40283 /clang/lib/Sema/SemaDeclObjC.cpp
parentd980da2290fda089a3156d0b23e928fcf99b270a (diff)
downloadbcm5719-llvm-f41cf7f10f76704b7037de9a8a7adcc114db1c46.tar.gz
bcm5719-llvm-f41cf7f10f76704b7037de9a8a7adcc114db1c46.zip
Rename attribute 'objc_suppress_protocol_methods' to 'objc_protocol_requires_explicit_implementation'.
That's a mouthful, and not necessarily the final name. This also reflects a semantic change where this attribute is now on the protocol itself instead of a class. This attribute will require that a protocol, when adopted by a class, is explicitly implemented by the class itself (instead of walking the super class chain). Note that this attribute is not "done". This should be considered a WIP. llvm-svn: 196955
Diffstat (limited to 'clang/lib/Sema/SemaDeclObjC.cpp')
-rw-r--r--clang/lib/Sema/SemaDeclObjC.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/clang/lib/Sema/SemaDeclObjC.cpp b/clang/lib/Sema/SemaDeclObjC.cpp
index 421b797c794..babfafe656d 100644
--- a/clang/lib/Sema/SemaDeclObjC.cpp
+++ b/clang/lib/Sema/SemaDeclObjC.cpp
@@ -1666,6 +1666,8 @@ void Sema::CheckProtocolMethodDefs(SourceLocation ImpLoc,
// the method was implemented by a base class or an inherited
// protocol. This lookup is slow, but occurs rarely in correct code
// and otherwise would terminate in a warning.
+ if (PDecl->hasAttr<ObjCExplicitProtocolImplAttr>())
+ Super = NULL;
// check unimplemented instance methods.
if (!NSIDecl)
@@ -1679,8 +1681,7 @@ void Sema::CheckProtocolMethodDefs(SourceLocation ImpLoc,
true /* instance */,
false /* shallowCategory */,
true /* followsSuper */,
- NULL /* category */,
- PDecl /* protocol */))) {
+ NULL /* category */))) {
// If a method is not implemented in the category implementation but
// has been declared in its primary class, superclass,
// or in one of their protocols, no need to issue the warning.
@@ -1717,8 +1718,7 @@ void Sema::CheckProtocolMethodDefs(SourceLocation ImpLoc,
false /* class method */,
false /* shallowCategoryLookup */,
true /* followSuper */,
- NULL /* category */,
- PDecl /* protocol */))) {
+ NULL /* category */))) {
// See above comment for instance method lookups.
if (C && IDecl->lookupMethod(method->getSelector(),
false /* class */,
OpenPOWER on IntegriCloud