diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-09-13 20:15:54 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-09-13 20:15:54 +0000 |
commit | 14ec9f674a566cc11a31fbb95cb7486869795a74 (patch) | |
tree | f447f1653b9be91adce411bb3d528d7934c67711 /clang/lib/Serialization | |
parent | 9b0d1cf47c041942b24c1e98e85648bdcc6174f1 (diff) | |
download | bcm5719-llvm-14ec9f674a566cc11a31fbb95cb7486869795a74.tar.gz bcm5719-llvm-14ec9f674a566cc11a31fbb95cb7486869795a74.zip |
When applying 'delete' on a pointer-to-array type match GCC and EDG behavior and treat it as 'delete[]'.
Also offer a fix-it hint adding '[]'.
llvm-svn: 113778
Diffstat (limited to 'clang/lib/Serialization')
-rw-r--r-- | clang/lib/Serialization/ASTReaderStmt.cpp | 1 | ||||
-rw-r--r-- | clang/lib/Serialization/ASTWriterStmt.cpp | 1 |
2 files changed, 2 insertions, 0 deletions
diff --git a/clang/lib/Serialization/ASTReaderStmt.cpp b/clang/lib/Serialization/ASTReaderStmt.cpp index e53bf716a8c..a6da3c7296a 100644 --- a/clang/lib/Serialization/ASTReaderStmt.cpp +++ b/clang/lib/Serialization/ASTReaderStmt.cpp @@ -1112,6 +1112,7 @@ void ASTStmtReader::VisitCXXDeleteExpr(CXXDeleteExpr *E) { VisitExpr(E); E->GlobalDelete = Record[Idx++]; E->ArrayForm = Record[Idx++]; + E->ArrayFormAsWritten = Record[Idx++]; E->OperatorDelete = cast_or_null<FunctionDecl>(Reader.GetDecl(Record[Idx++])); E->Argument = Reader.ReadSubExpr(); E->Loc = Reader.ReadSourceLocation(Record, Idx); diff --git a/clang/lib/Serialization/ASTWriterStmt.cpp b/clang/lib/Serialization/ASTWriterStmt.cpp index b9a22842b9c..3701e0c146e 100644 --- a/clang/lib/Serialization/ASTWriterStmt.cpp +++ b/clang/lib/Serialization/ASTWriterStmt.cpp @@ -1121,6 +1121,7 @@ void ASTStmtWriter::VisitCXXDeleteExpr(CXXDeleteExpr *E) { VisitExpr(E); Record.push_back(E->isGlobalDelete()); Record.push_back(E->isArrayForm()); + Record.push_back(E->isArrayFormAsWritten()); Writer.AddDeclRef(E->getOperatorDelete(), Record); Writer.AddStmt(E->getArgument()); Writer.AddSourceLocation(E->getSourceRange().getBegin(), Record); |