The following invalid code snippet triggers an ICE since GCC 4.1.0: template<intstruct A { static const int i; }; template<int Nstruct B { char c[A<N>::i], d; }; B<0b; bug.cc: In instantiation of 'B<0>': bug.cc:11: instantiated from here bug.cc:7: internal compiler error: tree check: expected integer_cst, have nop_expr in walk_subobject_offsets, at cp/class.c:3126 Please submit a full bug report, [etc.]
No.1 | | 131 bytes | |
-- reichelt at gcc dot gnu dot org changed: What |Removed |Added Target Milestone| |4.1.2
No.2 | | 206 bytes | |
Comment #1 from janis at gcc dot gnu dot org 2006-08-11 22:24 A regression hunt on powerpc-linux identified the following patch: r106566 | mmitchel | 2005-11-06 19:41:18 +0000 (Sun, 06 Nov 2005)
No.3 | | 88 bytes | |
Comment #2 from reichelt at gcc dot gnu dot org 2006-08-14 19:02 Confirmed by Janis.
No.4 | | 122 bytes | |
-- mmitchel at gcc dot gnu dot org changed: What |Removed |Added Priority|P3 |P2
No.5 | | 213 bytes | |
-- mmitchel at gcc dot gnu dot org changed: What |Removed |Added AssignedTo|unassigned at gcc dot gnu |mark at codesourcery dot com |dot org | Status|NEW |ASSIGNED
No.6 | | 1641 bytes | |
Comment #3 from mmitchel at gcc dot gnu dot org 2006-08-26 16:23 Subject: Bug 28595
Author: mmitchel Date: Sat Aug 26 16:23:33 2006 New Revision: 116468
URL: Log: PR c++/28588 * class.c (): Add access_path parameter. Perform access checks. (instantiate_type): Adjust call to Remove unnecessary code. * tree.c (is_overloaded_fn): Document. Return 2 when there are acutally multiple functions. (really_overloaded_fn): Use is_overloaded_fn. * mangle.c (write_expression): Handle BASELINKs. * cp-tree.h (really_overloaded_fn): Return bool. (baselink_for_fns): Declare. * search.c (lookup_member): Check access for single static functions here. * pt.c (): Handle BASELINKs. (tsubst_copy_and_build): Generate BASELINKs for template-ids. * semantics.c (finish_call_expr): Use baselink_for_fns. (baselink_for_fns): New function. (finish_id_expression): Use it. * parser.c (cp_parser_template_argument): Don't strip BASELINKs. PR c++/28595 * pt.c (tsubst): Issue errors about attempts to create VLAs at template-instantiation time. PR c++/28588 * gdg/inherit/access6.C: New test. * gdg/inherit/access7.C: Likewise. PR c++/28595 * gdg/template/array15.C: New test. * gdg/template/crash2.C: Tweak error markers.