aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp/init.c
diff options
context:
space:
mode:
authorVolker Reichelt <reichelt@igpm.rwth-aachen.de>2006-06-20 13:02:47 +0000
committerVolker Reichelt <reichelt@gcc.gnu.org>2006-06-20 13:02:47 +0000
commit2e5d297000e914b5132c50f5569ddc13a5512598 (patch)
treee303065643dbc7ce507ca168fef3a32fd9b8a7c7 /gcc/cp/init.c
parent8fdbc9c6eb3bea037982fba616d96c6288f177f9 (diff)
downloadgcc-2e5d297000e914b5132c50f5569ddc13a5512598.zip
gcc-2e5d297000e914b5132c50f5569ddc13a5512598.tar.gz
gcc-2e5d297000e914b5132c50f5569ddc13a5512598.tar.bz2
re PR c++/28052 (ICE on invalid bitfield)
PR c++/28052 * init.c (push_base_cleanups): Skip members with invalid types. * typeck.c (build_class_member_access_expr): Robustify. * g++.dg/other/bitfield2.C: New test. From-SVN: r114811
Diffstat (limited to 'gcc/cp/init.c')
-rw-r--r--gcc/cp/init.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/gcc/cp/init.c b/gcc/cp/init.c
index 590036b..357cba9 100644
--- a/gcc/cp/init.c
+++ b/gcc/cp/init.c
@@ -2898,7 +2898,9 @@ push_base_cleanups (void)
for (member = TYPE_FIELDS (current_class_type); member;
member = TREE_CHAIN (member))
{
- if (TREE_CODE (member) != FIELD_DECL || DECL_ARTIFICIAL (member))
+ if (TREE_TYPE (member) == error_mark_node
+ || TREE_CODE (member) != FIELD_DECL
+ || DECL_ARTIFICIAL (member))
continue;
if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (TREE_TYPE (member)))
{