From 2a36089eef6bf8c1c4937cf6be4ce802a728c369 Mon Sep 17 00:00:00 2001 From: Fariborz Jahanian Date: Mon, 19 Jul 2010 16:14:33 +0000 Subject: [PATCH] Categories cannot synthesize property ivars, and a minor cleanup. llvm-svn: 108707 --- clang/lib/Sema/SemaExpr.cpp | 10 +++++----- clang/test/SemaObjC/synth-provisional-ivars.m | 5 +++++ 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 2d3aaf6edc05..447dc387320c 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -1006,7 +1006,6 @@ bool Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R, } static ObjCIvarDecl *SynthesizeProvisionalIvar(Sema &SemaRef, - ASTContext &Context, IdentifierInfo *II, SourceLocation NameLoc) { ObjCMethodDecl *CurMeth = SemaRef.getCurMethodDecl(); @@ -1014,7 +1013,8 @@ static ObjCIvarDecl *SynthesizeProvisionalIvar(Sema &SemaRef, if (!IDecl) return 0; ObjCImplementationDecl *ClassImpDecl = IDecl->getImplementation(); - assert(ClassImpDecl && "Method not inside @implementation"); + if (!ClassImpDecl) + return 0; bool DynamicImplSeen = false; ObjCPropertyDecl *property = SemaRef.LookupPropertyDecl(IDecl, II); if (!property) @@ -1023,8 +1023,8 @@ static ObjCIvarDecl *SynthesizeProvisionalIvar(Sema &SemaRef, DynamicImplSeen = (PIDecl->getPropertyImplementation() == ObjCPropertyImplDecl::Dynamic); if (!DynamicImplSeen) { - QualType PropType = Context.getCanonicalType(property->getType()); - ObjCIvarDecl *Ivar = ObjCIvarDecl::Create(Context, ClassImpDecl, + QualType PropType = SemaRef.Context.getCanonicalType(property->getType()); + ObjCIvarDecl *Ivar = ObjCIvarDecl::Create(SemaRef.Context, ClassImpDecl, NameLoc, II, PropType, /*Dinfo=*/0, ObjCIvarDecl::Protected, @@ -1104,7 +1104,7 @@ Sema::OwningExprResult Sema::ActOnIdExpression(Scope *S, if (Ex) return Owned(Ex); // Synthesize ivars lazily if (getLangOptions().ObjCNonFragileABI2) { - if (SynthesizeProvisionalIvar(*this, Context, II, NameLoc)) + if (SynthesizeProvisionalIvar(*this, II, NameLoc)) return ActOnIdExpression(S, SS, Id, HasTrailingLParen, isAddressOfOperand); } diff --git a/clang/test/SemaObjC/synth-provisional-ivars.m b/clang/test/SemaObjC/synth-provisional-ivars.m index 2a1a6b15fa54..6ed424dae87e 100644 --- a/clang/test/SemaObjC/synth-provisional-ivars.m +++ b/clang/test/SemaObjC/synth-provisional-ivars.m @@ -38,3 +38,8 @@ int bar; - (int) Meth6 { return bar1; } @end + +@implementation I(CAT) +- (int) Meth { return PROP1; } // expected-error {{use of undeclared identifier 'PROP1'}} +@end + -- GitLab