C FE: fix range of primary-expression in c_parser_postfix_expression
gcc/c/ChangeLog: * c-parser.c (c_parser_postfix_expression): Use EXPR_LOC_OR_LOC to preserve range information for the primary expression in the call to c_parser_postfix_expression_after_primary. gcc/testsuite/ChangeLog: * gcc.dg/cast-function-1.c (bar): Update column numbers. * gcc.dg/diagnostic-range-bad-called-object.c: New test case. From-SVN: r231709
This commit is contained in:
parent
0f7a02a32f
commit
a10704e17a
5 changed files with 41 additions and 5 deletions
|
@ -1,3 +1,9 @@
|
|||
2015-12-16 David Malcolm <dmalcolm@redhat.com>
|
||||
|
||||
* c-parser.c (c_parser_postfix_expression): Use EXPR_LOC_OR_LOC
|
||||
to preserve range information for the primary expression
|
||||
in the call to c_parser_postfix_expression_after_primary.
|
||||
|
||||
2015-12-16 David Malcolm <dmalcolm@redhat.com>
|
||||
|
||||
* c-parser.c (c_parser_static_assert_declaration_no_semi): Use the
|
||||
|
|
|
@ -7954,7 +7954,8 @@ c_parser_postfix_expression (c_parser *parser)
|
|||
expr.value = error_mark_node;
|
||||
break;
|
||||
}
|
||||
return c_parser_postfix_expression_after_primary (parser, loc, expr);
|
||||
return c_parser_postfix_expression_after_primary
|
||||
(parser, EXPR_LOC_OR_LOC (expr.value, loc), expr);
|
||||
}
|
||||
|
||||
/* Parse a postfix expression after a parenthesized type name: the
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
2015-12-16 David Malcolm <dmalcolm@redhat.com>
|
||||
|
||||
* gcc.dg/cast-function-1.c (bar): Update column numbers.
|
||||
* gcc.dg/diagnostic-range-bad-called-object.c: New test case.
|
||||
|
||||
2015-12-16 David Malcolm <dmalcolm@redhat.com>
|
||||
|
||||
* gcc.dg/diagnostic-range-static-assert.c: New test case.
|
||||
|
|
|
@ -18,14 +18,14 @@ typedef struct {
|
|||
|
||||
void bar(double d, int i, str_t s)
|
||||
{
|
||||
d = ((double (*) (int)) foo1) (i); /* { dg-warning "7:non-compatible|abort" } */
|
||||
i = ((int (*) (double)) foo1) (d); /* { dg-warning "7:non-compatible|abort" } */
|
||||
s = ((str_t (*) (int)) foo1) (i); /* { dg-warning "7:non-compatible|abort" } */
|
||||
d = ((double (*) (int)) foo1) (i); /* { dg-warning "8:non-compatible|abort" } */
|
||||
i = ((int (*) (double)) foo1) (d); /* { dg-warning "8:non-compatible|abort" } */
|
||||
s = ((str_t (*) (int)) foo1) (i); /* { dg-warning "8:non-compatible|abort" } */
|
||||
((void (*) (int)) foo1) (d); /* { dg-warning "non-compatible|abort" } */
|
||||
i = ((int (*) (int)) foo1) (i); /* { dg-bogus "non-compatible|abort" } */
|
||||
(void) foo1 (i); /* { dg-bogus "non-compatible|abort" } */
|
||||
|
||||
d = ((double (*) (int)) foo2) (i); /* { dg-warning "7:non-compatible|abort" } */
|
||||
d = ((double (*) (int)) foo2) (i); /* { dg-warning "8:non-compatible|abort" } */
|
||||
i = ((int (*) (double)) foo2) (d); /* { dg-bogus "non-compatible|abort" } */
|
||||
s = ((str_t (*) (int)) foo2) (i); /* { dg-warning "non-compatible|abort" } */
|
||||
((void (*) (int)) foo2) (d); /* { dg-warning "non-compatible|abort" } */
|
||||
|
|
24
gcc/testsuite/gcc.dg/diagnostic-range-bad-called-object.c
Normal file
24
gcc/testsuite/gcc.dg/diagnostic-range-bad-called-object.c
Normal file
|
@ -0,0 +1,24 @@
|
|||
/* { dg-options "-fdiagnostics-show-caret" } */
|
||||
|
||||
/* Adapted from https://gcc.gnu.org/wiki/ClangDiagnosticsComparison */
|
||||
|
||||
void call_of_non_function_ptr (char **argP, char **argQ)
|
||||
{
|
||||
(argP - argQ)(); /* { dg-error "called object is not a function or function pointer" } */
|
||||
|
||||
/* { dg-begin-multiline-output "" }
|
||||
(argP - argQ)();
|
||||
~~~~~~^~~~~~~
|
||||
{ dg-end-multiline-output "" } */
|
||||
|
||||
argP(); /* { dg-error "called object 'argP' is not a function or function pointer" } */
|
||||
|
||||
/* { dg-begin-multiline-output "" }
|
||||
argP();
|
||||
^~~~
|
||||
{ dg-end-multiline-output "" }
|
||||
{ dg-begin-multiline-output "" }
|
||||
void call_of_non_function_ptr (char **argP, char **argQ)
|
||||
^~~~
|
||||
{ dg-end-multiline-output "" } */
|
||||
}
|
Loading…
Add table
Reference in a new issue