diff options
author | John McCall <rjmccall@apple.com> | 2012-04-06 18:20:53 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2012-04-06 18:20:53 +0000 |
commit | ed7b27830d75b611c324307f21f1fe52f3f871de (patch) | |
tree | 48957acd148d857a93fec4e4c938305070d4fd65 /clang/lib/Sema/TreeTransform.h | |
parent | 0e09facb85683f1004367cb11a90fc85f4a5c289 (diff) | |
download | bcm5719-llvm-ed7b27830d75b611c324307f21f1fe52f3f871de.tar.gz bcm5719-llvm-ed7b27830d75b611c324307f21f1fe52f3f871de.zip |
Fix a Sema invariant bug that I recently introduced involving
the template instantiation of statement-expressions.
I think it was jyasskin who had a crashing testcase in this area;
hopefully this fixes it and he can find his testcase and check it in.
llvm-svn: 154189
Diffstat (limited to 'clang/lib/Sema/TreeTransform.h')
-rw-r--r-- | clang/lib/Sema/TreeTransform.h | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index f16b667a658..fdb861eea51 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -6736,14 +6736,20 @@ TreeTransform<Derived>::TransformAddrLabelExpr(AddrLabelExpr *E) { template<typename Derived> ExprResult TreeTransform<Derived>::TransformStmtExpr(StmtExpr *E) { + SemaRef.ActOnStartStmtExpr(); StmtResult SubStmt = getDerived().TransformCompoundStmt(E->getSubStmt(), true); - if (SubStmt.isInvalid()) + if (SubStmt.isInvalid()) { + SemaRef.ActOnStmtExprError(); return ExprError(); + } if (!getDerived().AlwaysRebuild() && - SubStmt.get() == E->getSubStmt()) + SubStmt.get() == E->getSubStmt()) { + // Calling this an 'error' is unintuitive, but it does the right thing. + SemaRef.ActOnStmtExprError(); return SemaRef.MaybeBindToTemporary(E); + } return getDerived().RebuildStmtExpr(E->getLParenLoc(), SubStmt.get(), |