Use an ASTRecordLayout to compute the sizeof an interface, not

addRecordToClass.
 - Among other things, this fixes a crash when applying sizeof to an
   interface with synthesized ivars, although things still aren't
   "correct" here.

llvm-svn: 69675
This commit is contained in:
Daniel Dunbar 2009-04-21 15:48:54 +00:00
parent 426662ba79
commit 93c1914de3
2 changed files with 42 additions and 7 deletions

View File

@ -1079,18 +1079,18 @@ bool IntExprEvaluator::VisitSizeOfAlignOfExpr(const SizeOfAlignOfExpr *E) {
if (!SrcTy->isConstantSizeType())
return false;
unsigned BitWidth = 0;
if (SrcTy->isObjCInterfaceType()) {
// Slightly unusual case: the size of an ObjC interface type is the
// size of the class. This code intentionally falls through to the normal
// case.
// size of the class.
ObjCInterfaceDecl *OI = SrcTy->getAsObjCInterfaceType()->getDecl();
RecordDecl *RD = const_cast<RecordDecl*>(Info.Ctx.addRecordToClass(OI));
SrcTy = Info.Ctx.getTagDeclType(static_cast<TagDecl*>(RD));
}
const ASTRecordLayout &Layout = Info.Ctx.getASTObjCInterfaceLayout(OI);
BitWidth = Layout.getSize();
} else
BitWidth = Info.Ctx.getTypeSize(SrcTy);
// Get information about the size.
unsigned CharSize = Info.Ctx.Target.getCharWidth();
return Success(Info.Ctx.getTypeSize(SrcTy) / CharSize, E);
return Success(BitWidth / Info.Ctx.Target.getCharWidth(), E);
}
bool IntExprEvaluator::VisitUnaryOperator(const UnaryOperator *E) {

View File

@ -0,0 +1,35 @@
// RUN: clang-cc -triple x86_64-apple-darwin9 -fsyntax-only %t
@class I0;
// FIXME: Reject sizeof on incomplete interface; this breaks the test!
//int g0 = sizeof(I0); // exxpected-error{{invalid application of 'sizeof' to an incomplete type ...}}
@interface I0 {
char x[4];
}
@property int p0;
@end
// size == 4
int g1[ sizeof(I0) == 4 ? 1 : -1];
@implementation I0
@synthesize p0 = _p0;
@end
// size == 4 (we do not include extended properties in the
// sizeof).
int g2[ sizeof(I0) == 4 ? 1 : -1];
@interface I1
@property int p0;
@end
@implementation I1
@synthesize p0 = _p0;
@end
// FIXME: This is currently broken due to the way the record layout we
// create is tied to whether we have seen synthesized properties. Ugh.
// int g3[ sizeof(I1) == 0 ? 1 : -1];