re PR c++/65333 (error: incomplete type used in nested name specifier)
authorJason Merrill <jason@redhat.com>
Tue, 10 Mar 2015 17:44:48 +0000 (13:44 -0400)
committerJason Merrill <jason@gcc.gnu.org>
Tue, 10 Mar 2015 17:44:48 +0000 (13:44 -0400)
PR c++/65333
DR 1558
* pt.c (dependent_type_p_r): Check both class and alias template args.

From-SVN: r221328

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

index d354e07d2792d802b579d9c80350484db2e6611d..61c0b18e5ea3f6f22f5b2852e52c0e93cfc5bbf8 100644 (file)
@@ -1,3 +1,9 @@
+2015-03-10  Jason Merrill  <jason@redhat.com>
+
+       PR c++/65333
+       DR 1558
+       * pt.c (dependent_type_p_r): Check both class and alias template args.
+
 2015-03-10  Jakub Jelinek  <jakub@redhat.com>
 
        PR c/65120
index 9a00d0d30e6b79e85fe088dfd272f42189e44bb6..ea826211996f19dc45ded05b8d0e57a9f4164a0d 100644 (file)
@@ -20930,7 +20930,13 @@ dependent_type_p_r (tree type)
     return true;
   /* ... or any of the template arguments is a dependent type or
        an expression that is type-dependent or value-dependent.  */
-  else if (TYPE_TEMPLATE_INFO (type)
+  else if (CLASS_TYPE_P (type) && CLASSTYPE_TEMPLATE_INFO (type)
+          && (any_dependent_template_arguments_p
+              (INNERMOST_TEMPLATE_ARGS (CLASSTYPE_TI_ARGS (type)))))
+    return true;
+  /* For an alias template specialization, check the arguments both to the
+     class template and the alias template.  */
+  else if (alias_template_specialization_p (type)
           && (any_dependent_template_arguments_p
               (INNERMOST_TEMPLATE_ARGS (TYPE_TI_ARGS (type)))))
     return true;
diff --git a/gcc/testsuite/g++.dg/cpp0x/alias-decl-47.C b/gcc/testsuite/g++.dg/cpp0x/alias-decl-47.C
new file mode 100644 (file)
index 0000000..71611db
--- /dev/null
@@ -0,0 +1,13 @@
+// PR c++/65333
+// { dg-do compile { target c++11 } }
+
+template <typename T, T... Values> struct A
+{
+  using type = int;
+  template <type... Suffix> using array = A<type, Values..., Suffix...>;
+  void
+  m_fn1 ()
+  {
+    array<>::data;
+  }
+};