[cfe-commits] r106139 - /cfe/trunk/lib/Sema/SemaExprObjC.cpp
Fariborz Jahanian
fjahanian at apple.com
Wed Jun 16 12:56:08 PDT 2010
Author: fjahanian
Date: Wed Jun 16 14:56:08 2010
New Revision: 106139
URL: http://llvm.org/viewvc/llvm-project?rev=106139&view=rev
Log:
C return types must be complete as well.
Moved check before we build the ObjCMessageExpr node.
(PR7386 related).
Modified:
cfe/trunk/lib/Sema/SemaExprObjC.cpp
Modified: cfe/trunk/lib/Sema/SemaExprObjC.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaExprObjC.cpp?rev=106139&r1=106138&r2=106139&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaExprObjC.cpp (original)
+++ cfe/trunk/lib/Sema/SemaExprObjC.cpp Wed Jun 16 14:56:08 2010
@@ -1007,6 +1007,12 @@
if (CheckMessageArgumentTypes(Args, NumArgs, Sel, Method, false,
LBracLoc, RBracLoc, ReturnType))
return ExprError();
+
+ if (!ReturnType->isVoidType()) {
+ if (RequireCompleteType(LBracLoc, ReturnType,
+ diag::err_illegal_message_expr_incomplete_type))
+ return ExprError();
+ }
// Construct the appropriate ObjCMessageExpr instance.
Expr *Result;
@@ -1018,11 +1024,6 @@
else
Result = ObjCMessageExpr::Create(Context, ReturnType, LBracLoc, Receiver,
Sel, Method, Args, NumArgs, RBracLoc);
- if (Context.getLangOptions().CPlusPlus && !ReturnType->isVoidType()) {
- if (RequireCompleteType(LBracLoc, ReturnType,
- diag::err_illegal_message_expr_incomplete_type))
- return ExprError();
- }
return MaybeBindToTemporary(Result);
}
More information about the cfe-commits
mailing list