re PR c++/64970 (Hard error instead of SFINAE for expression in nested template alias)
authorPaolo Carlini <paolo.carlini@oracle.com>
Fri, 13 Feb 2015 14:54:48 +0000 (14:54 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Fri, 13 Feb 2015 14:54:48 +0000 (14:54 +0000)
/cp
2015-02-13  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/64970
* decl.c (make_typename_type): Pass tsubst_flags_t argument
to lookup_template_class.

/testsuite
2015-02-13  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/64970
* g++.dg/cpp0x/sfinae55.C: New.

From-SVN: r220684

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/sfinae55.C [new file with mode: 0644]

index 8132e2feee6d49dac21d934890c636bfcdc5c0e1..a39acaab7593755fb97ff49dfd44a9fe5a63a250 100644 (file)
@@ -1,3 +1,9 @@
+2015-02-13  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/64970
+       * decl.c (make_typename_type): Pass tsubst_flags_t argument
+       to lookup_template_class.
+
 2015-02-13  Jakub Jelinek  <jakub@redhat.com>
 
        PR ipa/65034
index f95a61a4487a09c76074d02e98b71613c87e9353..bc481bfe2f5091aae1315b45a9bc9350ec7e7976 100644 (file)
@@ -3569,7 +3569,7 @@ make_typename_type (tree context, tree name, enum tag_types tag_type,
     return lookup_template_class (t, TREE_OPERAND (fullname, 1),
                                  NULL_TREE, context,
                                  /*entering_scope=*/0,
-                                 tf_warning_or_error | tf_user);
+                                 complain | tf_user);
   
   if (DECL_ARTIFICIAL (t) || !(complain & tf_keep_type_decl))
     t = TREE_TYPE (t);
index 5c9ff2e2f94e0073643855314047b0a7b1bd1a6f..efdc9dce3178d315562558d4843dcccd281dfd70 100644 (file)
@@ -1,3 +1,8 @@
+2015-02-13  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/64970
+       * g++.dg/cpp0x/sfinae55.C: New.
+
 2015-02-13  Jakub Jelinek  <jakub@redhat.com>
 
        PR ipa/65034
diff --git a/gcc/testsuite/g++.dg/cpp0x/sfinae55.C b/gcc/testsuite/g++.dg/cpp0x/sfinae55.C
new file mode 100644 (file)
index 0000000..7b6557e
--- /dev/null
@@ -0,0 +1,33 @@
+// PR c++/64970
+// { dg-do compile { target c++11 } }
+
+template<typename T>
+T && declval();
+
+template<typename T>
+struct void_ { using type = void; };
+
+template<typename T>
+using void_t = typename void_<T>::type;
+
+template<class A, class B>
+struct Outer
+{
+    template<class C, class D>
+    using Inner = decltype(true ? declval<C>() : declval<D>());
+};
+
+template<class A, class B, typename Enable = void>
+struct S
+{};
+
+template<class A, class B>
+struct S<A, B, void_t<typename Outer<A, B>::template Inner<A, B>>>
+{};
+
+struct A{};
+struct B{};
+int main()
+{
+    S<A, B> s;
+}