]> granicus.if.org Git - clang/commitdiff
Add a missing ExpressionEvaluationContext for template default arguments. Fixes...
authorEli Friedman <eli.friedman@gmail.com>
Thu, 26 Apr 2012 22:43:24 +0000 (22:43 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Thu, 26 Apr 2012 22:43:24 +0000 (22:43 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@155670 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Parse/ParseTemplate.cpp
lib/Sema/SemaTemplate.cpp
test/SemaTemplate/default-expr-arguments.cpp

index f8204d9cda5ec5ecc73dfbcc40daa34dc8f082ac..5c3e2ba589ff457092e6b0181e17dfed9cd26547 100644 (file)
@@ -652,6 +652,7 @@ Parser::ParseNonTypeTemplateParameter(unsigned Depth, unsigned Position) {
     //   end of the template-parameter-list rather than a greater-than
     //   operator.
     GreaterThanIsOperatorScope G(GreaterThanIsOperator, false);
+    EnterExpressionEvaluationContext Unevaluated(Actions, Sema::Unevaluated);
 
     DefaultArg = ParseAssignmentExpression();
     if (DefaultArg.isInvalid())
index be590686491c8e6ae43fc1c0fad4f7a82dd7b2ab..b5b99f978ed766b4657a136e3b03dcf8a0116a11 100644 (file)
@@ -2562,6 +2562,7 @@ SubstDefaultTemplateArgument(Sema &SemaRef,
                                    SourceRange(TemplateLoc, RAngleLoc));
 
   Sema::ContextRAII SavedContext(SemaRef, Template->getDeclContext());
+  EnterExpressionEvaluationContext Unevaluated(SemaRef, Sema::Unevaluated);
   return SemaRef.SubstExpr(Param->getDefaultArgument(), AllTemplateArgs);
 }
 
index 5d301be2fb13733b2f25dfda804fc56ec792c8ba..1eefa9f8956b6da365f461ac496eff0a6e879028 100644 (file)
@@ -292,3 +292,14 @@ namespace PR8401 {
     f();
   }
 }
+
+namespace PR12581 {
+  const int a = 0;
+  template < typename > struct A;
+  template < typename MatrixType, int =
+  A < MatrixType >::Flags ? : A < MatrixType >::Flags & a > class B;
+  void
+  fn1 ()
+  {
+  }
+}