diff options
author | Marek Polacek <polacek@redhat.com> | 2020-05-06 19:24:58 -0400 |
---|---|---|
committer | Marek Polacek <polacek@redhat.com> | 2020-05-18 18:53:38 -0400 |
commit | bf732686c0b9c42a2fe119db774c5a65e5a97174 (patch) | |
tree | df923e1c6f96adfba733524631c290db6c89620f /gcc/c/c-parser.c | |
parent | 8edf0adb6616bd717312d9b305c7d7c9a6b7a171 (diff) | |
download | gcc-bf732686c0b9c42a2fe119db774c5a65e5a97174.zip gcc-bf732686c0b9c42a2fe119db774c5a65e5a97174.tar.gz gcc-bf732686c0b9c42a2fe119db774c5a65e5a97174.tar.bz2 |
c++: ICE with -Wall and constexpr if [PR94937]
An ICE arises here because we call cp_get_callee_fndecl_nofold in a
template, and we've got a CALL_EXPR whose CALL_EXPR_FN is a BASELINK.
This tickles the INDIRECT_TYPE_P assert in cp_get_fndecl_from_callee.
Fixed by turning the assert into a condition and returning NULL_TREE
in that case.
PR c++/94937
* cvt.c (cp_get_fndecl_from_callee): Return NULL_TREE if the function
type is not INDIRECT_TYPE_P.
* decl.c (omp_declare_variant_finalize_one): Call
cp_get_callee_fndecl_nofold instead of looking for the function decl
manually.
* g++.dg/cpp1z/constexpr-if34.C: New test.
* g++.dg/cpp2a/is-constant-evaluated10.C: New test.
Diffstat (limited to 'gcc/c/c-parser.c')
0 files changed, 0 insertions, 0 deletions