From: Volodymyr Sapsai Date: Thu, 21 Sep 2017 17:58:27 +0000 (+0000) Subject: [Sema] Fix using old initializer during switch statement transformation. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b46bc42555b1af8974fb686f2e427a86d3d0e088;p=clang [Sema] Fix using old initializer during switch statement transformation. It fixes a crash in CodeGen when we are trying to generate code for initializer expression created before template instantiation, like CallExpr '' |-UnresolvedLookupExpr '' lvalue (ADL) = 'parse' `-DeclRefExpr 'Buffer' lvalue ParmVar 'buffer' 'Buffer' rdar://problem/33888545 Reviewers: rsmith, ahatanak Reviewed By: ahatanak Subscribers: aemerson, kristof.beyls, cfe-commits Differential Revision: https://reviews.llvm.org/D38009 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@313896 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/TreeTransform.h b/lib/Sema/TreeTransform.h index ee67e15b9a..6fb9eca9a9 100644 --- a/lib/Sema/TreeTransform.h +++ b/lib/Sema/TreeTransform.h @@ -6601,8 +6601,7 @@ TreeTransform::TransformSwitchStmt(SwitchStmt *S) { // Rebuild the switch statement. StmtResult Switch - = getDerived().RebuildSwitchStmtStart(S->getSwitchLoc(), - S->getInit(), Cond); + = getDerived().RebuildSwitchStmtStart(S->getSwitchLoc(), Init.get(), Cond); if (Switch.isInvalid()) return StmtError(); diff --git a/test/SemaCXX/cxx1z-init-statement-template.cpp b/test/SemaCXX/cxx1z-init-statement-template.cpp new file mode 100644 index 0000000000..cedd2c720d --- /dev/null +++ b/test/SemaCXX/cxx1z-init-statement-template.cpp @@ -0,0 +1,32 @@ +// RUN: %clang_cc1 -std=c++1z -verify -emit-llvm-only %s +// expected-no-diagnostics + +// rdar://problem/33888545 +template class Buffer {}; + +class A { +public: + int status; +}; + +template A parse(Buffer buffer); + +template +void init_in_if(Buffer buffer) { + if (A a = parse(buffer); a.status > 0) { + } +} + +template +void init_in_switch(Buffer buffer) { + switch (A a = parse(buffer); a.status) { + default: + break; + } +} + +void test() { + Buffer<10> buffer; + init_in_if(buffer); + init_in_switch(buffer); +}