[Bug c++/81574] New: ICE on valid C++14 code: in canonicalize_component_ref, at gimplify.c:2481
su at cs dot ucdavis.edu
gcc-bugzilla@gcc.gnu.org
Thu Jul 27 07:19:00 GMT 2017
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=81574
Bug ID: 81574
Summary: ICE on valid C++14 code: in
canonicalize_component_ref, at gimplify.c:2481
Product: gcc
Version: unknown
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: c++
Assignee: unassigned at gcc dot gnu.org
Reporter: su at cs dot ucdavis.edu
Target Milestone: ---
$ 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/8.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 8.0.0 20170726 (experimental) [trunk revision 250555] (GCC)
$
$ clang++ -c -std=c++14 small.cpp
$ icc -c -std=c++14 small.cpp
$
$ g++-trunk -c -std=c++14 small.cpp
small.cpp: In lambda function:
small.cpp:5:18: error: field ‘f()::<lambda()>::<lambda()>::<b capture>’
invalidly declared function type
[=] { return b; } ();
^
small.cpp: In lambda function:
small.cpp:5:21: internal compiler error: in canonicalize_component_ref, at
gimplify.c:2481
[=] { return b; } ();
^
0xbb2693 canonicalize_component_ref
../../gcc-source-trunk/gcc/gimplify.c:2481
0xbc4ed7 gimplify_compound_lval
../../gcc-source-trunk/gcc/gimplify.c:2907
0xbbb7c1 gimplify_expr(tree_node**, gimple**, gimple**, bool (*)(tree_node*),
int)
../../gcc-source-trunk/gcc/gimplify.c:11277
0xbbb9b6 gimplify_addr_expr
../../gcc-source-trunk/gcc/gimplify.c:5920
0xbbb9b6 gimplify_expr(tree_node**, gimple**, gimple**, bool (*)(tree_node*),
int)
../../gcc-source-trunk/gcc/gimplify.c:11371
0xbced77 gimplify_modify_expr
../../gcc-source-trunk/gcc/gimplify.c:5513
0xbbc6d9 gimplify_expr(tree_node**, gimple**, gimple**, bool (*)(tree_node*),
int)
../../gcc-source-trunk/gcc/gimplify.c:11325
0xbc0406 gimplify_stmt(tree_node**, gimple**)
../../gcc-source-trunk/gcc/gimplify.c:6546
0xbbcceb gimplify_and_add(tree_node*, gimple**)
../../gcc-source-trunk/gcc/gimplify.c:438
0xbbcceb gimplify_return_expr
../../gcc-source-trunk/gcc/gimplify.c:1541
0xbbcceb gimplify_expr(tree_node**, gimple**, gimple**, bool (*)(tree_node*),
int)
../../gcc-source-trunk/gcc/gimplify.c:11584
0xbc0406 gimplify_stmt(tree_node**, gimple**)
../../gcc-source-trunk/gcc/gimplify.c:6546
0xbbbc7b gimplify_statement_list
../../gcc-source-trunk/gcc/gimplify.c:1737
0xbbbc7b gimplify_expr(tree_node**, gimple**, gimple**, bool (*)(tree_node*),
int)
../../gcc-source-trunk/gcc/gimplify.c:11752
0xbc0406 gimplify_stmt(tree_node**, gimple**)
../../gcc-source-trunk/gcc/gimplify.c:6546
0xbc17f5 gimplify_bind_expr
../../gcc-source-trunk/gcc/gimplify.c:1295
0xbbd826 gimplify_expr(tree_node**, gimple**, gimple**, bool (*)(tree_node*),
int)
../../gcc-source-trunk/gcc/gimplify.c:11524
0xbc0406 gimplify_stmt(tree_node**, gimple**)
../../gcc-source-trunk/gcc/gimplify.c:6546
0xbc25ef gimplify_body(tree_node*, bool)
../../gcc-source-trunk/gcc/gimplify.c:12521
0xbc2c24 gimplify_function_tree(tree_node*)
../../gcc-source-trunk/gcc/gimplify.c:12679
Please submit a full bug report,
with preprocessed source if appropriate.
Please include the complete backtrace with any bug report.
See <https://gcc.gnu.org/bugs/> for instructions.
$
-----------------------------
void f ()
{
[&b (f)]
{
[=] { return b; } ();
} ();
}
More information about the Gcc-bugs
mailing list