From: Mike Stump Date: Fri, 3 Dec 1999 03:31:44 +0000 (+0000) Subject: Fix p24939. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=2fbfe9b812e266e823ba26d423587466f2b1ba4c;p=gcc.git Fix p24939. From-SVN: r30765 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index db5dad4f19d..5e34a578cbf 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,7 @@ +1999-12-02 Mike Stump + + * init.c (perform_member_init): Handle parse errors better. + 1999-12-01 Mark Mitchell * cp-tree.h (min_tree_cons): Remove. diff --git a/gcc/cp/init.c b/gcc/cp/init.c index 639087ac39b..b0be498950b 100644 --- a/gcc/cp/init.c +++ b/gcc/cp/init.c @@ -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 index 00000000000..3ed8fd1ab19 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.mike/s24939.C @@ -0,0 +1,13 @@ +// Build don't link: + +class A; + +class B { +public: + B(); +private: + A a; // ERROR - +}; + +class A { }; +B::B() { }