]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR c++/34059 (ICE with invalid base type for class member)
authorSimon Martin <simartin@users.sourceforge.net>
Mon, 10 Dec 2007 22:39:27 +0000 (22:39 +0000)
committerSimon Martin <simartin@gcc.gnu.org>
Mon, 10 Dec 2007 22:39:27 +0000 (22:39 +0000)
gcc/cp/

2007-12-10  Simon Martin  <simartin@users.sourceforge.net>

PR c++/34059
* typeck.c (build_class_member_access_expr): Compute MEMBER_SCOPE from
MEMBER's BASELINK_ACCESS_BINFO instead of its BASELINK_BINFO.

gcc/testsuite/

2007-12-10  Simon Martin  <simartin@users.sourceforge.net>

PR c++/34059
* g++.dg/parse/crash40.C: New test.

From-SVN: r130754

gcc/cp/ChangeLog
gcc/cp/typeck.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/parse/crash40.C [new file with mode: 0644]

index 635c6973efeede4dd4315f006eb1b07b9a837d18..294be3a089d11263e7c278f9c1dd9475690d82a7 100644 (file)
@@ -1,3 +1,9 @@
+2007-12-10  Simon Martin  <simartin@users.sourceforge.net>
+
+       PR c++/34059
+       * typeck.c (build_class_member_access_expr): Compute MEMBER_SCOPE from
+       MEMBER's BASELINK_ACCESS_BINFO instead of its BASELINK_BINFO.
+
 2007-12-10  Jakub Jelinek  <jakub@redhat.com>
 
        PR c++/34395
index 6a3405a6c364a98a8d7cfba1aefeb3af5bdaaecc..0f7ecf723a48be6220095e6a5d1ae7c426d764fe 100644 (file)
@@ -1800,7 +1800,7 @@ build_class_member_access_expr (tree object, tree member,
        warn_deprecated_use (member);
     }
   else
-    member_scope = BINFO_TYPE (BASELINK_BINFO (member));
+    member_scope = BINFO_TYPE (BASELINK_ACCESS_BINFO (member));
   /* If MEMBER is from an anonymous aggregate, MEMBER_SCOPE will
      presently be the anonymous union.  Go outwards until we find a
      type related to OBJECT_TYPE.  */
index 8ff13b4fb12c3ee3ffb8f040d981e157a26b7cda..099f0291e228d4df0173b1d1f9536afd1a84eda5 100644 (file)
@@ -1,3 +1,8 @@
+2007-12-10  Simon Martin  <simartin@users.sourceforge.net>
+
+       PR c++/34059
+       * g++.dg/parse/crash40.C: New test.
+
 2007-12-10  Eric Botcazou  <ebotcazou@libertysurf.fr>
 
        * g++.dg/opt/memcpy1.C: New test.
diff --git a/gcc/testsuite/g++.dg/parse/crash40.C b/gcc/testsuite/g++.dg/parse/crash40.C
new file mode 100644 (file)
index 0000000..af44fdb
--- /dev/null
@@ -0,0 +1,42 @@
+/* PR c++/34059 */
+/* { dg-do "compile" } */
+
+struct A
+{
+  template<int> void foo();
+};
+struct B : A {};
+struct C : A {};
+
+class AA
+{
+  template<int> void foo(); /* { dg-error "is private" } */
+};
+struct BB : AA {};
+
+class AAA {
+  int get() const {}
+};
+struct BBB {
+  static BBB *foo();
+private:
+  int get() const {} /* { dg-error "is private" } */
+};
+template<bool> struct S {
+  S(unsigned int = BBB::foo()->AAA::get()); /* { dg-error "is not a base of" } */
+};
+template<bool> struct SS {
+  SS(unsigned int = BBB::foo()->get());
+};
+
+void bar()
+{
+  B().C::foo<0>(); /* { dg-error "is not a member of" } */
+  BB().AA::foo<0>(); /* { dg-error "within this context" } */
+
+  int i;
+  i.C::foo<0>(); /* { dg-error "which is of non-class type" } */
+
+  S<false> s;
+  SS<false> ss; /* { dg-error "within this context" } */
+}