OSDN Git Service

PR c++/32898
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 23 Aug 2007 23:27:34 +0000 (23:27 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 23 Aug 2007 23:27:34 +0000 (23:27 +0000)
* name-lookup.c (set_decl_namespace): lookup_qualified_name failure
is error_mark_node rather than NULL_TREE.
* pt.c (check_explicit_specialization): Likewise.

* g++.dg/lookup/ns3.C: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@127749 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/name-lookup.c
gcc/cp/pt.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/lookup/ns3.C [new file with mode: 0644]

index 19c149d..e39c0a1 100644 (file)
@@ -1,5 +1,10 @@
 2007-08-24  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c++/32898
+       * name-lookup.c (set_decl_namespace): lookup_qualified_name failure
+       is error_mark_node rather than NULL_TREE.
+       * pt.c (check_explicit_specialization): Likewise.
+
        PR c++/31941
        * error.c (resolve_virtual_fun_from_obj_type_ref): Handle
        TARGET_VTABLE_USES_DESCRIPTORS targets properly.
index 5f7e718..c6628aa 100644 (file)
@@ -2970,7 +2970,7 @@ set_decl_namespace (tree decl, tree scope, bool friendp)
 
   /* See whether this has been declared in the namespace.  */
   old = lookup_qualified_name (scope, DECL_NAME (decl), false, true);
-  if (!old)
+  if (old == error_mark_node)
     /* No old declaration at all.  */
     goto complain;
   if (!is_overloaded_fn (decl))
index b4a9b68..2594e7d 100644 (file)
@@ -1980,7 +1980,7 @@ check_explicit_specialization (tree declarator,
                 context.  */
              fns = lookup_qualified_name (CP_DECL_CONTEXT (decl), dname,
                                           false, true);
-             if (!fns || !is_overloaded_fn (fns))
+             if (fns == error_mark_node || !is_overloaded_fn (fns))
                {
                  error ("%qD is not a template function", dname);
                  fns = error_mark_node;
@@ -2215,6 +2215,8 @@ check_explicit_specialization (tree declarator,
               /* This specialization has the same linkage and visibility as
                  the function template it specializes.  */
               TREE_PUBLIC (decl) = TREE_PUBLIC (tmpl_func);
+             if (! TREE_PUBLIC (decl) && DECL_INTERFACE_KNOWN (tmpl_func))
+               DECL_INTERFACE_KNOWN (decl) = 1;
               DECL_THIS_STATIC (decl) = DECL_THIS_STATIC (tmpl_func);
               if (DECL_VISIBILITY_SPECIFIED (tmpl_func))
                 {
index b004d09..5c35247 100644 (file)
@@ -1,5 +1,8 @@
 2007-08-24  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c++/32898
+       * g++.dg/lookup/ns3.C: New test.
+
        * gfortran.dg/assumed_charlen_sharing.f90: New test.
 
        PR c++/31941
diff --git a/gcc/testsuite/g++.dg/lookup/ns3.C b/gcc/testsuite/g++.dg/lookup/ns3.C
new file mode 100644 (file)
index 0000000..144cba7
--- /dev/null
@@ -0,0 +1,5 @@
+// PR c++/32898
+
+namespace N { }
+
+int N::i;      // { dg-error "should have been declared inside" }