r203984 - Objective-C. Redo turning off designated initialization warnings on
Fariborz Jahanian
fjahanian at apple.com
Fri Mar 14 16:30:18 PDT 2014
Author: fjahanian
Date: Fri Mar 14 18:30:18 2014
New Revision: 203984
URL: http://llvm.org/viewvc/llvm-project?rev=203984&view=rev
Log:
Objective-C. Redo turning off designated initialization warnings on
'init' methods which are unavailable. Subclasses of NSObject
have to implement such methods as a common pattern to prevent
user's own implementation. // rdar://16305460
Modified:
cfe/trunk/lib/Sema/SemaDecl.cpp
cfe/trunk/lib/Sema/SemaDeclObjC.cpp
Modified: cfe/trunk/lib/Sema/SemaDecl.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDecl.cpp?rev=203984&r1=203983&r2=203984&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaDecl.cpp (original)
+++ cfe/trunk/lib/Sema/SemaDecl.cpp Fri Mar 14 18:30:18 2014
@@ -9831,14 +9831,19 @@ Decl *Sema::ActOnFinishFunctionBody(Decl
MD->isDesignatedInitializerForTheInterface(&InitMethod);
assert(isDesignated && InitMethod);
(void)isDesignated;
- Diag(MD->getLocation(),
- diag::warn_objc_designated_init_missing_super_call);
- Diag(InitMethod->getLocation(),
- diag::note_objc_designated_init_marked_here);
+ // Don't issue this warning for unavaialable inits.
+ if (!MD->isUnavailable()) {
+ Diag(MD->getLocation(),
+ diag::warn_objc_designated_init_missing_super_call);
+ Diag(InitMethod->getLocation(),
+ diag::note_objc_designated_init_marked_here);
+ }
getCurFunction()->ObjCWarnForNoDesignatedInitChain = false;
}
if (getCurFunction()->ObjCWarnForNoInitDelegation) {
- Diag(MD->getLocation(), diag::warn_objc_secondary_init_missing_init_call);
+ // Don't issue this warning for unavaialable inits.
+ if (!MD->isUnavailable())
+ Diag(MD->getLocation(), diag::warn_objc_secondary_init_missing_init_call);
getCurFunction()->ObjCWarnForNoInitDelegation = false;
}
} else {
Modified: cfe/trunk/lib/Sema/SemaDeclObjC.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDeclObjC.cpp?rev=203984&r1=203983&r2=203984&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaDeclObjC.cpp (original)
+++ cfe/trunk/lib/Sema/SemaDeclObjC.cpp Fri Mar 14 18:30:18 2014
@@ -392,14 +392,11 @@ void Sema::ActOnStartOfObjCMethodDef(Sco
if (MDecl->getMethodFamily() == OMF_init) {
if (MDecl->isDesignatedInitializerForTheInterface()) {
getCurFunction()->ObjCIsDesignatedInit = true;
- // Don't issue this warning for unavaialable inits.
- if (!MDecl->isUnavailable())
- getCurFunction()->ObjCWarnForNoDesignatedInitChain =
+ getCurFunction()->ObjCWarnForNoDesignatedInitChain =
IC->getSuperClass() != 0;
} else if (IC->hasDesignatedInitializers()) {
getCurFunction()->ObjCIsSecondaryInit = true;
- // Don't issue this warning for unavaialable inits.
- getCurFunction()->ObjCWarnForNoInitDelegation = !MDecl->isUnavailable();
+ getCurFunction()->ObjCWarnForNoInitDelegation = true;
}
}
More information about the cfe-commits
mailing list