diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-18 15:55:25 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-10-18 15:55:25 +0000 |
commit | 95f11b2181d5adfa3cd6fe7d09a440b78c4583a6 (patch) | |
tree | 73f1a827aa5c02a91811ff646cbf751b502b7177 /gcc/c-parser.c | |
parent | e856db016a73710a4ab25b28f8f9c3eeddea7e60 (diff) | |
download | gcc-95f11b2181d5adfa3cd6fe7d09a440b78c4583a6.tar.gz |
PR c/46015
* c-parser.c (c_parser_statement_after_labels): Call mark_exp_read
on computed goto argument.
* semantics.c (finish_goto_stmt): Call mark_rvalue_use on computed
goto destination.
* c-c++-common/Wunused-var-13.c: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@165643 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/c-parser.c')
-rw-r--r-- | gcc/c-parser.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/gcc/c-parser.c b/gcc/c-parser.c index 8338e9d3285..bde882c7099 100644 --- a/gcc/c-parser.c +++ b/gcc/c-parser.c @@ -4151,9 +4151,12 @@ c_parser_statement_after_labels (c_parser *parser) } else if (c_parser_next_token_is (parser, CPP_MULT)) { + tree val; + c_parser_consume_token (parser); - stmt = c_finish_goto_ptr (loc, - c_parser_expression (parser).value); + val = c_parser_expression (parser).value; + mark_exp_read (val); + stmt = c_finish_goto_ptr (loc, val); } else c_parser_error (parser, "expected identifier or %<*%>"); |