[cfe-commits] r62431 - in /cfe/trunk: include/clang/Basic/DiagnosticKinds.def lib/Sema/SemaDeclObjC.cpp test/SemaObjC/method-bad-param.m

Fariborz Jahanian fjahanian at apple.com
Sat Jan 17 13:57:49 PST 2009


Author: fjahanian
Date: Sat Jan 17 15:57:49 2009
New Revision: 62431

URL: http://llvm.org/viewvc/llvm-project?rev=62431&view=rev
Log:
Diagnose when method parameter is an object.


Added:
    cfe/trunk/test/SemaObjC/method-bad-param.m
Modified:
    cfe/trunk/include/clang/Basic/DiagnosticKinds.def
    cfe/trunk/lib/Sema/SemaDeclObjC.cpp

Modified: cfe/trunk/include/clang/Basic/DiagnosticKinds.def
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticKinds.def?rev=62431&r1=62430&r2=62431&view=diff

==============================================================================
--- cfe/trunk/include/clang/Basic/DiagnosticKinds.def (original)
+++ cfe/trunk/include/clang/Basic/DiagnosticKinds.def Sat Jan 17 15:57:49 2009
@@ -416,6 +416,8 @@
      "expected string literal or '[' for asm operand")
 DIAG(err_expected_selector_for_method, ERROR,
      "expected selector for Objective-C method")
+DIAG(err_object_as_method_param, ERROR,
+     "can not use an object as parameter to a method")
 DIAG(err_nsobject_attribute, ERROR,
      "__attribute ((NSObject)) is for pointer types only")
 

Modified: cfe/trunk/lib/Sema/SemaDeclObjC.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDeclObjC.cpp?rev=62431&r1=62430&r2=62431&view=diff

==============================================================================
--- cfe/trunk/lib/Sema/SemaDeclObjC.cpp (original)
+++ cfe/trunk/lib/Sema/SemaDeclObjC.cpp Sat Jan 17 15:57:49 2009
@@ -1349,6 +1349,11 @@
       }
       else if (argType->isFunctionType())
         argType = Context.getPointerType(argType);
+      else if (argType->isObjCInterfaceType()) {
+        // FIXME! provide more precise location for the parameter
+        Diag(MethodLoc, diag::err_object_as_method_param);
+        return 0;
+      }
     } else
       argType = Context.getObjCIdType();
     ParmVarDecl* Param;

Added: cfe/trunk/test/SemaObjC/method-bad-param.m
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaObjC/method-bad-param.m?rev=62431&view=auto

==============================================================================
--- cfe/trunk/test/SemaObjC/method-bad-param.m (added)
+++ cfe/trunk/test/SemaObjC/method-bad-param.m Sat Jan 17 15:57:49 2009
@@ -0,0 +1,18 @@
+// RUN: clang -fsyntax-only -verify %s
+
+ at interface foo
+ at end
+
+ at implementation foo
+ at end
+
+ at interface bar
+-(void) my_method:(foo) my_param; // expected-error {{can not use an object as parameter to a method}}
+ at end
+
+ at implementation bar
+-(void) my_method:(foo) my_param  // expected-error {{can not use an object as parameter to a method}}
+{
+}
+ at end
+





More information about the cfe-commits mailing list