Index: cfe/trunk/lib/Sema/TreeTransform.h =================================================================== --- cfe/trunk/lib/Sema/TreeTransform.h +++ cfe/trunk/lib/Sema/TreeTransform.h @@ -10356,6 +10356,18 @@ LSI->CallOperator = NewCallOperator; + for (unsigned I = 0, NumParams = NewCallOperator->getNumParams(); + I != NumParams; ++I) { + auto *P = NewCallOperator->getParamDecl(I); + if (P->hasUninstantiatedDefaultArg()) { + EnterExpressionEvaluationContext Eval( + getSema(), Sema::PotentiallyEvaluatedIfUsed, P); + ExprResult R = getDerived().TransformExpr( + E->getCallOperator()->getParamDecl(I)->getDefaultArg()); + P->setDefaultArg(R.get()); + } + } + getDerived().transformAttrs(E->getCallOperator(), NewCallOperator); getDerived().transformedLocalDecl(E->getCallOperator(), NewCallOperator); Index: cfe/trunk/test/SemaCXX/vartemplate-lambda.cpp =================================================================== --- cfe/trunk/test/SemaCXX/vartemplate-lambda.cpp +++ cfe/trunk/test/SemaCXX/vartemplate-lambda.cpp @@ -1,18 +1,36 @@ // RUN: %clang_cc1 -std=c++14 -fsyntax-only -verify %s -// expected-no-diagnostics template auto fn0 = [] {}; template void foo0() { fn0(); } template auto fn1 = [](auto a) { return a + T(1); }; +template auto v1 = [](int a = T(1)) { return a; }(); + +struct S { + template + static constexpr T t = [](int f = T(7)){return f;}(); // expected-error{{constexpr variable 't' must be initialized by a constant expression}} expected-error{{a lambda expression may not appear inside of a constant expression}} expected-note{{cannot be used in a constant expression}} +}; template int foo2() { X a = 0x61; fn1(a); + (void)v1; + (void)S::t; // expected-note{{in instantiation of static data member 'S::t' requested here}} return 0; } +template +int foo3() { + C::m1(); // expected-error{{type 'long long' cannot be used prior to '::' because it has no members}} + return 1; +} + +template +auto v2 = [](int a = foo3()){}; // expected-note{{in instantiation of function template specialization 'foo3' requested here}} + int main() { + v2(); // This line causes foo3 to be instantiated. + v2(2); // This line does not. foo2(); }