https://gcc.gnu.org/bugzilla/show_bug.cgi?id=72764
Bug ID: 72764
Summary: ICE on invalid C++11 code instantiating an alias
template: tree check: expected class ‘type’, have
‘exceptional’ (error_mark) in typedef_variant_p, at
tree.c:12660
Product: gcc
Version: 7.0
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: c++
Assignee: unassigned at gcc dot gnu.org
Reporter: su at cs dot ucdavis.edu
Target Milestone: ---
It affects 4.8.x and later, which ICE without any proper diagnostics. It is
correctly rejected by 4.7.x.
It is related to PR 72763, which is derived from the same original test.
$ g++-trunk -v
Using built-in specs.
COLLECT_GCC=g++-trunk
COLLECT_LTO_WRAPPER=/usr/local/gcc-trunk/libexec/gcc/x86_64-pc-linux-gnu/7.0.0/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: ../gcc-source-trunk/configure --enable-languages=c,c++,lto
--prefix=/usr/local/gcc-trunk --disable-bootstrap
Thread model: posix
gcc version 7.0.0 20160731 (experimental) [trunk revision 238915] (GCC)
$
$ g++-trunk -c -std=c++11 small.cpp
small.cpp:10:26: internal compiler error: tree check: expected class ‘type’,
have ‘exceptional’ (error_mark) in typedef_variant_p, at tree.c:12660
struct D : B < C < T > > {};
^
0x1071227 tree_class_check_failed(tree_node const*, tree_code_class, char
const*, int, char const*)
../../gcc-source-trunk/gcc/tree.c:9793
0x10812d0 tree_class_check
../../gcc-source-trunk/gcc/tree.h:3402
0x10812d0 typedef_variant_p(tree_node const*)
../../gcc-source-trunk/gcc/tree.c:12660
0x852520 strip_typedefs(tree_node*, bool*)
../../gcc-source-trunk/gcc/cp/tree.c:1494
0x6bba03 canonicalize_type_argument
../../gcc-source-trunk/gcc/cp/pt.c:6979
0x6f31b6 convert_template_argument
../../gcc-source-trunk/gcc/cp/pt.c:7251
0x6feea3 coerce_template_parms
../../gcc-source-trunk/gcc/cp/pt.c:7746
0x700dda lookup_template_class_1
../../gcc-source-trunk/gcc/cp/pt.c:8319
0x700dda lookup_template_class(tree_node*, tree_node*, tree_node*, tree_node*,
int, int)
../../gcc-source-trunk/gcc/cp/pt.c:8662
0x81e28d finish_template_type(tree_node*, tree_node*, int)
../../gcc-source-trunk/gcc/cp/semantics.c:3133
0x7aa444 cp_parser_template_id
../../gcc-source-trunk/gcc/cp/parser.c:14961
0x7aa6ea cp_parser_class_name
../../gcc-source-trunk/gcc/cp/parser.c:21265
0x79910d cp_parser_qualifying_entity
../../gcc-source-trunk/gcc/cp/parser.c:6271
0x79910d cp_parser_nested_name_specifier_opt
../../gcc-source-trunk/gcc/cp/parser.c:5955
0x791fd4 cp_parser_base_specifier
../../gcc-source-trunk/gcc/cp/parser.c:23046
0x791fd4 cp_parser_base_clause
../../gcc-source-trunk/gcc/cp/parser.c:22895
0x791fd4 cp_parser_class_head
../../gcc-source-trunk/gcc/cp/parser.c:22102
0x791fd4 cp_parser_class_specifier_1
../../gcc-source-trunk/gcc/cp/parser.c:21347
0x791fd4 cp_parser_class_specifier
../../gcc-source-trunk/gcc/cp/parser.c:21656
0x791fd4 cp_parser_type_specifier
../../gcc-source-trunk/gcc/cp/parser.c:15883
Please submit a full bug report,
with preprocessed source if appropriate.
Please include the complete backtrace with any bug report.
See <http://gcc.gnu.org/bugs.html> for instructions.
$
--------------------------------------------------------------------
template < typename > struct A;
template < typename > struct B {};
template < typename T >
using C = typename A < T >::template D < T >;
template < typename T > struct A
{
// should be: template < typename > struct D : B < C < T > > {};
struct D : B < C < T > > {};
};
A < int > a;