]> granicus.if.org Git - clang/commitdiff
Add support for deprecated Obj-C methods. The semantics mostly match what gcc has.
authorAnders Carlsson <andersca@mac.com>
Sat, 14 Feb 2009 19:08:58 +0000 (19:08 +0000)
committerAnders Carlsson <andersca@mac.com>
Sat, 14 Feb 2009 19:08:58 +0000 (19:08 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64562 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaExprObjC.cpp
test/SemaObjC/attr-deprecated.m [new file with mode: 0644]

index 6e110506eb92203604a654cb1ad55f641736aafb..91e7a185b0535bb3be362715172632489f12e0ce 100644 (file)
@@ -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();
diff --git a/test/SemaObjC/attr-deprecated.m b/test/SemaObjC/attr-deprecated.m
new file mode 100644 (file)
index 0000000..9577e60
--- /dev/null
@@ -0,0 +1,65 @@
+// RUN: clang %s -fsyntax-only -verify
+
+@interface A
++ (void)F __attribute__((deprecated));
+- (void)f __attribute__((deprecated));
+@end
+
+@implementation A
++ (void)F __attribute__((deprecated))
+{
+  [self F]; // expected-warning{{'F' is deprecated}}
+}
+
+- (void)g
+{
+  [self f]; // expected-warning{{'f' is deprecated}}
+}
+
+- (void)f
+{
+  [self f]; // expected-warning{{'f' is deprecated}}
+}
+@end
+
+@interface B: A
+@end
+  
+@implementation B
++ (void)G
+{
+  [super F]; // expected-warning{{'F' is deprecated}}
+}
+
+- (void)g
+{
+  [super f]; // // expected-warning{{'f' is deprecated}}
+}
+@end
+
+@protocol P
+- (void)p __attribute__((deprecated));
+@end
+
+void t1(A *a)
+{
+  [A F]; // expected-warning{{'F' is deprecated}}
+  [a f]; // expected-warning{{'f' is deprecated}}
+}
+
+void t2(id a)
+{
+  [a f];
+}
+
+void t3(A<P>* a)
+{
+  [a f]; // expected-warning{{'f' is deprecated}}
+  [a p]; // expected-warning{{'p' is deprecated}}
+} 
+
+void t4(Class c)
+{
+  [c F];
+}
+