aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2011-09-07 13:11:49 -0400
committerJason Merrill <jason@gcc.gnu.org>2011-09-07 13:11:49 -0400
commite39438c55d8d22f9ede589d3fc19bacd639be58b (patch)
tree0ca043664c1eece6adcfe41dd1397340888cb18d /gcc/cp
parent30288f9aa21c6ef870bdf792a1eee4f90fd2c468 (diff)
downloadgcc-e39438c55d8d22f9ede589d3fc19bacd639be58b.zip
gcc-e39438c55d8d22f9ede589d3fc19bacd639be58b.tar.gz
gcc-e39438c55d8d22f9ede589d3fc19bacd639be58b.tar.bz2
re PR c++/50298 ([C++0x][constexpr] References cannot be bound to static constexpr reference members)
PR c++/50298 * parser.c (cp_parser_member_declaration): Don't require a constant rvalue here in C++0x. From-SVN: r178652
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog4
-rw-r--r--gcc/cp/parser.c11
2 files changed, 15 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index ea67d2d..1c6c5a1 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,5 +1,9 @@
2011-09-07 Jason Merrill <jason@redhat.com>
+ PR c++/50298
+ * parser.c (cp_parser_member_declaration): Don't require a constant
+ rvalue here in C++0x.
+
* pt.c (type_unification_real): Correct complain arg for tsubsting
default template args.
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index 7d766d13..6346aa0 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -18187,6 +18187,17 @@ cp_parser_member_declaration (cp_parser* parser)
initializer_token_start = cp_lexer_peek_token (parser->lexer);
if (function_declarator_p (declarator))
initializer = cp_parser_pure_specifier (parser);
+ else if (cxx_dialect >= cxx0x)
+ {
+ bool nonconst;
+ /* Don't require a constant rvalue in C++11, since we
+ might want a reference constant. We'll enforce
+ constancy later. */
+ cp_lexer_consume_token (parser->lexer);
+ /* Parse the initializer. */
+ initializer = cp_parser_initializer_clause (parser,
+ &nonconst);
+ }
else
/* Parse the initializer. */
initializer = cp_parser_constant_initializer (parser);