aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaExprObjC.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Sema/SemaExprObjC.cpp')
-rw-r--r--lib/Sema/SemaExprObjC.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/lib/Sema/SemaExprObjC.cpp b/lib/Sema/SemaExprObjC.cpp
index 6e110506eb..91e7a185b0 100644
--- a/lib/Sema/SemaExprObjC.cpp
+++ b/lib/Sema/SemaExprObjC.cpp
@@ -268,6 +268,9 @@ Sema::ExprResult Sema::ActOnClassMessage(
if (!Method)
Method = ClassDecl->lookupInstanceMethod(Sel);
+ if (Method && Method->getAttr<DeprecatedAttr>())
+ Diag(receiverLoc, diag::warn_deprecated) << Method->getDeclName();
+
if (CheckMessageArgumentTypes(ArgExprs, NumArgs, Sel, Method, true,
lbrac, rbrac, returnType))
return true;
@@ -313,6 +316,9 @@ Sema::ExprResult Sema::ActOnInstanceMessage(ExprTy *receiver, Selector Sel,
Method = SuperDecl->lookupInstanceMethod(Sel);
}
+ if (Method && Method->getAttr<DeprecatedAttr>())
+ Diag(receiverLoc, diag::warn_deprecated) << Method->getDeclName();
+
if (CheckMessageArgumentTypes(ArgExprs, NumArgs, Sel, Method, false,
lbrac, rbrac, returnType))
return true;
@@ -343,6 +349,9 @@ Sema::ExprResult Sema::ActOnInstanceMessage(ExprTy *receiver, Selector Sel,
if (ObjCImplementationDecl *ImpDecl =
ObjCImplementations[ClassDecl->getIdentifier()])
Method = ImpDecl->getClassMethod(Sel);
+
+ if (Method && Method->getAttr<DeprecatedAttr>())
+ Diag(receiverLoc, diag::warn_deprecated) << Method->getDeclName();
}
if (!Method)
Method = FactoryMethodPool[Sel].Method;
@@ -393,6 +402,9 @@ Sema::ExprResult Sema::ActOnInstanceMessage(ExprTy *receiver, Selector Sel,
if (!Method && !OCIReceiver->qual_empty())
Diag(lbrac, diag::warn_method_not_found_in_protocol)
<< Sel << SourceRange(lbrac, rbrac);
+
+ if (Method && Method->getAttr<DeprecatedAttr>())
+ Diag(receiverLoc, diag::warn_deprecated) << Method->getDeclName();
} else {
Diag(lbrac, diag::error_bad_receiver_type)
<< RExpr->getType() << RExpr->getSourceRange();