Fix bug where we would report the wrong value for __alignof__ with an expr that is not a type.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@47259 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Anders Carlsson 2008-02-18 07:10:45 +00:00
Родитель b7894b57a1
Коммит 64a31ef8d4
1 изменённых файлов: 6 добавлений и 5 удалений

Просмотреть файл

@ -736,15 +736,16 @@ bool Expr::isIntegerConstantExpr(llvm::APSInt &Result, ASTContext &Ctx,
if (Exp->getSubExpr()->getType()->isFunctionType()) { if (Exp->getSubExpr()->getType()->isFunctionType()) {
// GCC extension: sizeof(function) = 1. // GCC extension: sizeof(function) = 1.
Result = Exp->getOpcode() == UnaryOperator::AlignOf ? 4 : 1; Result = Exp->getOpcode() == UnaryOperator::AlignOf ? 4 : 1;
} else if (Exp->getOpcode() == UnaryOperator::AlignOf) {
Result = Ctx.getTypeAlign(Exp->getSubExpr()->getType(),
Exp->getOperatorLoc());
} else { } else {
unsigned CharSize = unsigned CharSize =
Ctx.Target.getCharWidth(Ctx.getFullLoc(Exp->getOperatorLoc())); Ctx.Target.getCharWidth(Ctx.getFullLoc(Exp->getOperatorLoc()));
Result = Ctx.getTypeSize(Exp->getSubExpr()->getType(), if (Exp->getOpcode() == UnaryOperator::AlignOf)
Exp->getOperatorLoc()) / CharSize; Result = Ctx.getTypeAlign(Exp->getSubExpr()->getType(),
Exp->getOperatorLoc()) / CharSize;
else
Result = Ctx.getTypeSize(Exp->getSubExpr()->getType(),
Exp->getOperatorLoc()) / CharSize;
} }
break; break;
case UnaryOperator::LNot: { case UnaryOperator::LNot: {