re PR c++/10371 (misleading error message for illegal member access)
authorKriang Lerdsuwanakij <lerdsuwa@users.sourceforge.net>
Sun, 26 Oct 2003 11:04:36 +0000 (11:04 +0000)
committerKriang Lerdsuwanakij <lerdsuwa@gcc.gnu.org>
Sun, 26 Oct 2003 11:04:36 +0000 (11:04 +0000)
PR c++/10371
* semantics.c (finish_non_static_data_member): Handle when
both processing_template_decl and qualifying_scope are true.

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

From-SVN: r72950

gcc/cp/ChangeLog
gcc/cp/semantics.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/lookup/scoped8.C [new file with mode: 0644]

index 0d1cd9173ad0be3616c281fb64f3bf437a7698b0..0b7e80975b9873e3590dd8351a1935daa1e7ec0d 100644 (file)
@@ -1,3 +1,9 @@
+2003-10-26  Kriang Lerdsuwanakij  <lerdsuwa@users.sourceforge.net>
+
+       PR c++/10371
+       * semantics.c (finish_non_static_data_member): Handle when
+       both processing_template_decl and qualifying_scope are true.
+
 2003-10-24  Kriang Lerdsuwanakij  <lerdsuwa@users.sourceforge.net>
 
        PR c++/11076
index b55059dbc64c7daec569933155d3ecc7dbdec24e..13d873430ea36417c7e5c5b5413b8e95b9f7e7a1 100644 (file)
@@ -1224,7 +1224,7 @@ finish_non_static_data_member (tree decl, tree object, tree qualifying_scope)
       return error_mark_node;
     }
   TREE_USED (current_class_ptr) = 1;
-  if (processing_template_decl)
+  if (processing_template_decl && !qualifying_scope)
     {
       tree type = TREE_TYPE (decl);
 
@@ -1263,6 +1263,13 @@ finish_non_static_data_member (tree decl, tree object, tree qualifying_scope)
            }
        }
 
+      /* If PROCESSING_TEMPLATE_DECL is non-zero here, then
+        QUALIFYING_SCOPE is also non-null.  Wrap this in a SCOPE_REF
+        for now.  */
+      if (processing_template_decl)
+       return build_min (SCOPE_REF, TREE_TYPE (decl),
+                         qualifying_scope, DECL_NAME (decl));
+
       perform_or_defer_access_check (TYPE_BINFO (access_type), decl);
 
       /* If the data member was named `C::M', convert `*this' to `C'
index 28a067b1a6d5f9a0e5c5997dbb9e3ac3ecf73fd2..47a7512c64f1ece86b3c06c2e5baba216a1ca0c0 100644 (file)
@@ -1,3 +1,8 @@
+2003-10-26  Kriang Lerdsuwanakij  <lerdsuwa@users.sourceforge.net>
+
+       PR c++/10371
+       * g++.dg/lookup/scoped8.C: New test.
+
 2003-10-25  Eric Botcazou  <ebotcazou@libertysurf.fr>
 
        * g++.dg/opt/reg-stack3.C: New test.
diff --git a/gcc/testsuite/g++.dg/lookup/scoped8.C b/gcc/testsuite/g++.dg/lookup/scoped8.C
new file mode 100644 (file)
index 0000000..1c30304
--- /dev/null
@@ -0,0 +1,16 @@
+// { dg-do compile }
+
+// Origin: Volker Reichelt <reichelt@igpm.rwth-aachen.de>
+
+// PR c++/10371: Incorrect tree node built in
+// finish_non_static_data_member.
+
+struct A
+{
+    int i;                     // { dg-error "object missing" }
+};
+
+template <int> struct B
+{
+    int foo() { return A::i; } // { dg-error "this location" }
+};