decl.c (select_decl): Allow class templates when we need types.
authorMartin v. Löwis <loewis@informatik.hu-berlin.de>
Fri, 12 Mar 1999 23:17:05 +0000 (23:17 +0000)
committerMartin v. Löwis <loewis@gcc.gnu.org>
Fri, 12 Mar 1999 23:17:05 +0000 (23:17 +0000)
        * decl.c (select_decl): Allow class templates when we need types.
        * decl2.c (ambiguous_decl): Likewise.

From-SVN: r25737

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/cp/decl2.c

index e43e9c8..d24c458 100644 (file)
@@ -1,3 +1,8 @@
+1999-03-12  Martin von Löwis  <loewis@informatik.hu-berlin.de>
+
+       * decl.c (select_decl): Allow class templates when we need types.
+       * decl2.c (ambiguous_decl): Likewise.
+
 1999-03-12  Mark Mitchell  <mark@markmitchell.com>
 
        * lex.c (do_identifier): Correct call to enforce_access.
index 9a51e65..5eca402 100644 (file)
@@ -5246,7 +5246,8 @@ select_decl (binding, flags)
     val = TYPE_STUB_DECL (BINDING_TYPE (binding));
   /* Don't return non-types if we really prefer types. */
   else if (val && LOOKUP_TYPES_ONLY (flags)  && TREE_CODE (val) != TYPE_DECL
-          && (!looking_for_template || TREE_CODE (val) != TEMPLATE_DECL))
+          && (TREE_CODE (val) != TEMPLATE_DECL
+              || !DECL_CLASS_TEMPLATE_P (val)))
     val = NULL_TREE;
 
   return val;
index d9c1591..56f5839 100644 (file)
@@ -4063,8 +4063,7 @@ ambiguous_decl (name, old, new, flags)
         /* If we expect types or namespaces, and not templates,
            or this is not a template class. */
         if (LOOKUP_QUALIFIERS_ONLY (flags)
-            && (!(flags & LOOKUP_TEMPLATES_EXPECTED)
-                || !DECL_CLASS_TEMPLATE_P (val)))
+            && !DECL_CLASS_TEMPLATE_P (val))
           val = NULL_TREE;
         break;
       case TYPE_DECL: