OSDN Git Service

Fix p24939.
authormrs <mrs@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 3 Dec 1999 03:31:44 +0000 (03:31 +0000)
committermrs <mrs@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 3 Dec 1999 03:31:44 +0000 (03:31 +0000)
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@30765 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/init.c
gcc/testsuite/g++.old-deja/g++.mike/s24939.C [new file with mode: 0644]

index db5dad4..5e34a57 100644 (file)
@@ -1,3 +1,7 @@
+1999-12-02  Mike Stump  <mrs@wrs.com>
+
+       * init.c (perform_member_init): Handle parse errors better.
+
 1999-12-01  Mark Mitchell  <mark@codesourcery.com>
 
        * cp-tree.h (min_tree_cons): Remove.
index 639087a..b0be498 100644 (file)
@@ -144,6 +144,9 @@ perform_member_init (member, name, init, explicit)
 
   decl = build_component_ref (current_class_ref, name, NULL_TREE, explicit);
 
+  if (decl == error_mark_node)
+    return;
+
   /* Deal with this here, as we will get confused if we try to call the
      assignment op for an anonymous union.  This can happen in a
      synthesized copy constructor.  */
diff --git a/gcc/testsuite/g++.old-deja/g++.mike/s24939.C b/gcc/testsuite/g++.old-deja/g++.mike/s24939.C
new file mode 100644 (file)
index 0000000..3ed8fd1
--- /dev/null
@@ -0,0 +1,13 @@
+// Build don't link:
+
+class A;
+
+class B {
+public:
+  B(); 
+private:
+  A a;  // ERROR - 
+};
+
+class A { };
+B::B() { }