Don't poke into redefined 'id' type looking for a property

declaration as this results in a confusing error message,
instead of message related to missing property declaration.
// rdar://9106929

llvm-svn: 127682
This commit is contained in:
Fariborz Jahanian 2011-03-15 17:27:48 +00:00
parent 024932fc77
commit b03a4c23c2
2 changed files with 36 additions and 2 deletions

View File

@ -3905,8 +3905,9 @@ Sema::LookupMemberExpr(LookupResult &R, Expr *&BaseExpr,
MemberLoc, BaseExpr));
}
}
if (ShouldTryAgainWithRedefinitionType(*this, BaseExpr))
// Use of id.member can only be for a property reference. Do not
// use the 'id' redefinition in this case.
if (IsArrow && ShouldTryAgainWithRedefinitionType(*this, BaseExpr))
return LookupMemberExpr(R, BaseExpr, IsArrow, OpLoc, SS,
ObjCImpDecl, HasTemplateArgs);

View File

@ -0,0 +1,33 @@
// RUN: %clang_cc1 -fsyntax-only -verify %s
// rdar://9106929
typedef struct objc_class *Class;
typedef struct objc_object {
Class isa;
} *id;
typedef struct __FSEventStream* FSEventStreamRef;
extern id NSApp;
@interface FileSystemMonitor {
FSEventStreamRef fsEventStream;
}
@property(assign) FSEventStreamRef fsEventStream;
@end
@implementation FileSystemMonitor
@synthesize fsEventStream;
- (void)startFSEventGathering:(id)sender
{
fsEventStream = [NSApp delegate].fsEventStream; // expected-warning {{warning: method '-delegate' not found (return type defaults to 'id')}} \
// expected-error {{property 'fsEventStream' not found on object of type 'id'}}
}
@end