From 4882d82a27be94484f38bb4f998b7e4ffa5772d1 Mon Sep 17 00:00:00 2001 From: Paolo Carlini Date: Sun, 28 Apr 2013 22:56:44 +0000 Subject: [PATCH] re PR c++/56450 (ICE with SFINAE when detecting non-static member variable) /cp 2013-04-28 Paolo Carlini PR c++/56450 * semantics.c (finish_decltype_type): Handle COMPOUND_EXPR. /testsuite 2013-04-28 Paolo Carlini PR c++/56450 * g++.dg/cpp0x/decltype52.C: New. From-SVN: r198381 --- gcc/cp/ChangeLog | 5 +++++ gcc/cp/semantics.c | 1 + gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/cpp0x/decltype52.C | 18 ++++++++++++++++++ 4 files changed, 29 insertions(+) create mode 100644 gcc/testsuite/g++.dg/cpp0x/decltype52.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 39fbc46db44..c614ebed8d7 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2013-04-28 Paolo Carlini + + PR c++/56450 + * semantics.c (finish_decltype_type): Handle COMPOUND_EXPR. + 2013-04-26 Jakub Jelinek * error.c (cp_print_error_function): Adjust file_name_as_prefix diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 3566739a10e..2a0d5bcaded 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -5398,6 +5398,7 @@ finish_decltype_type (tree expr, bool id_expression_or_member_access_p, break; case COMPONENT_REF: + case COMPOUND_EXPR: mark_type_use (expr); type = is_bitfield_expr_with_lowered_type (expr); if (!type) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cf3465728c0..7e0975d6745 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-04-28 Paolo Carlini + + PR c++/56450 + * g++.dg/cpp0x/decltype52.C: New. + 2013-04-28 Jakub Jelinek N3472 binary constants diff --git a/gcc/testsuite/g++.dg/cpp0x/decltype52.C b/gcc/testsuite/g++.dg/cpp0x/decltype52.C new file mode 100644 index 00000000000..e6b5a4cafb4 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/decltype52.C @@ -0,0 +1,18 @@ +// PR c++/56450 +// { dg-do compile { target c++11 } } + +template +T&& declval(); + +template +struct is_same +{ static constexpr bool value = false; }; + +template +struct is_same +{ static constexpr bool value = true; }; + +struct A { static const int dummy = 0; }; + +static_assert(is_same().dummy), const int>::value, ""); +static_assert(!is_same().dummy), const int&>::value, ""); -- 2.30.2