aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMarek Polacek <polacek@redhat.com>2014-04-30 06:14:39 +0000
committerMarek Polacek <mpolacek@gcc.gnu.org>2014-04-30 06:14:39 +0000
commit8337d1db7113fa0c44541a1917529a0c41057a4a (patch)
treeedc7cc5205725c68c2ab5c60851dedd9e4147750 /gcc
parentc4bdc42f752a6fbff34c0bc75a907957afcbc431 (diff)
downloadgcc-8337d1db7113fa0c44541a1917529a0c41057a4a.zip
gcc-8337d1db7113fa0c44541a1917529a0c41057a4a.tar.gz
gcc-8337d1db7113fa0c44541a1917529a0c41057a4a.tar.bz2
re PR c/60139 (Imprecise column number for -pedantic on non-computable initializer element)
PR c/60139 * c-typeck.c (output_init_element): Pass OPT_Wpedantic to pedwarn and pedwarn_init. Use loc insted of input_location. * gcc.dg/pr60139.c: New test. From-SVN: r209926
Diffstat (limited to 'gcc')
-rw-r--r--gcc/c/ChangeLog6
-rw-r--r--gcc/c/c-typeck.c4
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr60139.c14
4 files changed, 27 insertions, 2 deletions
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog
index ee7c9be..d54b62e 100644
--- a/gcc/c/ChangeLog
+++ b/gcc/c/ChangeLog
@@ -1,5 +1,11 @@
2014-04-30 Marek Polacek <polacek@redhat.com>
+ PR c/60139
+ * c-typeck.c (output_init_element): Pass OPT_Wpedantic to pedwarn
+ and pedwarn_init. Use loc insted of input_location.
+
+2014-04-30 Marek Polacek <polacek@redhat.com>
+
PR c/60351
* c-typeck.c (build_binary_op): Use location when warning about
shift count.
diff --git a/gcc/c/c-typeck.c b/gcc/c/c-typeck.c
index e23c6db..6e56b69 100644
--- a/gcc/c/c-typeck.c
+++ b/gcc/c/c-typeck.c
@@ -8255,12 +8255,12 @@ output_init_element (location_t loc, tree value, tree origtype,
value = error_mark_node;
}
else if (require_constant_elements)
- pedwarn (input_location, 0,
+ pedwarn (loc, OPT_Wpedantic,
"initializer element is not computable at load time");
}
else if (!maybe_const
&& (require_constant_value || require_constant_elements))
- pedwarn_init (input_location, 0,
+ pedwarn_init (loc, OPT_Wpedantic,
"initializer element is not a constant expression");
/* Issue -Wc++-compat warnings about initializing a bitfield with
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 7923853..de10503 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2014-04-30 Marek Polacek <polacek@redhat.com>
+ PR c/60139
+ * gcc.dg/pr60139.c: New test.
+
+2014-04-30 Marek Polacek <polacek@redhat.com>
+
PR c/60351
* gcc.dg/pr60351.c: New test.
diff --git a/gcc/testsuite/gcc.dg/pr60139.c b/gcc/testsuite/gcc.dg/pr60139.c
new file mode 100644
index 0000000..a63d8b5
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr60139.c
@@ -0,0 +1,14 @@
+/* PR c/60139 */
+/* { dg-do compile } */
+/* { dg-options "-Wpedantic" } */
+/* { dg-prune-output ".*near initialization for.*" } */
+
+double sin (double);
+void
+fn (int *p)
+{
+ int **a[] = { &p, /* { dg-warning "17:initializer element is not computable at load time" } */
+ (void *) 0, &p }; /* { dg-warning "28:initializer element is not computable at load time" } */
+ double d[] = { sin (1.0), /* { dg-warning "18:initializer element is not a constant expression" } */
+ 8.8, sin (1.0), 2.6 }; /* { dg-warning "23:initializer element is not a constant expression" } */
+}