forked from OSchip/llvm-project
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:
parent
426662ba79
commit
93c1914de3
|
@ -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) {
|
||||
|
|
|
@ -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];
|
Loading…
Reference in New Issue