[cfe-commits] r96687 - in /cfe/trunk: include/clang/Basic/DiagnosticSemaKinds.td lib/Sema/SemaExpr.cpp test/SemaObjC/property-user-setter.m
Fariborz Jahanian
fjahanian at apple.com
Fri Feb 19 10:30:31 PST 2010
Author: fjahanian
Date: Fri Feb 19 12:30:30 2010
New Revision: 96687
URL: http://llvm.org/viewvc/llvm-project?rev=96687&view=rev
Log:
Issue extended diagnostic when property dot-syntax is used and
there is a setter but no getter (part of radar 7664555).
Modified:
cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
cfe/trunk/lib/Sema/SemaExpr.cpp
cfe/trunk/test/SemaObjC/property-user-setter.m
Modified: cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td?rev=96687&r1=96686&r2=96687&view=diff
==============================================================================
--- cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td (original)
+++ cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td Fri Feb 19 12:30:30 2010
@@ -2704,6 +2704,8 @@
def err_c99_array_usage_cxx : Error<
"C99-specific array features are not permitted in C++">;
+def note_getter_unavailable : Note<
+ "or because setter is declared here, but no getter method %0 is found">;
def err_invalid_protocol_qualifiers : Error<
"invalid protocol qualifiers on non-ObjC type">;
def warn_ivar_use_hidden : Warning<
Modified: cfe/trunk/lib/Sema/SemaExpr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaExpr.cpp?rev=96687&r1=96686&r2=96687&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaExpr.cpp (original)
+++ cfe/trunk/lib/Sema/SemaExpr.cpp Fri Feb 19 12:30:30 2010
@@ -3147,9 +3147,12 @@
return LookupMemberExpr(Res, BaseExpr, IsArrow, OpLoc, SS,
ObjCImpDecl);
}
-
- return ExprError(Diag(MemberLoc, diag::err_property_not_found)
- << MemberName << BaseType);
+ Diag(MemberLoc, diag::err_property_not_found)
+ << MemberName << BaseType;
+ if (Setter && !Getter)
+ Diag(Setter->getLocation(), diag::note_getter_unavailable)
+ << MemberName << BaseExpr->getSourceRange();
+ return ExprError();
}
// Handle the following exceptional case (*Obj).isa.
@@ -3168,7 +3171,7 @@
return Owned(new (Context) ExtVectorElementExpr(ret, BaseExpr, *Member,
MemberLoc));
}
-
+
Diag(MemberLoc, diag::err_typecheck_member_reference_struct_union)
<< BaseType << BaseExpr->getSourceRange();
Modified: cfe/trunk/test/SemaObjC/property-user-setter.m
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaObjC/property-user-setter.m?rev=96687&r1=96686&r2=96687&view=diff
==============================================================================
--- cfe/trunk/test/SemaObjC/property-user-setter.m (original)
+++ cfe/trunk/test/SemaObjC/property-user-setter.m Fri Feb 19 12:30:30 2010
@@ -70,7 +70,7 @@
{
int setterOnly;
}
-- (void) setSetterOnly:(int)value;
+- (void) setSetterOnly:(int)value; // expected-note {{or because setter is declared here, but no getter method 'setterOnly' is found}}
@end
@implementation Subclass
@@ -82,7 +82,7 @@
@interface C {}
// - (int)Foo;
-- (void)setFoo:(int)value;
+- (void)setFoo:(int)value; // expected-note 2 {{or because setter is declared here, but no getter method 'Foo' is found}}
@end
void g(int);
More information about the cfe-commits
mailing list