Hi! This patch attempts to implement the P0003R5 paper (I could find just traces of it in the github repo and the wording in n4618.pdf). I think throw() is still so commonly used that emitting deprecation warning for it is undesirable (in any mode).
Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk? I've tried to keep dynamic exception specification tests in the testsuite as much as possible even for -std=c++11 and -std=c++14, so often it means expecting the deprecation warning for those. For -std=c++1z, the behavior of throw() changes, it works as noexcept(true), so e.g. tests that expect the unexpected handler to be called had to be guarded for c++14_down. For destructors for C++17 typically I've been replacing throw (type-id-list) with noexcept(false), otherwise ifdefing it out, though in some testcases it has the dg-error lines to ensure it is properly rejected for C++17. Jonathan, there is one hunk in libstdc++ still needed (on top of what you've committed today). Is that ok with you? 2016-12-07 Jakub Jelinek <ja...@redhat.com> P0003R5 - removal of dynamic exception specification from C++17 * parser.c (cp_parser_exception_specification_opt): For C++17 error out on throw ( type-id-list ), for C++11 and C++14 issue -Wdeprecated warning on it. Formatting fix. Treat throw() in C++17 as noexcept(true). * g++.dg/template/error36.C: Adjust for deprecation of throw (type-id-list) in C++11 and C++14 and removal in C++17. * g++.dg/template/eh2.C: Likewise. * g++.dg/cpp1z/noexcept-type1.C: Likewise. * g++.dg/compat/eh/spec3_x.C: Likewise. * g++.dg/compat/eh/new1_y.C: Likewise. * g++.dg/compat/eh/new1_x.C: Likewise. * g++.dg/compat/eh/template1_y.C: Likewise. * g++.dg/compat/eh/template1.h: Likewise. * g++.dg/compat/eh/ctor1.h: Likewise. * g++.dg/compat/eh/ctor1_y.C: Likewise. * g++.dg/compat/eh/spec3_y.C: Likewise. * g++.dg/compat/eh/unexpected1_x.C: Likewise. * g++.dg/compat/eh/unexpected1_y.C: Likewise. * g++.dg/init/new13.C: Likewise. * g++.dg/init/new25.C: Likewise. * g++.dg/opt/noreturn-1.C: Likewise. * g++.dg/eh/spec3.C: Likewise. * g++.dg/eh/forced3.C: Likewise. * g++.dg/eh/forced4.C: Likewise. * g++.dg/eh/async-unwind2.C: Likewise. * g++.dg/eh/template1.C: Likewise. * g++.dg/eh/pr38662.C: Likewise. * g++.dg/eh/spec2.C: Likewise. * g++.dg/eh/shadow1.C: Likewise. * g++.dg/eh/spec7.C: Likewise. * g++.dg/eh/spec5.C: Likewise. * g++.dg/eh/spec6.C: Likewise. * g++.dg/eh/delete1.C: Likewise. * g++.dg/eh/spec9.C: Likewise. * g++.dg/eh/pr41819.C: Likewise. * g++.dg/eh/init-temp2.C: Likewise. * g++.dg/eh/ehopt1.C: Likewise. * g++.dg/eh/unexpected1.C: Likewise. * g++.dg/eh/cond4.C: Likewise. * g++.dg/eh/spec8.C: Likewise. * g++.dg/other/error3.C: Likewise. * g++.dg/rtti/crash3.C: Likewise. * g++.dg/warn/Wreturn-type-3.C: Likewise. * g++.dg/gcov/gcov-7.C: Likewise. * g++.dg/tree-ssa/pr45605.C: Likewise. * g++.dg/lookup/exception1.C: Likewise. * g++.dg/tm/pr46567.C: Likewise. * g++.dg/tm/pr47340.C: Likewise. * g++.dg/ext/has_nothrow_copy-1.C: Likewise. * g++.dg/ext/has_nothrow_copy-6.C: Likewise. * g++.dg/ext/has_nothrow_copy-7.C: Likewise. * g++.dg/ext/has_nothrow_copy-4.C: Likewise. * g++.dg/ext/has_nothrow_copy-2.C: Likewise. * g++.dg/ext/has_nothrow_assign.C: Likewise. * g++.dg/ext/has_nothrow_copy-5.C: Likewise. * g++.dg/ext/has_nothrow_constructor.C: Likewise. * g++.dg/torture/pr49394.C: Likewise. * g++.dg/torture/pr52918-1.C: Likewise. * g++.dg/torture/pr57190.C: Likewise. * g++.dg/torture/pr46364.C: Likewise. * g++.dg/torture/stackalign/eh-global-1.C: Likewise. * g++.dg/torture/stackalign/eh-fastcall-1.C: Likewise. * g++.dg/torture/stackalign/eh-vararg-2.C: Likewise. * g++.dg/torture/stackalign/eh-vararg-1.C: Likewise. * g++.dg/torture/stackalign/eh-inline-2.C: Likewise. * g++.dg/torture/stackalign/eh-thiscall-1.C: Likewise. * g++.dg/torture/stackalign/eh-inline-1.C: Likewise. * g++.dg/torture/stackalign/eh-alloca-1.C: Likewise. * g++.dg/cpp0x/variadic73.C: Likewise. * g++.dg/cpp0x/noexcept02.C: Likewise. * g++.dg/cpp0x/noexcept07.C: Likewise. * g++.dg/cpp0x/noexcept08.C: Likewise. * g++.dg/cpp0x/defaulted23.C: Likewise. * g++.dg/cpp0x/auto9.C: Likewise. * g++.dg/cpp0x/variadic-throw.C: Likewise. * g++.dg/cpp0x/error5.C: Likewise. * g++.dg/cpp0x/noexcept19.C: Likewise. * g++.dg/cpp0x/lambda/lambda-eh2.C: Likewise. * g++.old-deja/g++.robertl/eb123.C: Likewise. * g++.old-deja/g++.eh/throw1.C: Likewise. * g++.old-deja/g++.eh/spec3.C: Likewise. * g++.old-deja/g++.eh/spec4.C: Likewise. * g++.old-deja/g++.eh/spec2.C: Likewise. * g++.old-deja/g++.eh/tmpl3.C: Likewise. * g++.old-deja/g++.eh/spec6.C: Likewise. * g++.old-deja/g++.eh/cleanup2.C: Likewise. * g++.old-deja/g++.eh/spec1.C: Likewise. * g++.old-deja/g++.eh/throw2.C: Likewise. * g++.old-deja/g++.eh/tmpl1.C: Likewise. * g++.old-deja/g++.eh/badalloc1.C: Likewise. * g++.old-deja/g++.other/crash30.C: Likewise. * g++.old-deja/g++.other/new7.C: Likewise. * g++.old-deja/g++.other/crash28.C: Likewise. * g++.old-deja/g++.pt/ehspec1.C: Likewise. * g++.old-deja/g++.mike/eh51.C: Likewise. * g++.old-deja/g++.mike/eh15.C: Likewise. * g++.old-deja/g++.mike/eh50.C: Likewise. * g++.old-deja/g++.mike/p10416.C: Likewise. * g++.old-deja/g++.mike/eh33.C: Likewise. * g++.old-deja/g++.mike/eh25.C: Likewise. * g++.old-deja/g++.mike/eh34.C: Likewise. * g++.old-deja/g++.mike/eh55.C: Likewise. * testsuite/util/testsuite_new_operators.h: Include testsuite_hooks.h. (operator new): Use THROW macro. --- gcc/cp/parser.c.jj 2016-12-02 16:34:22.000000000 +0100 +++ gcc/cp/parser.c 2016-12-07 16:05:11.008689377 +0100 @@ -23786,8 +23786,8 @@ cp_parser_exception_specification_opt (c token = cp_lexer_peek_token (parser->lexer); /* Is it a noexcept-specification? */ - type_id_list = cp_parser_noexcept_specification_opt(parser, true, NULL, - false); + type_id_list = cp_parser_noexcept_specification_opt (parser, true, NULL, + false); if (type_id_list != NULL_TREE) return type_id_list; @@ -23795,12 +23795,7 @@ cp_parser_exception_specification_opt (c if (!cp_parser_is_keyword (token, RID_THROW)) return NULL_TREE; -#if 0 - /* Enable this once a lot of code has transitioned to noexcept? */ - if (cxx_dialect >= cxx11 && !in_system_header_at (input_location)) - warning (OPT_Wdeprecated, "dynamic exception specifications are " - "deprecated in C++0x; use %<noexcept%> instead"); -#endif + location_t loc = token->location; /* Consume the `throw'. */ cp_lexer_consume_token (parser->lexer); @@ -23821,7 +23816,23 @@ cp_parser_exception_specification_opt (c type_id_list = cp_parser_type_id_list (parser); /* Restore the saved message. */ parser->type_definition_forbidden_message = saved_message; + + if (cxx_dialect >= cxx1z) + { + error_at (loc, "ISO C++1z does not allow dynamic exception " + "specifications"); + type_id_list = NULL_TREE; + } + else if (cxx_dialect >= cxx11 && !in_system_header_at (input_location)) + warning_at (loc, OPT_Wdeprecated, + "dynamic exception specifications are deprecated in C++11;" + " use %<noexcept%> instead"); } + /* In C++17, throw() is equivalent to noexcept (true). throw() + is deprecated in C++11 and above as well, but is still widely used, + so don't warn about it yet. */ + else if (cxx_dialect >= cxx1z) + type_id_list = noexcept_true_spec; else type_id_list = empty_except_spec; --- gcc/testsuite/g++.dg/template/error36.C.jj 2015-05-29 15:04:33.199800941 +0200 +++ gcc/testsuite/g++.dg/template/error36.C 2016-12-07 15:38:27.089939388 +0100 @@ -1,9 +1,11 @@ // PR c++/37719.C +// { dg-do compile { target c++14_down } } template <typename T> class foo { void bar() throw(int); // { dg-message "throw \\(int\\)" } -}; +}; // { dg-warning "deprecated" "" { target c++11 } .-1 } template <> void foo<int>::bar() throw(float) {} // { dg-error "throw \\(float\\)" } + // { dg-warning "deprecated" "" { target c++11 } .-1 } --- gcc/testsuite/g++.dg/template/eh2.C.jj 2011-06-08 08:53:14.000000000 +0200 +++ gcc/testsuite/g++.dg/template/eh2.C 2016-12-07 15:36:56.703081777 +0100 @@ -1,10 +1,10 @@ // PR c++/23191 // Origin: Volker Reichelt <reich...@igpm.rwth-aachen.de> -// { dg-do compile } +// { dg-do compile { target c++14_down } } template<typename T> struct A { void foo() throw(typename T::X); // { dg-error "not a class" } -}; +}; // { dg-warning "deprecated" "" { target c++11 } .-1 } A<void> a; // { dg-message "required" } --- gcc/testsuite/g++.dg/cpp1z/noexcept-type1.C.jj 2016-11-09 15:22:33.911455208 +0100 +++ gcc/testsuite/g++.dg/cpp1z/noexcept-type1.C 2016-12-07 14:34:50.751229499 +0100 @@ -1,7 +1,7 @@ // Testcase from P0012r1 // { dg-options -std=c++1z } -void (*p)() throw(int); +void (*p)() throw(int); // { dg-error "dynamic exception specification" } void (**pp)() noexcept = &p; // { dg-error "" } cannot convert to pointer to noexcept function struct S { typedef void (*p)(); operator p(); }; --- gcc/testsuite/g++.dg/compat/eh/spec3_x.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/compat/eh/spec3_x.C 2016-12-07 13:31:41.947255194 +0100 @@ -1,6 +1,10 @@ #include "spec3.h" -extern void func () throw (B,A); +extern void func () +#if __cplusplus < 201103L +throw (B,A) +#endif +; void spec3_x (void) { --- gcc/testsuite/g++.dg/compat/eh/new1_y.C.jj 2008-10-23 13:21:05.000000000 +0200 +++ gcc/testsuite/g++.dg/compat/eh/new1_y.C 2016-12-07 13:31:16.879573416 +0100 @@ -4,7 +4,10 @@ extern int ret; void *ptr; -void * operator new[] (std::size_t s) throw (std::bad_alloc) +void * operator new[] (std::size_t s) +#if __cplusplus < 201103L +throw (std::bad_alloc) +#endif { ptr = operator new (s); return ptr; --- gcc/testsuite/g++.dg/compat/eh/new1_x.C.jj 2008-10-23 13:21:05.000000000 +0200 +++ gcc/testsuite/g++.dg/compat/eh/new1_x.C 2016-12-07 13:30:56.668829982 +0100 @@ -4,7 +4,11 @@ extern "C" void exit (int); extern "C" void abort (void); -extern void * operator new[] (std::size_t s) throw (std::bad_alloc); +extern void * operator new[] (std::size_t s) +#if __cplusplus < 201103L +throw (std::bad_alloc) +#endif +; extern void operator delete[] (void *p) throw (); struct A --- gcc/testsuite/g++.dg/compat/eh/template1_y.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/compat/eh/template1_y.C 2016-12-07 13:33:49.694633500 +0100 @@ -1,6 +1,9 @@ #include "template1.h" -template<class T> void C<T>::f (void) throw (E) +template<class T> void C<T>::f (void) +#if __cplusplus < 201103L +throw (E) +#endif { throw E(); } --- gcc/testsuite/g++.dg/compat/eh/template1.h.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/compat/eh/template1.h 2016-12-07 13:33:34.395827711 +0100 @@ -11,5 +11,9 @@ struct C { typedef B<T> D; typedef typename D::E E; - void f() throw(E); + void f() +#if __cplusplus < 201103L + throw(E) +#endif + ; }; --- gcc/testsuite/g++.dg/compat/eh/ctor1.h.jj 2015-05-07 19:54:51.814982313 +0200 +++ gcc/testsuite/g++.dg/compat/eh/ctor1.h 2016-12-07 13:30:15.080357929 +0100 @@ -5,6 +5,12 @@ struct Foo struct Bar { - ~Bar () throw(int); + ~Bar () +#if __cplusplus < 201103L + throw(int) +#else + noexcept(false) +#endif + ; Foo f; }; --- gcc/testsuite/g++.dg/compat/eh/ctor1_y.C.jj 2015-05-07 19:54:51.790982690 +0200 +++ gcc/testsuite/g++.dg/compat/eh/ctor1_y.C 2016-12-07 13:30:32.565135968 +0100 @@ -7,7 +7,12 @@ Foo::~Foo() was_f_in_Bar_destroyed=true; } -Bar::~Bar() throw(int) +Bar::~Bar() +#if __cplusplus < 201103L +throw(int) +#else +noexcept(false) +#endif { throw 1; } --- gcc/testsuite/g++.dg/compat/eh/spec3_y.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/compat/eh/spec3_y.C 2016-12-07 13:31:51.975127894 +0100 @@ -2,7 +2,10 @@ A::A() {} -void func() throw (B,A) +void func() +#if __cplusplus < 201103L +throw (B,A) +#endif { throw A(); } --- gcc/testsuite/g++.dg/compat/eh/unexpected1_x.C.jj 2014-09-25 15:02:37.312762134 +0200 +++ gcc/testsuite/g++.dg/compat/eh/unexpected1_x.C 2016-12-07 19:02:31.491176928 +0100 @@ -1,3 +1,5 @@ +// { dg-options "-std=c++98" } + #include <exception> struct One { }; --- gcc/testsuite/g++.dg/compat/eh/unexpected1_y.C.jj 2014-09-25 15:02:37.312762134 +0200 +++ gcc/testsuite/g++.dg/compat/eh/unexpected1_y.C 2016-12-07 19:02:06.694493863 +0100 @@ -1,3 +1,5 @@ +// { dg-options "-std=c++98" } + struct One { }; struct Two { }; --- gcc/testsuite/g++.dg/init/new13.C.jj 2010-11-09 13:58:19.000000000 +0100 +++ gcc/testsuite/g++.dg/init/new13.C 2016-12-07 15:23:02.668623042 +0100 @@ -6,6 +6,6 @@ struct A { void* operator new(__SIZE_TYPE__) throw(X); // { dg-error "expected|type" } -}; - +}; // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } A* p = new A; --- gcc/testsuite/g++.dg/init/new25.C.jj 2008-09-05 12:55:08.000000000 +0200 +++ gcc/testsuite/g++.dg/init/new25.C 2016-12-07 15:29:40.788591250 +0100 @@ -5,7 +5,11 @@ class C { public: void* operator new(std::size_t = 32) throw (std::bad_alloc); // { dg-error "first parameter" } + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } void* operator new[](std::size_t = 32) throw (std::bad_alloc); // { dg-error "first parameter" } + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } void* operator new(std::size_t = 32, const std::nothrow_t&) throw(); // { dg-error "first parameter" } void* operator new[](std::size_t = 32, const std::nothrow_t&) throw(); // { dg-error "first parameter" } }; --- gcc/testsuite/g++.dg/opt/noreturn-1.C.jj 2008-09-05 12:55:03.000000000 +0200 +++ gcc/testsuite/g++.dg/opt/noreturn-1.C 2016-12-07 15:33:25.889746222 +0100 @@ -58,16 +58,34 @@ struct Egeneric { }; struct infinint { - void detruit() throw(Egeneric); - template<class T> void infinint_from(T a) throw(Egeneric); - infinint(long a = 0) throw(Egeneric) { + void detruit() +#if __cplusplus <= 201402L + throw(Egeneric) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; + template<class T> void infinint_from(T a) +#if __cplusplus <= 201402L + throw(Egeneric) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; + infinint(long a = 0) +#if __cplusplus <= 201402L + throw(Egeneric) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + { try { infinint_from(a); } catch(Egeneric& e) { e.stack("infinint::infinint", "long"); } } - ~infinint() throw(Egeneric) { + ~infinint() +#if __cplusplus <= 201402L + throw(Egeneric) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + { try { detruit(); } catch(Egeneric& e) { } --- gcc/testsuite/g++.dg/eh/spec3.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/spec3.C 2016-12-07 15:01:54.270679549 +0100 @@ -12,7 +12,10 @@ struct A : virtual public Base struct B {}; -void func() throw (B,A) +void func() +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { throw A(); } --- gcc/testsuite/g++.dg/eh/forced3.C.jj 2014-09-25 15:02:39.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/forced3.C 2016-12-07 19:05:31.377877731 +0100 @@ -1,5 +1,6 @@ // HP-UX libunwind.so doesn't provide _UA_END_OF_STACK. // { dg-do run { xfail "ia64-hp-hpux11.*" } } +// { dg-require-effective-target c++14_down } // Test that forced unwinding calls std::unexpected going // through a nothrow function. --- gcc/testsuite/g++.dg/eh/forced4.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/forced4.C 2016-12-07 14:48:41.724712192 +0100 @@ -38,7 +38,10 @@ force_unwind () } static void -doit () throw(int) +doit () +#if __cplusplus <= 201402L +throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { force_unwind (); } --- gcc/testsuite/g++.dg/eh/async-unwind2.C.jj 2009-05-04 16:45:42.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/async-unwind2.C 2016-12-07 14:38:40.132326359 +0100 @@ -87,8 +87,16 @@ struct Y struct Z; -X <V> baz1 (const S &) throw (E); -X <Z> baz2 (const X <Z> &) throw (E); +X <V> baz1 (const S &) +#if __cplusplus <= 201402L +throw (E) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +; +X <Z> baz2 (const X <Z> &) +#if __cplusplus <= 201402L +throw (E) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +; template <typename T> X<T>::X () { @@ -112,7 +120,10 @@ template <typename T> T *X<T>::operator return &y; } -X <V> baz1 (const S &) throw (E) +X <V> baz1 (const S &) +#if __cplusplus <= 201402L +throw (E) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { return X<V> (); } @@ -125,7 +136,10 @@ E::~E () { } -X <Z> baz2 (const X <Z> &) throw (E) +X <Z> baz2 (const X <Z> &) +#if __cplusplus <= 201402L +throw (E) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { throw E (); } --- gcc/testsuite/g++.dg/eh/template1.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/template1.C 2016-12-07 15:07:04.513752069 +0100 @@ -17,7 +17,11 @@ struct C { typedef B<T> D; typedef typename D::E E; - void f() throw(E) { throw E(); } + void f() +#if __cplusplus <= 201402L + throw(E) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + { throw E(); } }; int main() --- gcc/testsuite/g++.dg/eh/pr38662.C.jj 2011-07-11 10:39:37.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/pr38662.C 2016-12-07 14:53:10.220313373 +0100 @@ -2,7 +2,11 @@ class E { }; class T { - int foo(bool a) throw (E) __attribute__((regparm(1))); + int foo(bool a) +#if __cplusplus <= 201402L + throw (E) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + __attribute__((regparm(1))); int bar(bool b) __attribute__((regparm(1))); }; --- gcc/testsuite/g++.dg/eh/spec2.C.jj 2016-11-09 15:22:33.366462111 +0100 +++ gcc/testsuite/g++.dg/eh/spec2.C 2016-12-07 15:01:05.088302136 +0100 @@ -3,8 +3,15 @@ struct S { void f (void); }; typedef void f1 (void) throw (int); // { dg-error "exception" "" { target c++14_down } } + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } typedef void (*f2) (void) throw (int); // { dg-error "exception" "" { target c++14_down } } + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } typedef void (S::*f3) (void) throw (int); // { dg-error "exception" "" { target c++14_down } } - -void (*f4) (void) throw (int); -void (S::*f5) (void) throw (int); + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } +void (*f4) (void) throw (int); // { dg-error "dynamic exception specification" "" { target c++1z } } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-1 } +void (S::*f5) (void) throw (int); // { dg-error "dynamic exception specification" "" { target c++1z } } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-1 } --- gcc/testsuite/g++.dg/eh/shadow1.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/shadow1.C 2016-12-07 14:57:53.030733346 +0100 @@ -13,14 +13,14 @@ struct D : private B friend class E; static B *baz (D *); - virtual void V () throw (B); // { dg-error "overriding" "" } -}; - + virtual void V () throw (B); // { dg-error "overriding" "" { target { ! c++1z } } } +}; // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } struct E : public D { - virtual void V () throw (D); // { dg-error "looser throw" "" } -}; - + virtual void V () throw (D); // { dg-error "looser throw" "" { target { ! c++1z } } } +}; // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-2 } B* foo (D *); B *D::baz (D *p) --- gcc/testsuite/g++.dg/eh/spec7.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/spec7.C 2016-12-07 15:04:24.300780355 +0100 @@ -19,7 +19,11 @@ struct D : public B { } o; struct Raiser { - Raiser() throw( int ) {throw 1;}; + Raiser() +#if __cplusplus <= 201402L + throw( int ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + {throw 1;}; } raiser; }; }; --- gcc/testsuite/g++.dg/eh/spec5.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/spec5.C 2016-12-07 15:02:59.918848525 +0100 @@ -8,12 +8,20 @@ struct A; struct B { - void f () throw (A); + void f () +#if __cplusplus <= 201402L + throw (A) +#endif + ; }; struct A {}; -void B::f () throw (A) {} +void B::f () +#if __cplusplus <= 201402L +throw (A) +#endif +{} int main () { --- gcc/testsuite/g++.dg/eh/spec6.C.jj 2014-05-20 16:36:55.544307894 +0200 +++ gcc/testsuite/g++.dg/eh/spec6.C 2016-12-07 15:03:39.730344561 +0100 @@ -1,6 +1,7 @@ // Test that we don't allow incomplete types in an exception-specification // for a definition, or at a call site. +// { dg-do compile { target c++14_down } } // { dg-options "-fpermissive -w" } struct A; // { dg-message "" } --- gcc/testsuite/g++.dg/eh/delete1.C.jj 2016-12-01 08:53:44.981183900 +0100 +++ gcc/testsuite/g++.dg/eh/delete1.C 2016-12-07 14:45:09.471398727 +0100 @@ -12,7 +12,13 @@ void operator delete (void *) throw () } struct Foo { - ~Foo() throw(int) {throw 1;} + ~Foo() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + {throw 1;} }; struct Baz { @@ -20,7 +26,13 @@ struct Baz { { deleted = 2; } - virtual ~Baz() throw(int) {throw 1;} + virtual ~Baz() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + {throw 1;} }; int non_virt () --- gcc/testsuite/g++.dg/eh/spec9.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/spec9.C 2016-12-07 15:06:19.148326402 +0100 @@ -4,7 +4,10 @@ typedef int IntArray[10]; IntArray i; -void test_array() throw (IntArray) +void test_array() +#if __cplusplus <= 201402L +throw (IntArray) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { throw i; } --- gcc/testsuite/g++.dg/eh/pr41819.C.jj 2009-10-28 14:57:00.000000000 +0100 +++ gcc/testsuite/g++.dg/eh/pr41819.C 2016-12-07 14:53:44.526879094 +0100 @@ -15,7 +15,10 @@ void f1() try {} catch (...) {} // { dg-error "" } } -void f2() throw(int) +void f2() +#if __cplusplus <= 201402L +throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { bar(); } --- gcc/testsuite/g++.dg/eh/init-temp2.C.jj 2015-05-07 19:54:50.846997518 +0200 +++ gcc/testsuite/g++.dg/eh/init-temp2.C 2016-12-07 14:49:35.017037578 +0100 @@ -8,18 +8,36 @@ template <class _Tp> class AutoPtr public: explicit AutoPtr(_Tp* __p = 0) : _M_ptr(__p) {} - ~AutoPtr() throw(int) { delete _M_ptr; } + ~AutoPtr() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + { delete _M_ptr; } }; struct A { A() { } - ~A() throw(int) { throw 1; } + ~A() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + { throw 1; } }; struct B { - virtual ~B() throw(int); + virtual ~B() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + ; }; B* f (const A &s) { throw 1; } --- gcc/testsuite/g++.dg/eh/ehopt1.C.jj 2015-05-07 19:54:50.825997848 +0200 +++ gcc/testsuite/g++.dg/eh/ehopt1.C 2016-12-07 14:47:54.669307855 +0100 @@ -15,7 +15,13 @@ class A<int, int> public: A(int) { ++count; if (b) throw 1; } A(const A&) { ++count; if (b) throw 1; } - ~A() throw(int) { --count; if (b) throw 1; } + ~A() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + { --count; if (b) throw 1; } }; typedef A<int, int> B; @@ -26,7 +32,13 @@ class A<void *, void *> public: A() { if (b) throw 1; } A(const B&) { if (b) throw 1; } - ~A() throw(int) { if (b) throw 1; } + ~A() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + { if (b) throw 1; } }; typedef A<void *, void *> C; --- gcc/testsuite/g++.dg/eh/unexpected1.C.jj 2008-09-05 12:55:05.000000000 +0200 +++ gcc/testsuite/g++.dg/eh/unexpected1.C 2016-12-07 15:08:42.459512060 +0100 @@ -1,6 +1,6 @@ // PR 3719 // Test that an unexpected handler can rethrow to categorize. -// { dg-do run } +// { dg-do run { target c++14_down } } #include <exception> @@ -23,7 +23,7 @@ handle_unexpected () } static void -doit () throw (Two) +doit () throw (Two) // { dg-warning "deprecated" "" { target { c++11 } } } { throw One (); } --- gcc/testsuite/g++.dg/eh/cond4.C.jj 2015-05-07 19:54:50.845997534 +0200 +++ gcc/testsuite/g++.dg/eh/cond4.C 2016-12-07 14:43:35.014594210 +0100 @@ -12,7 +12,13 @@ void my_terminate () struct A { A(int) { } - ~A() throw(int) { throw 1; }; + ~A() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + { throw 1; }; }; struct B { B(A) { } --- gcc/testsuite/g++.dg/eh/spec8.C.jj 2015-05-29 15:04:30.132848343 +0200 +++ gcc/testsuite/g++.dg/eh/spec8.C 2016-12-07 15:05:31.064935145 +0100 @@ -1,8 +1,10 @@ // PR c++/24817 +// { dg-do compile { target c++14_down } } struct exception {}; template <typename T> void foo() throw(exception); // { dg-message "declaration" } + // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-1 } template <typename T> void foo(); // { dg-error "exception" } struct bar --- gcc/testsuite/g++.dg/other/error3.C.jj 2015-05-29 11:36:05.291177791 +0200 +++ gcc/testsuite/g++.dg/other/error3.C 2016-12-07 19:09:20.186955337 +0100 @@ -1,5 +1,6 @@ // Test for proper error message formatting; the throw() should go inside // the parens, as below. -void (*g() throw())(); // { dg-message "g\\(\\) throw" "" } +void (*g() throw())(); // { dg-message "g\\(\\) throw" "" { target { ! c++1z } } } + // { dg-message "g\\(\\) noexcept" "" { target c++1z } .-1 } void (*g())(); // { dg-error "" "" } --- gcc/testsuite/g++.dg/rtti/crash3.C.jj 2008-09-05 12:55:02.000000000 +0200 +++ gcc/testsuite/g++.dg/rtti/crash3.C 2016-12-07 15:34:10.865177783 +0100 @@ -5,6 +5,9 @@ class A {}; class B {}; class C : public A, public B {}; class D : public C {}; -void f () throw (D) +void f () +#if __cplusplus <= 201402L +throw (D) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { } --- gcc/testsuite/g++.dg/warn/Wreturn-type-3.C.jj 2008-09-05 12:55:03.000000000 +0200 +++ gcc/testsuite/g++.dg/warn/Wreturn-type-3.C 2016-12-07 15:49:30.186572050 +0100 @@ -3,7 +3,10 @@ struct E{}; -inline int bar() throw(E) +inline int bar() +#if __cplusplus <= 201402L +throw(E) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { return 0; } --- gcc/testsuite/g++.dg/gcov/gcov-7.C.jj 2011-08-26 18:41:39.000000000 +0200 +++ gcc/testsuite/g++.dg/gcov/gcov-7.C 2016-12-07 15:20:18.702697512 +0100 @@ -7,7 +7,10 @@ struct foo { - foo () throw (int) + foo () +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { /* count (-) */ throw (1); } --- gcc/testsuite/g++.dg/tree-ssa/pr45605.C.jj 2015-05-29 15:04:33.040803399 +0200 +++ gcc/testsuite/g++.dg/tree-ssa/pr45605.C 2016-12-07 15:49:16.050750401 +0100 @@ -15,7 +15,11 @@ struct D : public B { } o; struct Raiser { - Raiser() throw( int ) {throw 1;}; + Raiser() +#if __cplusplus <= 201402L + throw( int ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + {throw 1;}; } raiser; }; }; --- gcc/testsuite/g++.dg/lookup/exception1.C.jj 2008-09-05 12:55:04.000000000 +0200 +++ gcc/testsuite/g++.dg/lookup/exception1.C 2016-12-07 15:31:12.938426579 +0100 @@ -11,8 +11,16 @@ namespace ns { class Test { public: - inline Test() throw( Exception ); - inline Test(int n ) throw( Exception ); + inline Test() +#if __cplusplus <= 201402L + throw( Exception ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; + inline Test(int n ) +#if __cplusplus <= 201402L + throw( Exception ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; private: int i; }; @@ -20,11 +28,19 @@ namespace ns // This line used to fail because Exception wasn't looked up in the // right scope. -ns::Test::Test() throw( Exception ) : i( 1 ) +ns::Test::Test() +#if __cplusplus <= 201402L +throw( Exception ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +: i( 1 ) { } -ns::Test::Test( int n ) throw( Exception ) : i( n ) +ns::Test::Test( int n ) +#if __cplusplus <= 201402L +throw( Exception ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +: i( n ) { } --- gcc/testsuite/g++.dg/tm/pr46567.C.jj 2011-11-08 23:35:11.499292345 +0100 +++ gcc/testsuite/g++.dg/tm/pr46567.C 2016-12-07 15:39:50.223889423 +0100 @@ -1667,8 +1667,16 @@ namespace std typedef void (*new_handler)(); new_handler set_new_handler(new_handler) throw(); } -void* operator new(std::size_t) throw (std::bad_alloc); -void* operator new[](std::size_t) throw (std::bad_alloc); +void* operator new(std::size_t) +#if __cplusplus <= 201402L +throw (std::bad_alloc) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +; +void* operator new[](std::size_t) +#if __cplusplus <= 201402L +throw (std::bad_alloc) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +; void operator delete(void*) throw(); void operator delete[](void*) throw(); void* operator new(std::size_t, const std::nothrow_t&) throw(); --- gcc/testsuite/g++.dg/tm/pr47340.C.jj 2011-11-08 23:35:11.500292339 +0100 +++ gcc/testsuite/g++.dg/tm/pr47340.C 2016-12-07 15:41:02.536977051 +0100 @@ -1,7 +1,11 @@ // { dg-do compile } // { dg-options "-fgnu-tm" } -void* operator new(__SIZE_TYPE__) throw (int); +void* operator new(__SIZE_TYPE__) +#if __cplusplus <= 201402L +throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +; void *point; --- gcc/testsuite/g++.dg/ext/has_nothrow_copy-1.C.jj 2011-02-25 19:01:44.000000000 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_copy-1.C 2016-12-07 15:14:35.899037460 +0100 @@ -15,6 +15,12 @@ struct B struct C : public A { }; +#if __cplusplus > 201402L +#define THROW_INT +#else +#define THROW_INT throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + struct D { D(const D&) throw() { } @@ -22,12 +28,12 @@ struct D struct E { - E(const E&) throw(int) { } + E(const E&) THROW_INT { } }; struct E1 { - E1(const E1&) throw(int) { throw int(); } + E1(const E1&) THROW_INT { throw int(); } }; struct F @@ -37,28 +43,28 @@ struct F struct G { - G() throw(int) { throw int(); } + G() THROW_INT { throw int(); } }; struct H { - H(H&) throw(int) { } + H(H&) THROW_INT { } }; struct H1 { - H1(H1&) throw(int) { throw int(); } + H1(H1&) THROW_INT { throw int(); } }; struct I { - I(I&) throw(int) { } + I(I&) THROW_INT { } I(const I&) throw() { } }; struct I1 { - I1(I1&) throw(int) { throw int(); } + I1(I1&) THROW_INT { throw int(); } I1(const I1&) throw() { } }; --- gcc/testsuite/g++.dg/ext/has_nothrow_copy-6.C.jj 2011-02-25 19:01:44.000000000 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_copy-6.C 2016-12-07 15:17:24.453903529 +0100 @@ -3,7 +3,11 @@ struct S { S (S&) throw (); - S (const S&, int) throw (int); + S (const S&, int) +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; int main () --- gcc/testsuite/g++.dg/ext/has_nothrow_copy-7.C.jj 2014-03-10 10:49:55.289085849 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_copy-7.C 2016-12-07 15:19:49.485067412 +0100 @@ -3,7 +3,11 @@ struct S { S (const S&) throw (); - S (S&&) throw (int); + S (S&&) +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { ! c++1z } } } +#endif + ; }; int main () --- gcc/testsuite/g++.dg/ext/has_nothrow_copy-4.C.jj 2011-02-25 19:01:44.000000000 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_copy-4.C 2016-12-07 15:16:26.702634670 +0100 @@ -4,7 +4,11 @@ struct S { S (const S&) throw (); - S (...) throw (int); + S (...) +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; int main () --- gcc/testsuite/g++.dg/ext/has_nothrow_copy-2.C.jj 2011-02-25 19:01:44.000000000 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_copy-2.C 2016-12-07 15:15:55.975023686 +0100 @@ -2,8 +2,21 @@ // { dg-do run } #include <cassert> -struct A { template <class T> A (T) throw (int); }; -struct B { B (B&) throw (); template <class T> B (T) throw (int); }; +struct A { + template <class T> A (T) +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; +}; +struct B { + B (B&) throw (); + template <class T> B (T) +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; +}; int main () { --- gcc/testsuite/g++.dg/ext/has_nothrow_assign.C.jj 2011-02-25 19:01:44.000000000 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_assign.C 2016-12-07 15:13:11.443106686 +0100 @@ -15,6 +15,12 @@ struct B struct C : public A { }; +#if __cplusplus > 201402L +#define THROW_INT +#else +#define THROW_INT throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + struct D { D& operator=(const D&) throw() { return *this; } @@ -22,43 +28,43 @@ struct D struct E { - E& operator=(const E&) throw(int) { return *this; } + E& operator=(const E&) THROW_INT { return *this; } }; struct E1 { - E1& operator=(const E1&) throw(int) { throw int(); return *this; } + E1& operator=(const E1&) THROW_INT { throw int(); return *this; } }; struct F { - F() throw(int) { } + F() THROW_INT { } }; struct G { - G() throw(int) { throw int(); } + G() THROW_INT { throw int(); } }; struct H { - H& operator=(H&) throw(int) { return *this; } + H& operator=(H&) THROW_INT { return *this; } }; struct H1 { - H1& operator=(H1&) throw(int) { throw int(); return *this; } + H1& operator=(H1&) THROW_INT { throw int(); return *this; } }; struct I { - I& operator=(I&) throw(int) { return *this; } + I& operator=(I&) THROW_INT { return *this; } I& operator=(const I&) throw() { return *this; } }; struct I1 { - I1& operator=(I1&) throw(int) { throw int(); return *this; } + I1& operator=(I1&) THROW_INT { throw int(); return *this; } I1& operator=(const I1&) throw() { return *this; } }; --- gcc/testsuite/g++.dg/ext/has_nothrow_copy-5.C.jj 2011-02-25 19:01:44.000000000 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_copy-5.C 2016-12-07 15:16:55.636268365 +0100 @@ -4,7 +4,11 @@ struct S { S (const S&) throw (); - S (int) throw (int); + S (int) +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; int main () --- gcc/testsuite/g++.dg/ext/has_nothrow_constructor.C.jj 2011-02-25 19:01:44.000000000 +0100 +++ gcc/testsuite/g++.dg/ext/has_nothrow_constructor.C 2016-12-07 15:14:00.923480256 +0100 @@ -12,6 +12,12 @@ struct B A a; }; +#if __cplusplus > 201402L +#define THROW_INT +#else +#define THROW_INT throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + struct C : public A { }; @@ -22,12 +28,12 @@ struct D struct E { - E() throw(int) { } + E() THROW_INT { } }; struct E1 { - E1() throw(int) { throw int(); } + E1() THROW_INT { throw int(); } }; struct F @@ -37,7 +43,7 @@ struct F struct G { - G(const G&) throw(int) { throw int(); } + G(const G&) THROW_INT { throw int(); } }; template<typename T> --- gcc/testsuite/g++.dg/torture/pr49394.C.jj 2015-05-07 19:54:51.019994801 +0200 +++ gcc/testsuite/g++.dg/torture/pr49394.C 2016-12-07 15:42:13.683079403 +0100 @@ -4,7 +4,10 @@ struct Mutex { bool locked; - ~Mutex () throw(int) + ~Mutex () +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { if (locked) throw 0; --- gcc/testsuite/g++.dg/torture/pr52918-1.C.jj 2012-04-19 11:09:00.154853167 +0200 +++ gcc/testsuite/g++.dg/torture/pr52918-1.C 2016-12-07 15:43:10.550361910 +0100 @@ -21,9 +21,16 @@ public: class free_list { typedef __mutex __mutex_type; __mutex_type& _M_get_mutex(); - void _M_get(size_t __sz) throw(bad_alloc); + void _M_get(size_t __sz) +#if __cplusplus <= 201402L + throw(bad_alloc) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; -void free_list::_M_get(size_t __sz) throw(bad_alloc) +void free_list::_M_get(size_t __sz) +#if __cplusplus <= 201402L +throw(bad_alloc) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { __mutex_type& __bfl_mutex = _M_get_mutex(); __bfl_mutex.unlock(); --- gcc/testsuite/g++.dg/torture/pr57190.C.jj 2013-05-09 10:02:23.185996812 +0200 +++ gcc/testsuite/g++.dg/torture/pr57190.C 2016-12-07 15:44:11.520592650 +0100 @@ -19,12 +19,24 @@ namespace std { class UIException { }; class PasswordDialog { - void run() throw (UIException); + void run() +#if __cplusplus <= 201402L + throw (UIException) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; class MessageBox { public: - MessageBox (std::string t) throw (UIException); - virtual int run() throw (UIException) ; + MessageBox (std::string t) +#if __cplusplus <= 201402L + throw (UIException) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; + virtual int run() +#if __cplusplus <= 201402L + throw (UIException) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; extern "C" { struct __jmp_buf_tag { @@ -33,7 +45,10 @@ extern "C" { typedef struct __jmp_buf_tag sigjmp_buf[1]; } sigjmp_buf password_dialog_sig_jmp_buf; -void PasswordDialog::run() throw (UIException) +void PasswordDialog::run() +#if __cplusplus <= 201402L +throw (UIException) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { __sigsetjmp (password_dialog_sig_jmp_buf, 1); MessageBox* errmsg = __null; --- gcc/testsuite/g++.dg/torture/pr46364.C.jj 2011-05-02 18:39:10.000000000 +0200 +++ gcc/testsuite/g++.dg/torture/pr46364.C 2016-12-07 15:41:27.614660647 +0100 @@ -1,7 +1,11 @@ // { dg-do compile } #include <string> -void a() throw (int); +void a() +#if __cplusplus <= 201402L +throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +; void b(std::string const &); void c(std::string *e) --- gcc/testsuite/g++.dg/torture/stackalign/eh-global-1.C.jj 2010-12-14 08:11:28.000000000 +0100 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-global-1.C 2016-12-07 15:45:50.697341340 +0100 @@ -21,7 +21,10 @@ struct A : virtual public Base struct B {}; void -foo (void) throw (B,A) +foo (void) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { aligned i; --- gcc/testsuite/g++.dg/torture/stackalign/eh-fastcall-1.C.jj 2011-07-11 10:39:37.000000000 +0200 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-fastcall-1.C 2016-12-07 15:45:20.791718658 +0100 @@ -21,7 +21,10 @@ struct B {}; __attribute__ ((fastcall)) void -foo (int j, int k, int m, int n, int o) throw (B,A) +foo (int j, int k, int m, int n, int o) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { aligned i; --- gcc/testsuite/g++.dg/torture/stackalign/eh-vararg-2.C.jj 2010-12-14 08:11:28.000000000 +0100 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-vararg-2.C 2016-12-07 15:48:05.132645173 +0100 @@ -29,7 +29,10 @@ struct A : virtual public Base struct B {}; void -test (va_list arg) throw (B,A) +test (va_list arg) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { char *p; aligned i; --- gcc/testsuite/g++.dg/torture/stackalign/eh-vararg-1.C.jj 2010-12-14 08:11:28.000000000 +0100 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-vararg-1.C 2016-12-07 15:47:32.512056746 +0100 @@ -28,7 +28,10 @@ struct A : virtual public Base struct B {}; void -foo (const char *fmt, ...) throw (B,A) +foo (const char *fmt, ...) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { va_list arg; char *p; --- gcc/testsuite/g++.dg/torture/stackalign/eh-inline-2.C.jj 2010-12-14 08:11:28.000000000 +0100 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-inline-2.C 2016-12-07 15:46:39.135730194 +0100 @@ -28,7 +28,10 @@ struct B {}; static void inline __attribute__((always_inline)) -foo (int size) throw (B,A) +foo (int size) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { char *p = (char *) __builtin_alloca (size + 1); aligned i; --- gcc/testsuite/g++.dg/torture/stackalign/eh-thiscall-1.C.jj 2011-07-11 10:39:37.000000000 +0200 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-thiscall-1.C 2016-12-07 15:47:01.133452649 +0100 @@ -21,7 +21,10 @@ struct B {}; __attribute__ ((thiscall)) void -foo (int j, int k, int m, int n, int o) throw (B,A) +foo (int j, int k, int m, int n, int o) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { aligned i; --- gcc/testsuite/g++.dg/torture/stackalign/eh-inline-1.C.jj 2010-12-14 08:11:28.000000000 +0100 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-inline-1.C 2016-12-07 15:46:15.482028632 +0100 @@ -22,7 +22,10 @@ struct B {}; static void inline __attribute__((always_inline)) -foo (void) throw (B,A) +foo (void) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { aligned i; --- gcc/testsuite/g++.dg/torture/stackalign/eh-alloca-1.C.jj 2010-12-14 08:11:28.000000000 +0100 +++ gcc/testsuite/g++.dg/torture/stackalign/eh-alloca-1.C 2016-12-07 15:44:42.794198072 +0100 @@ -27,7 +27,10 @@ struct A : virtual public Base struct B {}; void -foo (int size) throw (B,A) +foo (int size) +#if __cplusplus <= 201402L +throw (B,A) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { char *p = (char*) __builtin_alloca (size + 1); aligned i; --- gcc/testsuite/g++.dg/cpp0x/variadic73.C.jj 2014-03-10 10:50:13.179984365 +0100 +++ gcc/testsuite/g++.dg/cpp0x/variadic73.C 2016-12-07 14:31:27.142806449 +0100 @@ -3,7 +3,11 @@ struct A {}; struct B {}; struct C {}; -template<typename... Exceptions> void f(int idx) throw(Exceptions...) { +template<typename... Exceptions> void f(int idx) +#if __cplusplus <= 201402L +throw(Exceptions...) // { dg-warning "deprecated" "" { target { ! c++1z } } } +#endif +{ if (idx == 0) throw A(); else if (idx == 1) throw B(); else if (idx == 2) throw C(); --- gcc/testsuite/g++.dg/cpp0x/noexcept02.C.jj 2015-05-29 15:04:30.055849533 +0200 +++ gcc/testsuite/g++.dg/cpp0x/noexcept02.C 2016-12-07 14:23:16.208030209 +0100 @@ -10,8 +10,10 @@ void f(); SA(!noexcept(f())); -void g() throw (int); // { dg-message "previous declaration" } -void g() noexcept(false); // { dg-error "different exception" } +void g() throw (int); // { dg-message "previous declaration" "" { target { ! c++1z } } } + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { ! c++1z } } .-2 } +void g() noexcept(false); // { dg-error "different exception" "" { target { ! c++1z } } } void g(); void h() throw(); --- gcc/testsuite/g++.dg/cpp0x/noexcept08.C.jj 2014-03-10 10:50:13.229984081 +0100 +++ gcc/testsuite/g++.dg/cpp0x/noexcept08.C 2016-12-07 14:27:22.743903865 +0100 @@ -7,8 +7,8 @@ struct A virtual void g() throw(); virtual void h() noexcept; virtual void i() noexcept(false); - virtual void j() throw(int); -}; + virtual void j() throw(int); // { dg-error "dynamic exception specification" "" { target c++1z } } +}; // { dg-warning "deprecated" "" { target { ! c++1z } } .-1 } struct B: A { @@ -34,16 +34,23 @@ struct D: A void g() noexcept(false); // { dg-error "looser" } void h() noexcept(false); // { dg-error "looser" } void i() noexcept(false); - void j() noexcept(false); // { dg-error "looser" } + void j() noexcept(false); // { dg-error "looser" "" { target { ! c++1z } } } }; struct E: A { - void f() throw(int); + void f() throw(int); // { dg-error "dynamic exception specification" "" { target c++1z } } + // { dg-warning "deprecated" "" { target { ! c++1z } } .-1 } void g() throw(int); // { dg-error "looser" } + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { ! c++1z } } .-2 } void h() throw(int); // { dg-error "looser" } - void i() throw(int); - void j() throw(int); + // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { ! c++1z } } .-2 } + void i() throw(int); // { dg-error "dynamic exception specification" "" { target c++1z } } + // { dg-warning "deprecated" "" { target { ! c++1z } } .-1 } + void j() throw(int); // { dg-error "dynamic exception specification" "" { target c++1z } } + // { dg-warning "deprecated" "" { target { ! c++1z } } .-1 } }; struct F: A @@ -52,5 +59,5 @@ struct F: A void g(); // { dg-error "looser" } void h(); // { dg-error "looser" } void i(); - void j(); // { dg-error "looser" } + void j(); // { dg-error "looser" "" { target { ! c++1z } } } }; --- gcc/testsuite/g++.dg/cpp0x/defaulted23.C.jj 2014-03-10 10:50:13.175984387 +0100 +++ gcc/testsuite/g++.dg/cpp0x/defaulted23.C 2016-12-07 14:07:28.402048904 +0100 @@ -10,22 +10,22 @@ A a; struct B { - B() throw (int) = default; // { dg-message "exception-specification" } -}; - -B b; // { dg-error "deleted" } + B() throw (int) = default; // { dg-message "exception-specification" "" { target { ! c++1z } } } +}; // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + // { dg-warning "deprecated" "" { target { ! c++1z } } .-2 } +B b; // { dg-error "deleted" "" { target { ! c++1z } } } struct C { - C() throw (int) { } -}; + C() throw (int) { } // { dg-error "dynamic exception specification" "" { target c++1z } } +}; // { dg-warning "deprecated" "" { target { ! c++1z } } .-1 } C c; struct D: C { - D() throw (int) = default; -}; + D() throw (int) = default; // { dg-error "dynamic exception specification" "" { target c++1z } } +}; // { dg-warning "deprecated" "" { target { ! c++1z } } .-1 } D d; --- gcc/testsuite/g++.dg/cpp0x/auto9.C.jj 2016-11-09 23:55:13.725247159 +0100 +++ gcc/testsuite/g++.dg/cpp0x/auto9.C 2016-12-07 13:44:15.570698861 +0100 @@ -103,13 +103,13 @@ auto fnlate2 () -> auto *; // { dg-err void badthrow () throw (auto) // { dg-error "invalid use of" } -{ -} +{ // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } +} // { dg-warning "deprecated" "" { target { ! c++1z } } .-2 } void badthrow2 () throw (auto &) // { dg-error "invalid use of|expected" } -{ -} +{ // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } +} // { dg-warning "deprecated" "" { target { ! c++1z } } .-2 } template <auto V = 4> struct G {}; // { dg-error "auto" "" { target { ! c++1z } } } --- gcc/testsuite/g++.dg/cpp0x/variadic-throw.C.jj 2014-03-10 10:50:04.185035388 +0100 +++ gcc/testsuite/g++.dg/cpp0x/variadic-throw.C 2016-12-07 14:33:19.749381255 +0100 @@ -9,9 +9,9 @@ template<int M, int N> struct pair template<int... M> struct S { - template<int... N> static int foo() throw (pair <M, N>...) // { dg-error "mismatched" } - { - return 1; + template<int... N> static int foo() throw (pair <M, N>...) // { dg-error "mismatched" "" { target { ! c++1z } } } + { // { dg-error "dynamic exception specification" "" { target c++1z } .-1 } + return 1; // { dg-warning "deprecated" "" { target { ! c++1z } } .-2 } } }; @@ -22,5 +22,5 @@ int bar () int wibble() { - return S<0, 1, 2>::foo<0, 1> (); // { dg-error "no matching" } + return S<0, 1, 2>::foo<0, 1> (); // { dg-error "no matching" "" { target { ! c++1z } } } } --- gcc/testsuite/g++.dg/cpp0x/error5.C.jj 2014-03-10 10:50:13.263983888 +0100 +++ gcc/testsuite/g++.dg/cpp0x/error5.C 2016-12-07 14:16:33.269139914 +0100 @@ -39,7 +39,11 @@ namespace std struct bad_alloc { }; } -void* operator new(std::size_t) throw (std::bad_alloc); +void* operator new(std::size_t) +#if __cplusplus <= 201402L +throw (std::bad_alloc) // { dg-warning "deprecated" "" { target { ! c++1z } } } +#endif +; namespace std { --- gcc/testsuite/g++.dg/cpp0x/noexcept19.C.jj 2014-03-10 10:50:13.247983979 +0100 +++ gcc/testsuite/g++.dg/cpp0x/noexcept19.C 2016-12-07 14:30:17.184691867 +0100 @@ -22,7 +22,11 @@ struct C struct D { - D () throw (int); + D () +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { ! c++1z } } } +#endif + ; }; C <D, B <D>> c; --- gcc/testsuite/g++.dg/cpp0x/lambda/lambda-eh2.C.jj 2014-03-10 10:50:00.850054305 +0100 +++ gcc/testsuite/g++.dg/cpp0x/lambda/lambda-eh2.C 2016-12-07 14:18:13.799865074 +0100 @@ -1,7 +1,7 @@ // PR c++/47263 // PR c++/49260 // { dg-options "-fno-asynchronous-unwind-tables -fno-dwarf2-cfi-asm" } -// { dg-do run { target c++11 } } +// { dg-do run { target { c++11 && { ! c++1z } } } } #include <exception> @@ -10,7 +10,7 @@ int main( void ) std::set_unexpected( []{ throw 0; } ); try { - []() throw( int ) { throw nullptr; }(); + []() throw( int ) { throw nullptr; }(); // { dg-warning "deprecated" } } catch( int ) { } --- gcc/testsuite/g++.old-deja/g++.robertl/eb123.C.jj 2008-09-05 12:54:51.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.robertl/eb123.C 2016-12-07 16:20:26.684091391 +0100 @@ -2,7 +2,10 @@ // { dg-options "-O2 -W " } #include "stdio.h" -void writeNote() throw( int ) +void writeNote() +#if __cplusplus <= 201402L +throw( int ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { printf( "hello world\n" ); try { } --- gcc/testsuite/g++.old-deja/g++.eh/throw1.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/throw1.C 2016-12-07 16:02:09.660981764 +0100 @@ -1,6 +1,9 @@ // { dg-do assemble } -void athrow(const int & e) throw(int) +void athrow(const int & e) +#if __cplusplus <= 201402L +throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { throw e; } --- gcc/testsuite/g++.old-deja/g++.eh/spec3.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/spec3.C 2016-12-07 15:58:05.391069432 +0100 @@ -1,4 +1,4 @@ -// { dg-do run } +// { dg-do run { target c++14_down } } // Testing exception specifications. // Test 3: the bad_exception throw succeeds. @@ -9,7 +9,7 @@ void my_term () { exit (1); } void my_unexp () { throw 42; } void -f () throw (std::bad_exception) +f () throw (std::bad_exception) // { dg-warning "deprecated" "" { target c++11 } } { throw 'a'; } --- gcc/testsuite/g++.old-deja/g++.eh/spec4.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/spec4.C 2016-12-07 15:58:40.576624723 +0100 @@ -1,4 +1,4 @@ -// { dg-do run } +// { dg-do run { target c++14_down } } // Testing exception specifications. // Test 4: all throws fail, call terminate. @@ -9,7 +9,7 @@ void my_term () { exit (0); } void my_unexp () { throw 42; } void -f () throw (short) +f () throw (short) // { dg-warning "deprecated" "" { target c++11 } } { throw 'a'; } --- gcc/testsuite/g++.old-deja/g++.eh/spec2.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/spec2.C 2016-12-07 15:57:29.221526578 +0100 @@ -1,4 +1,4 @@ -// { dg-do run } +// { dg-do run { target c++14_down } } // Testing exception specifications. // Test 2: the second throw succeeds. @@ -9,7 +9,7 @@ void my_term () { exit (1); } void my_unexp () { throw 42; } void -f () throw (int, std::bad_exception) +f () throw (int, std::bad_exception) // { dg-warning "deprecated" "" { target c++11 } } { throw 'a'; } --- gcc/testsuite/g++.old-deja/g++.eh/tmpl3.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/tmpl3.C 2016-12-07 16:08:01.251537365 +0100 @@ -3,9 +3,16 @@ // Posted by Trevor Taylor <ttay...@powerup.com.au> template<class T> struct A { - void X() throw(T); + void X() +#if __cplusplus <= 201402L + throw(T) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; template<class T> inline void A<T>::X() -throw(T) { } +#if __cplusplus <= 201402L +throw(T) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif +{ } --- gcc/testsuite/g++.old-deja/g++.eh/spec6.C.jj 2015-05-29 15:03:02.262206440 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/spec6.C 2016-12-07 16:01:15.596665183 +0100 @@ -1,4 +1,5 @@ -// { dg-do assemble } +// { dg-do assemble { target c++14_down } } +// { dg-additional-options "-Wno-deprecated" } // Copyright (C) 1999 Free Software Foundation, Inc. // Contributed by Nathan Sidwell 19 Jan 1999 <nat...@acm.org> --- gcc/testsuite/g++.old-deja/g++.eh/cleanup2.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/cleanup2.C 2016-12-07 15:51:06.178360924 +0100 @@ -18,11 +18,18 @@ static int thrower () struct X { - X (int) throw (int); + X (int) +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; ~X () throw (); }; -X::X (int) throw (int) +X::X (int) +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif {printf ("in ctor X %s\n", __PRETTY_FUNCTION__); bad = true;} X::~X () throw () {printf ("in dtor X %s\n", __PRETTY_FUNCTION__); bad = true;} @@ -30,10 +37,17 @@ X::~X () throw () struct X1 {}; struct Y : X { - Y() throw (int); + Y() +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; ~Y() throw (); }; -Y::Y() throw (int) +Y::Y() +#if __cplusplus <= 201402L + throw (int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif : X(thrower ()) // throws, so X::X is never called {printf ("in ctor Y%s\n", __PRETTY_FUNCTION__); bad = true;} Y::~Y() throw () --- gcc/testsuite/g++.old-deja/g++.eh/spec1.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/spec1.C 2016-12-07 15:56:37.567179435 +0100 @@ -1,4 +1,4 @@ -// { dg-do run } +// { dg-do run { target c++14_down } } // Testing exception specifications. // Test 1: the original exception succeeds. @@ -9,7 +9,7 @@ void my_term () { exit (1); } void my_unexp () { throw 42; } void -f () throw (char, int, std::bad_exception) +f () throw (char, int, std::bad_exception) // { dg-warning "deprecated" "" { target c++11 } } { throw 'a'; } --- gcc/testsuite/g++.old-deja/g++.eh/throw2.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/throw2.C 2016-12-07 16:06:43.156524551 +0100 @@ -4,7 +4,10 @@ #define ANY int // a class with a public constructor -void athrow(const ANY & e) throw(ANY) +void athrow(const ANY & e) +#if __cplusplus <= 201402L +throw(ANY) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { throw e; // { dg-bogus "" } discarding const } --- gcc/testsuite/g++.old-deja/g++.eh/tmpl1.C.jj 2008-09-05 12:54:57.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.eh/tmpl1.C 2016-12-07 16:07:19.791061460 +0100 @@ -1,6 +1,9 @@ // { dg-do run } template <class T> -void f() throw (T) +void f() +#if __cplusplus <= 201402L +throw (T) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { throw 7; } --- gcc/testsuite/g++.old-deja/g++.other/crash30.C.jj 2008-09-05 12:54:53.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.other/crash30.C 2016-12-07 16:16:49.376858070 +0100 @@ -8,7 +8,7 @@ struct foo }; void foo::x() throw(bar) // { dg-error "" } parse error -{ +{ // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } .-1 } } void bar() --- gcc/testsuite/g++.old-deja/g++.other/new7.C.jj 2008-09-05 12:54:53.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.other/new7.C 2016-12-07 16:18:01.864935177 +0100 @@ -13,7 +13,10 @@ struct X { { throw 1; } - void* operator new ( std::size_t n ) throw ( std::bad_alloc ) + void* operator new ( std::size_t n ) +#if __cplusplus <= 201402L + throw ( std::bad_alloc ) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { new_flag = true; return ::operator new( n ); --- gcc/testsuite/g++.old-deja/g++.other/crash28.C.jj 2013-01-04 17:55:17.193795258 +0100 +++ gcc/testsuite/g++.old-deja/g++.other/crash28.C 2016-12-07 16:15:27.216899989 +0100 @@ -27,9 +27,16 @@ class foo bool b; public: foo(); - void x () throw(bar); + void x () +#if __cplusplus <= 201402L + throw(bar) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + ; }; -void foo::x() throw(bar) +void foo::x() +#if __cplusplus <= 201402L +throw(bar) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { if (!b) throw bar (static_cast<::N::X*>(this)); // { dg-error "lambda expressions|expected|invalid" } parse error } --- gcc/testsuite/g++.old-deja/g++.pt/ehspec1.C.jj 2008-09-05 12:54:56.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.pt/ehspec1.C 2016-12-07 16:19:53.465514318 +0100 @@ -1,6 +1,6 @@ -// { dg-do assemble } +// { dg-do assemble { target c++14_down } } // Bug: g++ forgets to instantiate A<int> // Contributed by Jason Merrill <ja...@cygnus.com> template <class T> struct A { }; -void f () throw (A<int>); +void f () throw (A<int>); // { dg-warning "deprecated" "" { target c++11 } } --- gcc/testsuite/g++.old-deja/g++.mike/eh51.C.jj 2008-09-05 12:54:56.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/eh51.C 2016-12-07 16:13:21.954483411 +0100 @@ -1,4 +1,5 @@ // { dg-do run { xfail sparc64-*-elf z8k-*-* arm-*-pe } } +// { dg-require-effective-target c++14_down } // { dg-options "-fexceptions" } #include <exception> @@ -7,7 +8,7 @@ void my_unexpected() { throw 42; } -template <class T> void foo(T) throw (T) { throw "Hi"; } +template <class T> void foo(T) throw (T) { throw "Hi"; } // { dg-warning "deprecated" "" { target c++11 } } main() { std::set_unexpected (my_unexpected); --- gcc/testsuite/g++.old-deja/g++.mike/eh15.C.jj 2008-09-05 12:54:56.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/eh15.C 2016-12-07 16:08:50.878910033 +0100 @@ -1,6 +1,6 @@ -// { dg-do assemble } +// { dg-do assemble { target c++14_down } } // { dg-options "-fexceptions" } struct A { - A() throw (int); + A() throw (int); // { dg-warning "deprecated" "" { target c++11 } } }; --- gcc/testsuite/g++.old-deja/g++.mike/eh50.C.jj 2008-09-05 12:54:56.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/eh50.C 2016-12-07 16:12:30.020139905 +0100 @@ -1,4 +1,5 @@ // { dg-do run { xfail sparc64-*-elf z8k-*-* arm-*-pe } } +// { dg-require-effective-target c++14_down } // { dg-options "-fexceptions" } #include <exception> @@ -7,7 +8,7 @@ void my_unexpected() { throw 42; } -template <class T> void foo(T) throw (int) { throw "Hi"; } +template <class T> void foo(T) throw (int) { throw "Hi"; } // { dg-warning "deprecated" "" { target c++11 } } main() { std::set_unexpected (my_unexpected); --- gcc/testsuite/g++.old-deja/g++.mike/p10416.C.jj 2008-09-05 12:54:56.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/p10416.C 2016-12-07 16:14:15.242809802 +0100 @@ -5,5 +5,9 @@ class not_ok { public: - void f() throw(int) { } + void f() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif + { } }; --- gcc/testsuite/g++.old-deja/g++.mike/eh33.C.jj 2008-09-05 12:54:56.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/eh33.C 2016-12-07 16:11:33.260857389 +0100 @@ -1,4 +1,5 @@ // { dg-do run { xfail sparc64-*-elf z8k-*-* arm-*-pe } } +// { dg-require-effective-target c++14_down } // { dg-options "-fexceptions" } #include <exception> @@ -7,7 +8,7 @@ void my_unexpected() { throw 42; } -void foo() throw (int) { throw "Hi"; } +void foo() throw (int) { throw "Hi"; } // { dg-warning "deprecated" "" { target c++11 } } int main() { std::set_unexpected (my_unexpected); --- gcc/testsuite/g++.old-deja/g++.mike/eh25.C.jj 2015-05-07 19:54:44.822092158 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/eh25.C 2016-12-07 16:09:43.797241101 +0100 @@ -10,7 +10,13 @@ void my_terminate() { struct A { A() { } - ~A() throw(int) { + ~A() +#if __cplusplus <= 201402L + throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#else + noexcept(false) +#endif + { std::set_terminate (my_terminate); throw 1; // This throws from EH dtor, should call my_terminate } --- gcc/testsuite/g++.old-deja/g++.mike/eh34.C.jj 2014-09-25 15:02:12.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/eh34.C 2016-12-07 19:31:56.642700848 +0100 @@ -1,4 +1,5 @@ // { dg-do run { xfail sparc64-*-elf arm-*-pe } } +// { dg-require-effective-target c++14_down } #include <exception> #include <stdlib.h> --- gcc/testsuite/g++.old-deja/g++.mike/eh55.C.jj 2014-09-25 15:02:12.000000000 +0200 +++ gcc/testsuite/g++.old-deja/g++.mike/eh55.C 2016-12-07 19:36:11.501463466 +0100 @@ -9,7 +9,7 @@ void my_terminate_handler() { } void throw_an_unexpected_exception() throw() { - throw 1; + throw 1; // { dg-warning "throw will always call terminate" "" { target c++1z } } } int main() { --- gcc/testsuite/g++.old-deja/g++.eh/badalloc1.C.jj 2015-01-22 17:32:41.000000000 +0100 +++ gcc/testsuite/g++.old-deja/g++.eh/badalloc1.C 2016-12-07 18:08:23.031234468 +0100 @@ -93,19 +93,28 @@ extern "C" void *realloc (void *p, size_ return r; } -void fn_throw() throw(int) +void fn_throw() +#if __cplusplus <= 201402L +throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { throw 1; } -void fn_rethrow() throw(int) +void fn_rethrow() +#if __cplusplus <= 201402L +throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { try{fn_throw();} catch(int a){ throw;} } -void fn_catchthrow() throw(int) +void fn_catchthrow() +#if __cplusplus <= 201402L +throw(int) // { dg-warning "deprecated" "" { target { c++11 && { ! c++1z } } } } +#endif { try{fn_throw();} catch(int a){ --- gcc/testsuite/g++.dg/cpp0x/noexcept07.C.jj 2014-09-25 15:02:39.927713093 +0200 +++ gcc/testsuite/g++.dg/cpp0x/noexcept07.C 2016-12-07 18:39:22.391804334 +0100 @@ -1,6 +1,6 @@ // Test that checking of a nothrow specification uses the one on the -// definition. -// { dg-do run { target c++11 } } +// definition. In C++17 throw() is equivalent to noexcept(true). +// { dg-do run { target { c++11 && c++14_down } } } #include <exception> #include <cstdlib> --- libstdc++-v3/testsuite/util/testsuite_new_operators.h.jj 2016-07-22 15:02:02.000000000 +0200 +++ libstdc++-v3/testsuite/util/testsuite_new_operators.h 2016-12-07 18:19:46.578561027 +0100 @@ -23,6 +23,7 @@ #define _GLIBCXX_TESTSUITE_NEW_OPERATORS_H #include <new> +#include <testsuite_hooks.h> namespace __gnu_test { @@ -38,7 +39,7 @@ namespace __gnu_test { get_new_limit() = l; } } -void* operator new(std::size_t size) throw(std::bad_alloc) +void* operator new(std::size_t size) THROW(std::bad_alloc) { if (size > __gnu_test::get_new_limit()) throw std::bad_alloc(); Jakub