aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp/parser.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2007-11-05 09:18:03 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2007-11-05 09:18:03 +0100
commitf370e66bb8c7fe4b8fe694dd79f13e834b4e7575 (patch)
tree621f3e5c2cfd28d23aa3ab9568e1678a9a43b766 /gcc/cp/parser.c
parent1b021ff438d08470cb72ee3e8e75029bda7989f1 (diff)
downloadgcc-f370e66bb8c7fe4b8fe694dd79f13e834b4e7575.zip
gcc-f370e66bb8c7fe4b8fe694dd79f13e834b4e7575.tar.gz
gcc-f370e66bb8c7fe4b8fe694dd79f13e834b4e7575.tar.bz2
re PR c++/33836 (ICE with invalid use of &&)
PR c++/33836 * parser.c (cp_parser_unary_expression): For &&label call cp_parser_non_integral_constant_expression and return error_mark_node if it returned true. * g++.dg/ext/label10.C: New test. From-SVN: r129896
Diffstat (limited to 'gcc/cp/parser.c')
-rw-r--r--gcc/cp/parser.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index 0772c87..4729d1e 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -5329,13 +5329,18 @@ cp_parser_unary_expression (cp_parser *parser, bool address_p, bool cast_p)
&& token->type == CPP_AND_AND)
{
tree identifier;
+ tree expression;
/* Consume the '&&' token. */
cp_lexer_consume_token (parser->lexer);
/* Look for the identifier. */
identifier = cp_parser_identifier (parser);
/* Create an expression representing the address. */
- return finish_label_address_expr (identifier);
+ expression = finish_label_address_expr (identifier);
+ if (cp_parser_non_integral_constant_expression (parser,
+ "the address of a label"))
+ expression = error_mark_node;
+ return expression;
}
}
if (unary_operator != ERROR_MARK)