diff options
author | Marek Polacek <polacek@redhat.com> | 2017-03-03 09:58:10 +0000 |
---|---|---|
committer | Marek Polacek <mpolacek@gcc.gnu.org> | 2017-03-03 09:58:10 +0000 |
commit | 7278b0a266909c8558e83a4fa91fd0588e92fa1c (patch) | |
tree | 62c4a90250b01b8e44129773e8e4494d655f637f /gcc | |
parent | 5719c938be12a48749833d6fa29c7a9a7724f37e (diff) | |
download | gcc-7278b0a266909c8558e83a4fa91fd0588e92fa1c.zip gcc-7278b0a266909c8558e83a4fa91fd0588e92fa1c.tar.gz gcc-7278b0a266909c8558e83a4fa91fd0588e92fa1c.tar.bz2 |
re PR c++/79791 (-Werror=write-strings ignored with -Wpedantic)
PR c++/79791
* typeck.c (string_conv_p): In C++11, always call pedwarn with
OPT_Wwrite_strings.
* g++.dg/warn/Wwrite-strings-1.C: New test.
* g++.dg/warn/Wwrite-strings-2.C: New test.
* g++.dg/warn/Wwrite-strings-3.C: New test.
* g++.dg/warn/Wwrite-strings-4.C: New test.
* g++.dg/warn/Wwrite-strings-5.C: New test.
* g++.dg/warn/Wwrite-strings-6.C: New test.
* g++.dg/warn/Wwrite-strings-7.C: New test.
* g++.dg/warn/Wwrite-strings-8.C: New test.
* g++.dg/warn/Wwrite-strings-9.C: New test.
* g++.dg/warn/Wwrite-strings-10.C: New test.
* g++.dg/warn/Wwrite-strings-11.C: New test.
* g++.dg/warn/Wwrite-strings-12.C: New test.
From-SVN: r245864
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/cp/typeck.c | 3 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 16 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-1.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-10.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-11.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-12.C | 6 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-2.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-3.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-4.C | 6 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-5.C | 6 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-6.C | 6 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-7.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-8.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wwrite-strings-9.C | 5 |
15 files changed, 87 insertions, 2 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index be98880..7ff2827 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2017-03-03 Marek Polacek <polacek@redhat.com> + + PR c++/79791 + * typeck.c (string_conv_p): In C++11, always call pedwarn with + OPT_Wwrite_strings. + 2017-03-02 Jason Merrill <jason@redhat.com> Update overload resolution with deduction guides. diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c index 3216bc4..d111124 100644 --- a/gcc/cp/typeck.c +++ b/gcc/cp/typeck.c @@ -2175,8 +2175,7 @@ string_conv_p (const_tree totype, const_tree exp, int warn) if (warn) { if (cxx_dialect >= cxx11) - pedwarn (input_location, - pedantic ? OPT_Wpedantic : OPT_Wwrite_strings, + pedwarn (input_location, OPT_Wwrite_strings, "ISO C++ forbids converting a string constant to %qT", totype); else diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e5a08ac..502a073 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,19 @@ +2017-03-03 Marek Polacek <polacek@redhat.com> + + PR c++/79791 + * g++.dg/warn/Wwrite-strings-1.C: New test. + * g++.dg/warn/Wwrite-strings-2.C: New test. + * g++.dg/warn/Wwrite-strings-3.C: New test. + * g++.dg/warn/Wwrite-strings-4.C: New test. + * g++.dg/warn/Wwrite-strings-5.C: New test. + * g++.dg/warn/Wwrite-strings-6.C: New test. + * g++.dg/warn/Wwrite-strings-7.C: New test. + * g++.dg/warn/Wwrite-strings-8.C: New test. + * g++.dg/warn/Wwrite-strings-9.C: New test. + * g++.dg/warn/Wwrite-strings-10.C: New test. + * g++.dg/warn/Wwrite-strings-11.C: New test. + * g++.dg/warn/Wwrite-strings-12.C: New test. + 2017-03-03 Richard Biener <rguenther@suse.de> PR middle-end/79818 diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-1.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-1.C new file mode 100644 index 0000000..05abca3 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-1.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "" } + +char *s = "foo"; // { dg-warning "ISO C\\+\\+ forbids converting a string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-10.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-10.C new file mode 100644 index 0000000..d34b0b0 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-10.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target { ! c++11 } } } +// { dg-options "" } + +char *s = "foo"; // { dg-warning "deprecated conversion from string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-11.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-11.C new file mode 100644 index 0000000..11ddcdb --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-11.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target { ! c++11 } } } +// { dg-options "-pedantic-errors" } + +char *s = "foo"; // { dg-warning "deprecated conversion from string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-12.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-12.C new file mode 100644 index 0000000..754a9c8 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-12.C @@ -0,0 +1,6 @@ +// PR c++/79791 +// { dg-do compile { target { ! c++11 } } } +// { dg-options "-Werror=write-strings" } +// { dg-message "some warnings being treated as errors" "" { target *-*-* } 0 } + +char *s = "foo"; // { dg-error "deprecated conversion from string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-2.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-2.C new file mode 100644 index 0000000..53084d9 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-2.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-pedantic-errors" } + +char *s = "foo"; // { dg-error "ISO C\\+\\+ forbids converting a string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-3.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-3.C new file mode 100644 index 0000000..6cb9654 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-3.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-pedantic-errors -Wno-write-strings" } + +char *s = "foo"; diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-4.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-4.C new file mode 100644 index 0000000..2654c39 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-4.C @@ -0,0 +1,6 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-Werror=write-strings" } +// { dg-message "some warnings being treated as errors" "" { target *-*-* } 0 } + +char *s = "foo"; // { dg-error "ISO C\\+\\+ forbids converting a string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-5.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-5.C new file mode 100644 index 0000000..f58ea90 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-5.C @@ -0,0 +1,6 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-Werror=write-strings -Wpedantic" } +// { dg-message "some warnings being treated as errors" "" { target *-*-* } 0 } + +char *s = "foo"; // { dg-error "ISO C\\+\\+ forbids converting a string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-6.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-6.C new file mode 100644 index 0000000..ff89f38 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-6.C @@ -0,0 +1,6 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-Werror=write-strings -Wno-pedantic" } +// { dg-message "some warnings being treated as errors" "" { target *-*-* } 0 } + +char *s = "foo"; // { dg-error "ISO C\\+\\+ forbids converting a string constant" } diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-7.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-7.C new file mode 100644 index 0000000..13a8291 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-7.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-Wno-write-strings" } + +char *s = "foo"; diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-8.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-8.C new file mode 100644 index 0000000..df5f283 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-8.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-Wpedantic -Wno-write-strings" } + +char *s = "foo"; diff --git a/gcc/testsuite/g++.dg/warn/Wwrite-strings-9.C b/gcc/testsuite/g++.dg/warn/Wwrite-strings-9.C new file mode 100644 index 0000000..5db813b --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wwrite-strings-9.C @@ -0,0 +1,5 @@ +// PR c++/79791 +// { dg-do compile { target c++11 } } +// { dg-options "-Wno-error=write-strings -pedantic-errors" } + +char *s = "foo"; // { dg-warning "ISO C\\+\\+ forbids converting a string constant" } |