diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-12-03 03:49:52 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-12-03 03:49:52 +0000 |
commit | 8bc27822fc867d43399d4474bccbb58b7b7c7ad7 (patch) | |
tree | c2f70b8b1461eb509604f1538c98e4ec336973de /lib/Serialization/ASTReaderStmt.cpp | |
parent | d977e6b0eb4c9b57b0aad6e9e0be39cc67b3a8c7 (diff) |
[PCH] Make sure that the SourceExpr of a OpaqueValueExpr is always initialized
when deserialized, fixing random crashes in libclang.
Also simplifies how OpaqueValueExprs are [de]serialized.
The reader/writer automatically retains pointer equality of sub-statements (when a
statement node is referenced in multiple nodes), so no need to manually handle it.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@145752 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Serialization/ASTReaderStmt.cpp')
-rw-r--r-- | lib/Serialization/ASTReaderStmt.cpp | 21 |
1 files changed, 3 insertions, 18 deletions
diff --git a/lib/Serialization/ASTReaderStmt.cpp b/lib/Serialization/ASTReaderStmt.cpp index 91a6e1922f..65081c3560 100644 --- a/lib/Serialization/ASTReaderStmt.cpp +++ b/lib/Serialization/ASTReaderStmt.cpp @@ -568,8 +568,6 @@ ASTStmtReader::VisitBinaryConditionalOperator(BinaryConditionalOperator *E) { E->SubExprs[BinaryConditionalOperator::RHS] = Reader.ReadSubExpr(); E->QuestionLoc = ReadSourceLocation(Record, Idx); E->ColonLoc = ReadSourceLocation(Record, Idx); - - E->getOpaqueValue()->setSourceExpr(E->getCommon()); } void ASTStmtReader::VisitImplicitCastExpr(ImplicitCastExpr *E) { @@ -787,8 +785,6 @@ void ASTStmtReader::VisitPseudoObjectExpr(PseudoObjectExpr *E) { // Read all the semantic expressions. for (unsigned i = 0; i != numSemanticExprs; ++i) { Expr *subExpr = Reader.ReadSubExpr(); - if (isa<OpaqueValueExpr>(subExpr)) - cast<OpaqueValueExpr>(subExpr)->setSourceExpr(Reader.ReadSubExpr()); E->getSubExprsBuffer()[i+1] = subExpr; } } @@ -1376,7 +1372,7 @@ void ASTStmtReader::VisitMaterializeTemporaryExpr(MaterializeTemporaryExpr *E) { void ASTStmtReader::VisitOpaqueValueExpr(OpaqueValueExpr *E) { VisitExpr(E); - Idx++; // skip ID + E->SourceExpr = Reader.ReadSubExpr(); E->Loc = ReadSourceLocation(Record, Idx); } @@ -2055,20 +2051,9 @@ Stmt *ASTReader::ReadStmtFromStream(ModuleFile &F) { S = new (Context) MaterializeTemporaryExpr(Empty); break; - case EXPR_OPAQUE_VALUE: { - unsigned key = Record[ASTStmtReader::NumExprFields]; - OpaqueValueExpr *&expr = OpaqueValueExprs[key]; - - // If we already have an entry for this opaque value expression, - // don't bother reading it again. - if (expr) { - StmtStack.push_back(expr); - continue; - } - - S = expr = new (Context) OpaqueValueExpr(Empty); + case EXPR_OPAQUE_VALUE: + S = new (Context) OpaqueValueExpr(Empty); break; - } case EXPR_CUDA_KERNEL_CALL: S = new (Context) CUDAKernelCallExpr(Context, Empty); |