aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-sra.c
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2020-02-10 14:05:06 +0100
committerJason Merrill <jason@redhat.com>2020-02-11 09:17:42 +0100
commitdfffecb802681fbdb56629d3bdd96491ac660be0 (patch)
treec39d43ce40c0895261f2d7993ac4b5a8c783bcba /gcc/tree-sra.c
parenta6ee556c7659877bb59b719f11ca2153e86ded59 (diff)
downloadgcc-dfffecb802681fbdb56629d3bdd96491ac660be0.zip
gcc-dfffecb802681fbdb56629d3bdd96491ac660be0.tar.gz
gcc-dfffecb802681fbdb56629d3bdd96491ac660be0.tar.bz2
c++: Fix static initialization from <=>.
Constant evaluation of genericize_spaceship produced a CONSTRUCTOR, which we then wanted to bind to a reference, which we can't do. So wrap the result in a TARGET_EXPR so we get something with an address. We also need to handle treating the result of cxx_eval_binary_expression as a glvalue for SPACESHIP_EXPR. My earlier change to add uid_sensitive to maybe_constant_value was wrong; we don't even look at the cache when manifestly_const_eval, and I failed to adjust the later call to cxx_eval_outermost_constant_expr. gcc/cp/ChangeLog 2020-02-11 Jason Merrill <jason@redhat.com> PR c++/93650 PR c++/90691 * constexpr.c (maybe_constant_value): Correct earlier change. (cxx_eval_binary_expression) [SPACESHIP_EXPR]: Pass lval through. * method.c (genericize_spaceship): Wrap result in TARGET_EXPR.
Diffstat (limited to 'gcc/tree-sra.c')
0 files changed, 0 insertions, 0 deletions