diff options
author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2008-12-02 14:43:59 +0000 |
---|---|---|
committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2008-12-02 14:43:59 +0000 |
commit | 351bb78a10cbc4d7c5894366f16acebef7a038f2 (patch) | |
tree | e25cdf63c42ac39f2ff3e8e533066c77aa07be8b /clang/lib/AST | |
parent | 318ccb0e62ecd82d842d9b86a6b7dce31ecae21d (diff) | |
download | bcm5719-llvm-351bb78a10cbc4d7c5894366f16acebef7a038f2.tar.gz bcm5719-llvm-351bb78a10cbc4d7c5894366f16acebef7a038f2.zip |
Handle new by passing the Declaration to the Action, not a processed type.
llvm-svn: 60413
Diffstat (limited to 'clang/lib/AST')
-rw-r--r-- | clang/lib/AST/ExprCXX.cpp | 16 | ||||
-rw-r--r-- | clang/lib/AST/StmtPrinter.cpp | 3 | ||||
-rw-r--r-- | clang/lib/AST/StmtSerialization.cpp | 16 |
3 files changed, 21 insertions, 14 deletions
diff --git a/clang/lib/AST/ExprCXX.cpp b/clang/lib/AST/ExprCXX.cpp index c0f2985f1e9..1bf07c4a63e 100644 --- a/clang/lib/AST/ExprCXX.cpp +++ b/clang/lib/AST/ExprCXX.cpp @@ -80,30 +80,32 @@ Stmt::child_iterator CXXConditionDeclExpr::child_end() { // CXXNewExpr CXXNewExpr::CXXNewExpr(bool globalNew, FunctionDecl *operatorNew, Expr **placementArgs, unsigned numPlaceArgs, - bool parenTypeId, QualType alloc, + bool parenTypeId, Expr *arraySize, CXXConstructorDecl *constructor, bool initializer, Expr **constructorArgs, unsigned numConsArgs, FunctionDecl *operatorDelete, QualType ty, SourceLocation startLoc, SourceLocation endLoc) : Expr(CXXNewExprClass, ty), GlobalNew(globalNew), ParenTypeId(parenTypeId), - Initializer(initializer), NumPlacementArgs(numPlaceArgs), + Initializer(initializer), Array(arraySize), NumPlacementArgs(numPlaceArgs), NumConstructorArgs(numConsArgs), OperatorNew(operatorNew), - OperatorDelete(operatorDelete), Constructor(constructor), AllocType(alloc), + OperatorDelete(operatorDelete), Constructor(constructor), StartLoc(startLoc), EndLoc(endLoc) { - unsigned TotalSize = NumPlacementArgs + NumConstructorArgs; + unsigned TotalSize = Array + NumPlacementArgs + NumConstructorArgs; SubExprs = new Stmt*[TotalSize]; unsigned i = 0; - for(unsigned j = 0; j < NumPlacementArgs; ++j) + if (Array) + SubExprs[i++] = arraySize; + for (unsigned j = 0; j < NumPlacementArgs; ++j) SubExprs[i++] = placementArgs[j]; - for(unsigned j = 0; j < NumConstructorArgs; ++j) + for (unsigned j = 0; j < NumConstructorArgs; ++j) SubExprs[i++] = constructorArgs[j]; assert(i == TotalSize); } Stmt::child_iterator CXXNewExpr::child_begin() { return &SubExprs[0]; } Stmt::child_iterator CXXNewExpr::child_end() { - return &SubExprs[0] + getNumPlacementArgs() + getNumConstructorArgs(); + return &SubExprs[0] + Array + getNumPlacementArgs() + getNumConstructorArgs(); } // CXXDeleteExpr diff --git a/clang/lib/AST/StmtPrinter.cpp b/clang/lib/AST/StmtPrinter.cpp index b6f07070538..445e3e47552 100644 --- a/clang/lib/AST/StmtPrinter.cpp +++ b/clang/lib/AST/StmtPrinter.cpp @@ -953,6 +953,9 @@ void StmtPrinter::VisitCXXNewExpr(CXXNewExpr *E) { } if (E->isParenTypeId()) OS << "("; + // FIXME: This doesn't print the dynamic array size. We'd have to split up + // the allocated type to correctly emit that, but without an ASTContext, + // that's not possible. OS << E->getAllocatedType().getAsString(); if (E->isParenTypeId()) OS << ")"; diff --git a/clang/lib/AST/StmtSerialization.cpp b/clang/lib/AST/StmtSerialization.cpp index 40f5b3ffc5b..a8602245f3e 100644 --- a/clang/lib/AST/StmtSerialization.cpp +++ b/clang/lib/AST/StmtSerialization.cpp @@ -1444,7 +1444,10 @@ CXXZeroInitValueExpr::CreateImpl(Deserializer& D, ASTContext& C) { void CXXNewExpr::EmitImpl(Serializer& S) const { S.Emit(getType()); - S.Emit(Initializer); + S.EmitBool(GlobalNew); + S.EmitBool(ParenTypeId); + S.EmitBool(Initializer); + S.EmitBool(Array); S.EmitInt(NumPlacementArgs); S.EmitInt(NumConstructorArgs); S.BatchEmitOwnedPtrs(NumPlacementArgs + NumConstructorArgs, SubExprs); @@ -1455,7 +1458,6 @@ void CXXNewExpr::EmitImpl(Serializer& S) const { S.EmitPtr(OperatorNew); S.EmitPtr(OperatorDelete); S.EmitPtr(Constructor); - S.Emit(AllocType); S.Emit(StartLoc); S.Emit(EndLoc); } @@ -1466,19 +1468,19 @@ CXXNewExpr::CreateImpl(Deserializer& D, ASTContext& C) { bool GlobalNew = D.ReadBool(); bool ParenTypeId = D.ReadBool(); bool Initializer = D.ReadBool(); + bool Array = D.ReadBool(); unsigned NumPlacementArgs = D.ReadInt(); unsigned NumConstructorArgs = D.ReadInt(); - unsigned TotalExprs = NumPlacementArgs + NumConstructorArgs; + unsigned TotalExprs = Array + NumPlacementArgs + NumConstructorArgs; Stmt** SubExprs = new Stmt*[TotalExprs]; D.BatchReadOwnedPtrs(TotalExprs, SubExprs, C); FunctionDecl *OperatorNew = D.ReadPtr<FunctionDecl>(); FunctionDecl *OperatorDelete = D.ReadPtr<FunctionDecl>(); CXXConstructorDecl *Constructor = D.ReadPtr<CXXConstructorDecl>(); - QualType AllocType = QualType::ReadVal(D); SourceLocation StartLoc = SourceLocation::ReadVal(D); SourceLocation EndLoc = SourceLocation::ReadVal(D); - return new CXXNewExpr(T, AllocType, GlobalNew, ParenTypeId, Initializer, + return new CXXNewExpr(T, GlobalNew, ParenTypeId, Initializer, Array, NumPlacementArgs, NumConstructorArgs, SubExprs, OperatorNew, OperatorDelete, Constructor, StartLoc, EndLoc); @@ -1486,8 +1488,8 @@ CXXNewExpr::CreateImpl(Deserializer& D, ASTContext& C) { void CXXDeleteExpr::EmitImpl(Serializer& S) const { S.Emit(getType()); - S.Emit(GlobalDelete); - S.Emit(ArrayForm); + S.EmitBool(GlobalDelete); + S.EmitBool(ArrayForm); S.EmitPtr(OperatorDelete); S.EmitOwnedPtr(Argument); S.Emit(Loc); |