Index: cfe/trunk/lib/Sema/TreeTransform.h =================================================================== --- cfe/trunk/lib/Sema/TreeTransform.h +++ cfe/trunk/lib/Sema/TreeTransform.h @@ -6601,8 +6601,7 @@ // 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(); Index: cfe/trunk/test/SemaCXX/cxx1z-init-statement-template.cpp =================================================================== --- cfe/trunk/test/SemaCXX/cxx1z-init-statement-template.cpp +++ cfe/trunk/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); +}