On Mon, May 18, 2020 at 03:51:36PM -0400, Jason Merrill wrote:
> On 5/16/20 6:34 PM, Marek Polacek wrote:
> > Since GCC 9, C++17 support is no longer experimental.  It was too late
> > to change the default C++ dialect to C++17 in GCC 10, but I think now
> > it's time to pull the trigger (C++14 was made the default in GCC 6.1).
> > We're still missing two C++17 library features, but that shouldn't stop
> > us.  See
> > <https://gcc.gnu.org/onlinedocs/libstdc++/manual/status.html#status.iso.2017>
> > and
> > <https://gcc.gnu.org/projects/cxx-status.html#cxx17>
> > for the C++17 status.
> > 
> > I won't list all C++17 features here, but just a few heads-up:
> > 
> > - trigraphs were removed (hardly anyone cares, unless your keyboard is
> >    missing the # key),
> > - operator++(bool) was removed (so some tests now run in C++14 and down
> >    only),
> > - the keyword register was removed (some legacy code might trip on
> >    this),
> > - noexcept specification is now part of the type system and C++17 does
> >    not allow dynamic exception specifications anymore (the empty throw
> >    specification is still available, but it is deprecated),
> > - the evaluation order rules are different in C++17,
> > - static constexpr data members are now implicitly inline (which makes
> >    them definitions),
> > - C++17 requires guaranteed copy elision, meaning that a copy/move
> >    constructor call might be elided completely.  That means that if
> >    something relied on a constructor being instantiated via e.g. copying
> >    a function parameter, it might now fail.
> > 
> > Jakub, the last point is actually what I encountered in for-27.C and it
> > looks like an OpenMP issue, in that it wrongly depends on an implicit
> > instantiation.  Am I mistaken?
> > 
> > Due to the 'register' removal, this patch depends on the regenerated
> > cfns.h version I posted earlier today.
> > 
> > I'll post an update for cxx-status.html and add a new caveat to changes.html
> > once this is in.
> > 
> > Bootstrapped/regtested on x86_64-pc-linux-gnu, aarch64-unknown-linux-gnu,
> > and powerpc64le-unknown-linux-gnu.  Ok for trunk?
> > 
> >     * doc/invoke.texi (C Dialect Options): Adjust -std default for C++.
> >     * doc/standards.texi (C Language): Correct the default dialect.
> >     (C++ Language): Update the default for C++ to gnu++17.
> > 
> >     * c-opts.c (c_common_init_options): Default to gnu++17.
> > 
> >     * c-c++-common/torture/vector-subscript-3.c: Remove the register
> >     keywords.
> >     * g++.dg/cpp1z/attributes-enum-1a.C: Update for C++17.
> >     * g++.dg/cpp1z/fold7a.C: Likewise.
> >     * g++.dg/cpp1z/nontype3a.C: Likewise.
> >     * g++.dg/cpp1z/utf8-2a.C: Likewise.
> >     * g++.dg/parse/error11.C: Use c++14_down.
> >     * g++.dg/torture/pr34850.C: Add -Wno-attribute-warning.
> >     * g++.dg/torture/pr49394.C: Add dg-warning.
> >     * g++.dg/torture/pr82154.C: Use -std=c++14.
> >     * g++.dg/ubsan/pr85029.C: Use -Wno-register.
> >     * g++.dg/ubsan/vptr-12.C: Use -fstrong-eval-order=some.
> >     * lib/target-supports.exp: Set to C++17.
> >     * obj-c++.dg/try-catch-9.mm: Use -Wno-register.
> > 
> >     * testsuite/libgomp.c++/atomic-3.C: Use -std=gnu++14.
> >     * testsuite/libgomp.c++/for-27.C: Explicitly instantiate the
> >     copy constructor for I<int>.
> > ---
> >   gcc/c-family/c-opts.c                                   | 4 ++--
> >   gcc/doc/invoke.texi                                     | 2 +-
> >   gcc/doc/standards.texi                                  | 4 ++--
> >   gcc/testsuite/c-c++-common/torture/vector-subscript-3.c | 6 +++---
> >   gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C         | 4 ++--
> >   gcc/testsuite/g++.dg/cpp1z/fold7a.C                     | 4 ++--
> >   gcc/testsuite/g++.dg/cpp1z/nontype3a.C                  | 4 ++--
> >   gcc/testsuite/g++.dg/cpp1z/utf8-2a.C                    | 4 ++--
> >   gcc/testsuite/g++.dg/parse/error11.C                    | 5 +++--
> >   gcc/testsuite/g++.dg/torture/pr34850.C                  | 2 +-
> >   gcc/testsuite/g++.dg/torture/pr49394.C                  | 2 +-
> >   gcc/testsuite/g++.dg/torture/pr82154.C                  | 3 ++-
> >   gcc/testsuite/g++.dg/ubsan/pr85029.C                    | 2 +-
> >   gcc/testsuite/g++.dg/ubsan/vptr-12.C                    | 2 +-
> >   gcc/testsuite/lib/target-supports.exp                   | 2 +-
> >   gcc/testsuite/obj-c++.dg/try-catch-9.mm                 | 2 +-
> >   libgomp/testsuite/libgomp.c++/atomic-3.C                | 3 ++-
> >   libgomp/testsuite/libgomp.c++/for-27.C                  | 6 ++++++
> >   18 files changed, 35 insertions(+), 26 deletions(-)
> > 
> > diff --git a/gcc/c-family/c-opts.c b/gcc/c-family/c-opts.c
> > index 7695e88c130..5b266c06f3b 100644
> > --- a/gcc/c-family/c-opts.c
> > +++ b/gcc/c-family/c-opts.c
> > @@ -256,9 +256,9 @@ c_common_init_options (unsigned int 
> > decoded_options_count,
> >       }
> >       }
> > -  /* Set C++ standard to C++14 if not specified on the command line.  */
> > +  /* Set C++ standard to C++17 if not specified on the command line.  */
> >     if (c_dialect_cxx ())
> > -    set_std_cxx14 (/*ISO*/false);
> > +    set_std_cxx17 (/*ISO*/false);
> >     global_dc->colorize_source_p = true;
> >   }
> > diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> > index 850aeac033d..97e13421323 100644
> > --- a/gcc/doc/invoke.texi
> > +++ b/gcc/doc/invoke.texi
> > @@ -2057,7 +2057,6 @@ The name @samp{c++1y} is deprecated.
> >   @item gnu++14
> >   @itemx gnu++1y
> >   GNU dialect of @option{-std=c++14}.
> > -This is the default for C++ code.
> >   The name @samp{gnu++1y} is deprecated.
> >   @item c++17
> > @@ -2068,6 +2067,7 @@ The name @samp{c++1z} is deprecated.
> >   @item gnu++17
> >   @itemx gnu++1z
> >   GNU dialect of @option{-std=c++17}.
> > +This is the default for C++ code.
> >   The name @samp{gnu++1z} is deprecated.
> >   @item c++20
> > diff --git a/gcc/doc/standards.texi b/gcc/doc/standards.texi
> > index f39d8b378f1..fc5016028dd 100644
> > --- a/gcc/doc/standards.texi
> > +++ b/gcc/doc/standards.texi
> > @@ -130,7 +130,7 @@ select an extended version of the C language explicitly 
> > with
> >   extensions).
> >   The default, if no C language dialect options are given,
> > -is @option{-std=gnu11}.
> > +is @option{-std=gnu17}.
> 
> I don't think you mean to change the default C dialect.

The current default C dialect already is gnu17, here I was just correcting that
as a drive-by.  I can commit it separately if you prefer.

> >   The ISO C standard defines (in clause 4) two classes of conforming
> >   implementation.  A @dfn{conforming hosted implementation} supports the
> > @@ -246,7 +246,7 @@ select an extended version of the C++ language 
> > explicitly with
> >   @option{-std=gnu++17} (for C++17 with GNU extensions).
> >   The default, if
> > -no C++ language dialect options are given, is @option{-std=gnu++14}.
> > +no C++ language dialect options are given, is @option{-std=gnu++17}.
> >   @section Objective-C and Objective-C++ Languages
> >   @cindex Objective-C
> > diff --git a/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c 
> > b/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c
> > index bb5c91485d7..12779af5438 100644
> > --- a/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c
> > +++ b/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c
> > @@ -12,9 +12,9 @@ struct vec_s {
> >   int main () {
> > -  register short vector v0 = {1,2,3,4,5,6,7};
> > -  register myvec_t v1 = {1,2,3,4,5,6,7};
> > -  register struct vec_s v2;
> > +  short vector v0 = {1,2,3,4,5,6,7};
> > +  myvec_t v1 = {1,2,3,4,5,6,7};
> > +  struct vec_s v2;
> 
> I'd be careful about changing a c-c++-common torture test like this. Maybe
> #define away register for C++17 and up, or add -Wno-register in C++ mode
> like you do for other testcases?

Done.

> >     v2.member = v1;
> > diff --git a/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C 
> > b/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C
> > index aacfac875b1..4d7e547920f 100644
> > --- a/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C
> > +++ b/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C
> > @@ -1,5 +1,5 @@
> > -// This macro should not be defined without -std=c++17.
> > +// This macro should be defined with -std=c++17.
> > -#ifdef __cpp_enumerator_attributes
> > +#ifndef __cpp_enumerator_attributes
> 
> You're turning this file into the same test as attributes-enum-1.C, and it's
> intended to be the complementary test.  Instead, restrict the test to
> pre-C++17.

Indeed, that was sloppy.  This test (and the other) is now c++14_down.  It was
annoying to find out that only adding the target didn't suffice -- it seems
that dejagnu's proc check-flags happily accepts -std flags in comments too, so
it thought that we specified -std=c++17 and it didn't run the test in any other
mode.  Fixed by tweaking the comment...

> >   #error __cpp_enumerator_attributes defined
> >   #endif
> > diff --git a/gcc/testsuite/g++.dg/cpp1z/fold7a.C 
> > b/gcc/testsuite/g++.dg/cpp1z/fold7a.C
> > index 5c782ff0969..530741d3907 100644
> > --- a/gcc/testsuite/g++.dg/cpp1z/fold7a.C
> > +++ b/gcc/testsuite/g++.dg/cpp1z/fold7a.C
> > @@ -1,5 +1,5 @@
> > -// This macro should not be defined without -std=c++17.
> > +// This macro should be defined with -std=c++17.
> > -#ifdef __cpp_fold_expressions
> > +#ifndef __cpp_fold_expressions
> 
> Likewise.

^

> >   #error __cpp_fold_expressions defined
> >   #endif
> > diff --git a/gcc/testsuite/g++.dg/cpp1z/nontype3a.C 
> > b/gcc/testsuite/g++.dg/cpp1z/nontype3a.C
> > index a704e5045b6..7b640e551b6 100644
> > --- a/gcc/testsuite/g++.dg/cpp1z/nontype3a.C
> > +++ b/gcc/testsuite/g++.dg/cpp1z/nontype3a.C
> > @@ -1,5 +1,5 @@
> > -// This macro should not be defined without -std=c++17.
> > +// This macro should be defined with -std=c++17.
> > -#ifdef __cpp_nontype_template_args
> > +#ifndef __cpp_nontype_template_args
> 
> Likewise.

^

> >   #error __cpp_nontype_template_args defined
> >   #endif
> > diff --git a/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C 
> > b/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C
> > index 0e243d68a75..c4a8f46fb7d 100644
> > --- a/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C
> > +++ b/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C
> > @@ -1,5 +1,5 @@
> > -// This macro should not be 201411 without -std=c++17.
> > +// This macro should be 201411 with -std=c++17.
> > -#if __cpp_unicode_characters == 201411
> > +#if __cpp_unicode_characters != 201411
> 
> Likewise.

^

> >   #error Wrong value for __cpp_unicode_characters
> >   #endif
> > diff --git a/gcc/testsuite/g++.dg/parse/error11.C 
> > b/gcc/testsuite/g++.dg/parse/error11.C
> > index 1a49d6edb12..4e2a7f8b75f 100644
> > --- a/gcc/testsuite/g++.dg/parse/error11.C
> > +++ b/gcc/testsuite/g++.dg/parse/error11.C
> > @@ -1,5 +1,6 @@
> > -// { dg-do compile }
> > -// { dg-options "-fshow-column" }"
> > +// { dg-do compile { target c++14_down } }
> > +// C++17 removed trigraphs.
> 
> There are no trigraphs in this testcase, and digraphs are still part of
> C++20.

True.  In C++17 we issue slightly different diagnostics for lines 51 and 52,
and I thought it was so because trigraphs had been removed.  I've updated
the expected error messages instead.  Is that acceptable?

> > +// { dg-options "-fshow-column" }
> >   // Origin: Giovanni Bajo <giovannibajo at gcc dot gnu dot org>
> >   // Try to find out when the digraph '<:' is used as a mistake, and parse 
> > it
> >   //  correctly to avoid cascaded errors.
> > diff --git a/gcc/testsuite/g++.dg/torture/pr34850.C 
> > b/gcc/testsuite/g++.dg/torture/pr34850.C
> > index c4d808c5a0d..59dd5dfde7d 100644
> > --- a/gcc/testsuite/g++.dg/torture/pr34850.C
> > +++ b/gcc/testsuite/g++.dg/torture/pr34850.C
> > @@ -1,6 +1,6 @@
> >   /* { dg-do compile } */
> >   /* { dg-skip-if "" { *-*-* } { "-O0" } { "" } } */
> > -/* { dg-options "-ffat-lto-objects -Wno-return-type" } */
> > +/* { dg-options "-ffat-lto-objects -Wno-return-type 
> > -Wno-attribute-warning" } */
> 
> Why?

Sorry, this was non-obvious.

This boils down to

void __warn_memset_zero_len() __attribute__((__warning__("")));
long b;
void foo() throw()
{
  if (__builtin_constant_p(b))
    __warn_memset_zero_len();
}
int bar() { foo(); }

In C++17, with -O2, we give

t.C:6:27: warning: call to '__warn_memset_zero_len' declared with attribute 
warning:  [-Wattribute-warning]
    6 |     __warn_memset_zero_len();

while in C++14 we don't.  We behave differently due to...

26006   /* In C++17, throw() is equivalent to noexcept (true).  throw()
26007      is deprecated in C++11 and above as well, but is still widely used,
26008      so don't warn about it yet.  */
26009   else if (cxx_dialect >= cxx17)
26010     type_id_list = noexcept_true_spec;
26011   else
26012     type_id_list = empty_except_spec;

...and different optimizations based on that.  In C++17, we inline foo, and
then CCP folds the __builtin_constant_p call and we end up with

bar () {
  __warn_memset_zero_len ();
  __builtin_unreachable ();
}

and since __warn_memset_zero_len is marked with the warning attribute,
expand_expr_real_1 warns.

In C++14 we don't inline foo, but VRP removes the code inside foo, DCE then
elides the call to foo completely, and we end up without the call to
__warn_memset_zero_len so we don't warn.

Note that bar misses a return statement, which can be UB at runtime.  This
doesn't strike me as a C++ FE issue.

> >   typedef unsigned char uint8_t;
> >   typedef unsigned int uint32_t;
> > diff --git a/gcc/testsuite/g++.dg/torture/pr49394.C 
> > b/gcc/testsuite/g++.dg/torture/pr49394.C
> > index 7bd8fd4dc72..32e1a98ce05 100644
> > --- a/gcc/testsuite/g++.dg/torture/pr49394.C
> > +++ b/gcc/testsuite/g++.dg/torture/pr49394.C
> > @@ -10,7 +10,7 @@ struct Mutex
> >   #endif
> >     {
> >       if (locked)
> > -      throw 0;
> > +      throw 0; // { dg-warning ".throw. will always call .terminate." "" { 
> > target c++17 } }
> 
> Instead, the destructor should be noexcept(false) in C++17 and up.

Fixed.

> >     }
> >     void lock ()
> >     {
> > diff --git a/gcc/testsuite/g++.dg/torture/pr82154.C 
> > b/gcc/testsuite/g++.dg/torture/pr82154.C
> > index e229c3e640e..698340d8c65 100644
> > --- a/gcc/testsuite/g++.dg/torture/pr82154.C
> > +++ b/gcc/testsuite/g++.dg/torture/pr82154.C
> > @@ -1,5 +1,6 @@
> >   // { dg-do compile }
> > -// { dg-additional-options "-Wno-deprecated" }
> > +// { dg-additional-options "-std=c++14 -Wno-deprecated" }
> > +// C++17 does not allow dynamic exception specification.
> >   namespace a {
> >   int b;
> > diff --git a/gcc/testsuite/g++.dg/ubsan/pr85029.C 
> > b/gcc/testsuite/g++.dg/ubsan/pr85029.C
> > index 07472af16a5..836ce69cc15 100644
> > --- a/gcc/testsuite/g++.dg/ubsan/pr85029.C
> > +++ b/gcc/testsuite/g++.dg/ubsan/pr85029.C
> > @@ -1,7 +1,7 @@
> >   // PR sanitizer/85029
> >   // { dg-do compile }
> >   // { dg-skip-if "" { *-*-* } { "-flto -fno-fat-lto-objects" } }
> > -// { dg-options "-fsanitize=undefined" }
> > +// { dg-options "-fsanitize=undefined -Wno-register" }
> >   struct B {
> >     virtual B bar ();
> > diff --git a/gcc/testsuite/g++.dg/ubsan/vptr-12.C 
> > b/gcc/testsuite/g++.dg/ubsan/vptr-12.C
> > index f23bbc3fd10..ce57ba87db0 100644
> > --- a/gcc/testsuite/g++.dg/ubsan/vptr-12.C
> > +++ b/gcc/testsuite/g++.dg/ubsan/vptr-12.C
> > @@ -1,6 +1,6 @@
> >   // { dg-do run }
> >   // { dg-shouldfail "ubsan" }
> > -// { dg-options "-fsanitize=vptr -fno-sanitize-recover=vptr" }
> > +// { dg-options "-fsanitize=vptr -fno-sanitize-recover=vptr 
> > -fstrong-eval-order=some" }
> 
> Why?  I can't see anything in this testcase that should be affected by
> -fstrong-eval-order.

I think this points to a bug; I'd been meaning to come back to it but
apparently I never did.

I've investigated more now and opened https://gcc.gnu.org/PR95221 along with
my initial analysis.  I'm uncertain if this one should be a blocker for the
default change -- valid code should never hit it, after all --, though...

> >   struct MyClass
> >   {
> > diff --git a/gcc/testsuite/lib/target-supports.exp 
> > b/gcc/testsuite/lib/target-supports.exp
> > index 3e91a81dd5a..4191600fcd9 100644
> > --- a/gcc/testsuite/lib/target-supports.exp
> > +++ b/gcc/testsuite/lib/target-supports.exp
> > @@ -9018,7 +9018,7 @@ proc check_effective_target_c++ { } {
> >    return 0
> >   }
> > -set cxx_default "c++14"
> > +set cxx_default "c++17"
> >   # Check whether the current active language standard supports the features
> >   # of C++11/C++14 by checking for the presence of one of the -std flags.
> >   # This assumes that the default for the compiler is $cxx_default, and that
> > diff --git a/gcc/testsuite/obj-c++.dg/try-catch-9.mm 
> > b/gcc/testsuite/obj-c++.dg/try-catch-9.mm
> > index 73c7c991709..b2dc61b9989 100644
> > --- a/gcc/testsuite/obj-c++.dg/try-catch-9.mm
> > +++ b/gcc/testsuite/obj-c++.dg/try-catch-9.mm
> > @@ -6,7 +6,7 @@
> >   /* { dg-xfail-run-if "PR23616" { *-*-* } { "-fgnu-runtime" } { 
> > "-fnext-runtime" } } */
> >   /* { dg-xfail-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } 
> > } } { "-fnext-runtime" "-fgnu-runtime" } { "" } }
> >   /* { dg-prune-output ".*internal compiler error.*" } */
> > -/* { dg-options "-fobjc-exceptions -O2" } */
> > +/* { dg-options "-fobjc-exceptions -O2 -Wno-register" } */
> >   #include "../objc-obj-c++-shared/TestsuiteObject.m"
> >   #include <stdlib.h>
> > diff --git a/libgomp/testsuite/libgomp.c++/atomic-3.C 
> > b/libgomp/testsuite/libgomp.c++/atomic-3.C
> > index f957b2fece5..c02532d3206 100644
> > --- a/libgomp/testsuite/libgomp.c++/atomic-3.C
> > +++ b/libgomp/testsuite/libgomp.c++/atomic-3.C
> > @@ -1,5 +1,6 @@
> >   // { dg-do run }
> > -// { dg-options "-Wno-deprecated" }
> > +// C++17 forbids ++ on bool.
> > +// { dg-options "-Wno-deprecated -std=gnu++14" }
> >   extern "C" void abort (void);
> >   bool v, x1, x2, x3, x4, x5, x6;
> > diff --git a/libgomp/testsuite/libgomp.c++/for-27.C 
> > b/libgomp/testsuite/libgomp.c++/for-27.C
> > index 7dca4305f85..d286346e63a 100644
> > --- a/libgomp/testsuite/libgomp.c++/for-27.C
> > +++ b/libgomp/testsuite/libgomp.c++/for-27.C
> > @@ -151,6 +151,12 @@ f4 (const I<int> &x, const I<int> &y)
> >       else if (results[i])                          \
> >         abort ()
> > +// FIXME: OpenMP seems to count on this being instantiated; the copy
> > +// constructor is called in functions fn2/fn3/fn4.  But in C++17 we
> > +// elide this copy constructor, so it's never been instantiated.  For
> > +// now instantiate it explicitly.
> 
> This sounds like a bug that needs to be fixed before the default can change.
> I guess the openmp code needs to mark_used the copy constructor or the like.

...this makes sense.  I've opened https://gcc.gnu.org/PR95197 to handle this;
I think either Jakub or I should be able to fix it before long.

Bootstrapped/regtested on x86_64-pc-linux-gnu.

-- >8 --
Since GCC 9, C++17 support is no longer experimental.  It was too late
to change the default C++ dialect to C++17 in GCC 10, but I think now
it's time to pull the trigger (C++14 was made the default in GCC 6.1).
We're still missing two C++17 library features, but that shouldn't stop
us.  See
<https://gcc.gnu.org/onlinedocs/libstdc++/manual/status.html#status.iso.2017>
and
<https://gcc.gnu.org/projects/cxx-status.html#cxx17>
for the C++17 status.

I won't list all C++17 features here, but just a few heads-up:

- trigraphs were removed (hardly anyone cares, unless your keyboard is
  missing the # key),
- operator++(bool) was removed (so some tests now run in C++14 and down
  only),
- the keyword register was removed (some legacy code might trip on
  this),
- noexcept specification is now part of the type system and C++17 does
  not allow dynamic exception specifications anymore (the empty throw
  specification is still available, but it is deprecated),
- the evaluation order rules are different in C++17,
- static constexpr data members are now implicitly inline (which makes
  them definitions),
- C++17 requires guaranteed copy elision, meaning that a copy/move
  constructor call might be elided completely.  That means that if
  something relied on a constructor being instantiated via e.g. copying
  a function parameter, it might now fail.

I'll post an update for cxx-status.html and add a new caveat to changes.html
once this is in.

        * doc/invoke.texi (C Dialect Options): Adjust -std default for C++.
        * doc/standards.texi (C Language): Correct the default dialect.
        (C++ Language): Update the default for C++ to gnu++17.

        * c-opts.c (c_common_init_options): Default to gnu++17.

        * c-c++-common/torture/vector-subscript-3.c: In C++17, define away
        the keyword register.
        * g++.dg/cpp1z/attributes-enum-1a.C: Only run pre-C++17.
        * g++.dg/cpp1z/fold7a.C: Likewise.
        * g++.dg/cpp1z/nontype3a.C: Likewise.
        * g++.dg/cpp1z/utf8-2a.C: Likewise.
        * g++.dg/parse/error11.C: Update expected diagnostics for C++17.
        * g++.dg/torture/pr34850.C: Add -Wno-attribute-warning.
        * g++.dg/torture/pr49394.C: In C++17, use noexcept(false).
        * g++.dg/torture/pr82154.C: Use -std=c++14.
        * g++.dg/ubsan/pr85029.C: Use -Wno-register.
        * g++.dg/ubsan/vptr-12.C: Use -fstrong-eval-order=some.  Adjust
        dg-output.
        * lib/target-supports.exp: Set to C++17.
        * obj-c++.dg/try-catch-9.mm: Use -Wno-register.

        * testsuite/libgomp.c++/atomic-3.C: Use -std=gnu++14.
---
 gcc/c-family/c-opts.c                          |  4 ++--
 gcc/doc/invoke.texi                            |  2 +-
 gcc/doc/standards.texi                         |  4 ++--
 .../c-c++-common/torture/vector-subscript-3.c  |  3 +++
 .../g++.dg/cpp1z/attributes-enum-1a.C          |  3 ++-
 gcc/testsuite/g++.dg/cpp1z/fold7a.C            |  3 ++-
 gcc/testsuite/g++.dg/cpp1z/nontype3a.C         |  3 ++-
 gcc/testsuite/g++.dg/cpp1z/utf8-2a.C           |  3 ++-
 gcc/testsuite/g++.dg/parse/error11.C           | 18 +++++++++++-------
 gcc/testsuite/g++.dg/torture/pr34850.C         |  2 +-
 gcc/testsuite/g++.dg/torture/pr49394.C         |  2 ++
 gcc/testsuite/g++.dg/torture/pr82154.C         |  3 ++-
 gcc/testsuite/g++.dg/ubsan/pr85029.C           |  2 +-
 gcc/testsuite/g++.dg/ubsan/vptr-12.C           |  5 +++--
 gcc/testsuite/lib/target-supports.exp          |  2 +-
 gcc/testsuite/obj-c++.dg/try-catch-9.mm        |  2 +-
 libgomp/testsuite/libgomp.c++/atomic-3.C       |  3 ++-
 17 files changed, 40 insertions(+), 24 deletions(-)

diff --git a/gcc/c-family/c-opts.c b/gcc/c-family/c-opts.c
index 7695e88c130..5b266c06f3b 100644
--- a/gcc/c-family/c-opts.c
+++ b/gcc/c-family/c-opts.c
@@ -256,9 +256,9 @@ c_common_init_options (unsigned int decoded_options_count,
          }
     }
 
-  /* Set C++ standard to C++14 if not specified on the command line.  */
+  /* Set C++ standard to C++17 if not specified on the command line.  */
   if (c_dialect_cxx ())
-    set_std_cxx14 (/*ISO*/false);
+    set_std_cxx17 (/*ISO*/false);
 
   global_dc->colorize_source_p = true;
 }
diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
index 7217e27151d..c1acb8a70c2 100644
--- a/gcc/doc/invoke.texi
+++ b/gcc/doc/invoke.texi
@@ -2057,7 +2057,6 @@ The name @samp{c++1y} is deprecated.
 @item gnu++14
 @itemx gnu++1y
 GNU dialect of @option{-std=c++14}.
-This is the default for C++ code.
 The name @samp{gnu++1y} is deprecated.
 
 @item c++17
@@ -2068,6 +2067,7 @@ The name @samp{c++1z} is deprecated.
 @item gnu++17
 @itemx gnu++1z
 GNU dialect of @option{-std=c++17}.
+This is the default for C++ code.
 The name @samp{gnu++1z} is deprecated.
 
 @item c++20
diff --git a/gcc/doc/standards.texi b/gcc/doc/standards.texi
index f39d8b378f1..fc5016028dd 100644
--- a/gcc/doc/standards.texi
+++ b/gcc/doc/standards.texi
@@ -130,7 +130,7 @@ select an extended version of the C language explicitly with
 extensions).  
 
 The default, if no C language dialect options are given,
-is @option{-std=gnu11}.  
+is @option{-std=gnu17}.
 
 The ISO C standard defines (in clause 4) two classes of conforming
 implementation.  A @dfn{conforming hosted implementation} supports the
@@ -246,7 +246,7 @@ select an extended version of the C++ language explicitly 
with
 @option{-std=gnu++17} (for C++17 with GNU extensions).  
 
 The default, if
-no C++ language dialect options are given, is @option{-std=gnu++14}.
+no C++ language dialect options are given, is @option{-std=gnu++17}.
 
 @section Objective-C and Objective-C++ Languages
 @cindex Objective-C
diff --git a/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c 
b/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c
index bb5c91485d7..05d24f49011 100644
--- a/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c
+++ b/gcc/testsuite/c-c++-common/torture/vector-subscript-3.c
@@ -10,6 +10,9 @@ struct vec_s {
     vector short member;
 };
 
+#if defined(__cplusplus) && __cplusplus >= 201703L
+#define register /* nothing */
+#endif
 
 int main () {
   register short vector v0 = {1,2,3,4,5,6,7};
diff --git a/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C 
b/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C
index aacfac875b1..20f0b1d8876 100644
--- a/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C
+++ b/gcc/testsuite/g++.dg/cpp1z/attributes-enum-1a.C
@@ -1,4 +1,5 @@
-// This macro should not be defined without -std=c++17.
+// { dg-do compile { target c++14_down } }
+// This macro should not be defined without c++17.
 
 #ifdef __cpp_enumerator_attributes
 #error __cpp_enumerator_attributes defined
diff --git a/gcc/testsuite/g++.dg/cpp1z/fold7a.C 
b/gcc/testsuite/g++.dg/cpp1z/fold7a.C
index 5c782ff0969..8cca8792709 100644
--- a/gcc/testsuite/g++.dg/cpp1z/fold7a.C
+++ b/gcc/testsuite/g++.dg/cpp1z/fold7a.C
@@ -1,4 +1,5 @@
-// This macro should not be defined without -std=c++17.
+// { dg-do compile { target c++14_down } }
+// This macro should not be defined without c++17.
 
 #ifdef __cpp_fold_expressions
 #error __cpp_fold_expressions defined
diff --git a/gcc/testsuite/g++.dg/cpp1z/nontype3a.C 
b/gcc/testsuite/g++.dg/cpp1z/nontype3a.C
index a704e5045b6..b3ffe037904 100644
--- a/gcc/testsuite/g++.dg/cpp1z/nontype3a.C
+++ b/gcc/testsuite/g++.dg/cpp1z/nontype3a.C
@@ -1,4 +1,5 @@
-// This macro should not be defined without -std=c++17.
+// { dg-do compile { target c++14_down } }
+// This macro should not be defined without c++17.
 
 #ifdef __cpp_nontype_template_args
 #error __cpp_nontype_template_args defined
diff --git a/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C 
b/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C
index 0e243d68a75..b2a99a99023 100644
--- a/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C
+++ b/gcc/testsuite/g++.dg/cpp1z/utf8-2a.C
@@ -1,4 +1,5 @@
-// This macro should not be 201411 without -std=c++17.
+// { dg-do compile { target c++14_down } }
+// This macro should not be 201411 without c++17.
 
 #if __cpp_unicode_characters == 201411
 #error Wrong value for __cpp_unicode_characters
diff --git a/gcc/testsuite/g++.dg/parse/error11.C 
b/gcc/testsuite/g++.dg/parse/error11.C
index 1a49d6edb12..4baf97e531d 100644
--- a/gcc/testsuite/g++.dg/parse/error11.C
+++ b/gcc/testsuite/g++.dg/parse/error11.C
@@ -1,5 +1,5 @@
 // { dg-do compile }
-// { dg-options "-fshow-column" }"
+// { dg-options "-fshow-column" }
 // Origin: Giovanni Bajo <giovannibajo at gcc dot gnu dot org>
 // Try to find out when the digraph '<:' is used as a mistake, and parse it
 //  correctly to avoid cascaded errors.
@@ -50,12 +50,16 @@ void func(void)
   //  the special error message.
   Foo<: :B> k2;     // { dg-bogus "cannot begin|alternate spelling" "smart 
error should not be triggered here" }
   Foo[:B> k1;       // { dg-bogus "cannot begin|alternate spelling" "smart 
error should not be triggered here" } 
-// { dg-error "6:missing template arguments before" "template" { target *-*-* 
} 51 }
-// { dg-error "9:expected primary-expression before ':' token" "primary" { 
target *-*-* } 51 }
-// { dg-error "8:expected '\]' before ':' token" "backslash" { target *-*-* } 
51 }
-// { dg-error "6:missing template arguments before" "template" { target *-*-* 
} 52 }
-// { dg-error "7:expected primary-expression before ':' token" "primary" { 
target *-*-* } 52 }
-// { dg-error "7:expected '\]' before ':' token" "backslash" { target *-*-* } 
52 }
+// { dg-error "6:missing template arguments before" "template" { target 
c++14_down } .-2 }
+// { dg-error "9:expected primary-expression before ':' token" "primary" { 
target c++14_down } .-3 }
+// { dg-error "8:expected '\]' before ':' token" "backslash" { target 
c++14_down } .-4 }
+// { dg-error "6:missing template arguments before" "template" { target 
c++14_down } .-4 }
+// { dg-error "7:expected primary-expression before ':' token" "primary" { 
target c++14_down } .-5 }
+// { dg-error "7:expected '\]' before ':' token" "backslash" { target 
c++14_down } .-6 }
+// { dg-error "9:expected identifier" "" { target c++17 } .-8 }
+// { dg-error "8:expected" "" { target c++17 } .-9 }
+// { dg-error "7:expected identifier" "" { target c++17 } .-9 }
+// { dg-error "7:expected" "" { target c++17 } .-10 }
 //
   int Foo[2];
   Foo[::value] = 0;
diff --git a/gcc/testsuite/g++.dg/torture/pr34850.C 
b/gcc/testsuite/g++.dg/torture/pr34850.C
index c4d808c5a0d..59dd5dfde7d 100644
--- a/gcc/testsuite/g++.dg/torture/pr34850.C
+++ b/gcc/testsuite/g++.dg/torture/pr34850.C
@@ -1,6 +1,6 @@
 /* { dg-do compile } */
 /* { dg-skip-if "" { *-*-* } { "-O0" } { "" } } */
-/* { dg-options "-ffat-lto-objects -Wno-return-type" } */
+/* { dg-options "-ffat-lto-objects -Wno-return-type -Wno-attribute-warning" } 
*/
 
 typedef unsigned char uint8_t;
 typedef unsigned int uint32_t;
diff --git a/gcc/testsuite/g++.dg/torture/pr49394.C 
b/gcc/testsuite/g++.dg/torture/pr49394.C
index 7bd8fd4dc72..75901a5d668 100644
--- a/gcc/testsuite/g++.dg/torture/pr49394.C
+++ b/gcc/testsuite/g++.dg/torture/pr49394.C
@@ -7,6 +7,8 @@ struct Mutex
   ~Mutex ()
 #if __cplusplus <= 201402L
   throw(int)                   // { dg-warning "deprecated" "" { target { 
c++11 && { ! c++17 } } } }
+#else
+  noexcept(false)
 #endif
   {
     if (locked)
diff --git a/gcc/testsuite/g++.dg/torture/pr82154.C 
b/gcc/testsuite/g++.dg/torture/pr82154.C
index e229c3e640e..698340d8c65 100644
--- a/gcc/testsuite/g++.dg/torture/pr82154.C
+++ b/gcc/testsuite/g++.dg/torture/pr82154.C
@@ -1,5 +1,6 @@
 // { dg-do compile }
-// { dg-additional-options "-Wno-deprecated" }
+// { dg-additional-options "-std=c++14 -Wno-deprecated" }
+// C++17 does not allow dynamic exception specification.
 
 namespace a {
 int b;
diff --git a/gcc/testsuite/g++.dg/ubsan/pr85029.C 
b/gcc/testsuite/g++.dg/ubsan/pr85029.C
index 07472af16a5..836ce69cc15 100644
--- a/gcc/testsuite/g++.dg/ubsan/pr85029.C
+++ b/gcc/testsuite/g++.dg/ubsan/pr85029.C
@@ -1,7 +1,7 @@
 // PR sanitizer/85029
 // { dg-do compile }
 // { dg-skip-if "" { *-*-* } { "-flto -fno-fat-lto-objects" } }
-// { dg-options "-fsanitize=undefined" }
+// { dg-options "-fsanitize=undefined -Wno-register" }
 
 struct B {
   virtual B bar ();
diff --git a/gcc/testsuite/g++.dg/ubsan/vptr-12.C 
b/gcc/testsuite/g++.dg/ubsan/vptr-12.C
index f23bbc3fd10..79d4290754e 100644
--- a/gcc/testsuite/g++.dg/ubsan/vptr-12.C
+++ b/gcc/testsuite/g++.dg/ubsan/vptr-12.C
@@ -1,6 +1,7 @@
 // { dg-do run }
 // { dg-shouldfail "ubsan" }
-// { dg-options "-fsanitize=vptr -fno-sanitize-recover=vptr" }
+// { dg-options "-fsanitize=vptr -fno-sanitize-recover=vptr 
-fstrong-eval-order=some" }
+// FIXME: See PR95221 for why we use a specific eval order.
 
 struct MyClass
 {
@@ -18,5 +19,5 @@ main ()
   return 0;
 }
 
-// { dg-output "\[^\n\r]*vptr-12.C:16:\[0-9]*: runtime error: member call on 
address 0x\[0-9a-fA-F]* which does not point to an object of type 
'MyClass'(\n|\r\n|\r)" }
+// { dg-output "\[^\n\r]*vptr-12.C:17:\[0-9]*: runtime error: member call on 
address 0x\[0-9a-fA-F]* which does not point to an object of type 
'MyClass'(\n|\r\n|\r)" }
 // { dg-output "0x\[0-9a-fA-F]*: note: object has invalid vptr" }
diff --git a/gcc/testsuite/lib/target-supports.exp 
b/gcc/testsuite/lib/target-supports.exp
index b335108358d..58638a3e189 100644
--- a/gcc/testsuite/lib/target-supports.exp
+++ b/gcc/testsuite/lib/target-supports.exp
@@ -9046,7 +9046,7 @@ proc check_effective_target_c++ { } {
  return 0
 }
 
-set cxx_default "c++14"
+set cxx_default "c++17"
 # Check whether the current active language standard supports the features
 # of C++11/C++14 by checking for the presence of one of the -std flags.
 # This assumes that the default for the compiler is $cxx_default, and that
diff --git a/gcc/testsuite/obj-c++.dg/try-catch-9.mm 
b/gcc/testsuite/obj-c++.dg/try-catch-9.mm
index 73c7c991709..b2dc61b9989 100644
--- a/gcc/testsuite/obj-c++.dg/try-catch-9.mm
+++ b/gcc/testsuite/obj-c++.dg/try-catch-9.mm
@@ -6,7 +6,7 @@
 /* { dg-xfail-run-if "PR23616" { *-*-* } { "-fgnu-runtime" } { 
"-fnext-runtime" } } */
 /* { dg-xfail-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } 
{ "-fnext-runtime" "-fgnu-runtime" } { "" } } 
 /* { dg-prune-output ".*internal compiler error.*" } */
-/* { dg-options "-fobjc-exceptions -O2" } */
+/* { dg-options "-fobjc-exceptions -O2 -Wno-register" } */
 
 #include "../objc-obj-c++-shared/TestsuiteObject.m"
 #include <stdlib.h>
diff --git a/libgomp/testsuite/libgomp.c++/atomic-3.C 
b/libgomp/testsuite/libgomp.c++/atomic-3.C
index f957b2fece5..c02532d3206 100644
--- a/libgomp/testsuite/libgomp.c++/atomic-3.C
+++ b/libgomp/testsuite/libgomp.c++/atomic-3.C
@@ -1,5 +1,6 @@
 // { dg-do run }
-// { dg-options "-Wno-deprecated" }
+// C++17 forbids ++ on bool.
+// { dg-options "-Wno-deprecated -std=gnu++14" }
 
 extern "C" void abort (void);
 bool v, x1, x2, x3, x4, x5, x6;

base-commit: a2d196e75cef95c2b70734ad02e94f9da0e769fe
-- 
Marek Polacek • Red Hat, Inc. • 300 A St, Boston, MA


Reply via email to