summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST/StmtSerialization.cpp
diff options
context:
space:
mode:
authorSebastian Redl <sebastian.redl@getdesigned.at>2008-11-11 17:56:53 +0000
committerSebastian Redl <sebastian.redl@getdesigned.at>2008-11-11 17:56:53 +0000
commit6f28289aca5bf15feb49b95e73f80cf9af99cdb3 (patch)
tree71037f611a5ba7b910255fcfb6a419cf159d8ee7 /clang/lib/AST/StmtSerialization.cpp
parent5499e89d06ba27f89dbffb028cbce72e3a3c95ed (diff)
downloadbcm5719-llvm-6f28289aca5bf15feb49b95e73f80cf9af99cdb3.tar.gz
bcm5719-llvm-6f28289aca5bf15feb49b95e73f80cf9af99cdb3.zip
Introduce a single AST node SizeOfAlignOfExpr for all sizeof and alignof expressions, both of values and types.
llvm-svn: 59057
Diffstat (limited to 'clang/lib/AST/StmtSerialization.cpp')
-rw-r--r--clang/lib/AST/StmtSerialization.cpp25
1 files changed, 18 insertions, 7 deletions
diff --git a/clang/lib/AST/StmtSerialization.cpp b/clang/lib/AST/StmtSerialization.cpp
index 39828815769..f71b88b46f1 100644
--- a/clang/lib/AST/StmtSerialization.cpp
+++ b/clang/lib/AST/StmtSerialization.cpp
@@ -136,8 +136,8 @@ Stmt* Stmt::Create(Deserializer& D, ASTContext& C) {
case ReturnStmtClass:
return ReturnStmt::CreateImpl(D, C);
- case SizeOfAlignOfTypeExprClass:
- return SizeOfAlignOfTypeExpr::CreateImpl(D, C);
+ case SizeOfAlignOfExprClass:
+ return SizeOfAlignOfExpr::CreateImpl(D, C);
case StmtExprClass:
return StmtExpr::CreateImpl(D, C);
@@ -795,22 +795,33 @@ ReturnStmt* ReturnStmt::CreateImpl(Deserializer& D, ASTContext& C) {
return new ReturnStmt(RetLoc,RetExpr);
}
-void SizeOfAlignOfTypeExpr::EmitImpl(Serializer& S) const {
+void SizeOfAlignOfExpr::EmitImpl(Serializer& S) const {
S.EmitBool(isSizeof);
- S.Emit(Ty);
+ S.EmitBool(isType);
+ if (isType)
+ S.Emit(getArgumentType());
+ else
+ S.EmitOwnedPtr(getArgumentExpr());
S.Emit(getType());
S.Emit(OpLoc);
S.Emit(RParenLoc);
}
-SizeOfAlignOfTypeExpr* SizeOfAlignOfTypeExpr::CreateImpl(Deserializer& D, ASTContext& C) {
+SizeOfAlignOfExpr*
+SizeOfAlignOfExpr::CreateImpl(Deserializer& D, ASTContext& C) {
bool isSizeof = D.ReadBool();
- QualType Ty = QualType::ReadVal(D);
+ bool isType = D.ReadBool();
+ void *Argument;
+ if (isType)
+ Argument = QualType::ReadVal(D).getAsOpaquePtr();
+ else
+ Argument = D.ReadOwnedPtr<Expr>(C);
QualType Res = QualType::ReadVal(D);
SourceLocation OpLoc = SourceLocation::ReadVal(D);
SourceLocation RParenLoc = SourceLocation::ReadVal(D);
- return new SizeOfAlignOfTypeExpr(isSizeof,Ty,Res,OpLoc,RParenLoc);
+ return new SizeOfAlignOfExpr(isSizeof, isType, Argument, Res,
+ OpLoc, RParenLoc);
}
void StmtExpr::EmitImpl(Serializer& S) const {
OpenPOWER on IntegriCloud