+2008-07-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/36871
+ PR c++/36872
+ * semantics.c (classtype_has_nothrow_assign_or_copy_p): Only check
+ copy constructors and copy assignment operators proper.
+
2008-07-21 Rafael Avila de Espindola <espindola@google.com>
* parser.c (cp_token): Remove in_system_header.
return false;
for (; fns; fns = OVL_NEXT (fns))
- if (!TYPE_NOTHROW_P (TREE_TYPE (OVL_CURRENT (fns))))
- return false;
+ {
+ tree fn = OVL_CURRENT (fns);
+
+ if (assign_p)
+ {
+ if (copy_fn_p (fn) == 0)
+ continue;
+ }
+ else if (copy_fn_p (fn) <= 0)
+ continue;
+
+ if (!TYPE_NOTHROW_P (TREE_TYPE (fn)))
+ return false;
+ }
return true;
}
+2008-07-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/36871
+ PR c++/36872
+ * g++.dg/ext/has_nothrow_copy.C: Rename to...
+ * g++.dg/ext/has_nothrow_copy-1.C: ... this.
+ * g++.dg/ext/has_nothrow_copy-2.C: New.
+ * g++.dg/ext/has_nothrow_copy-3.C: Likewise.
+ * g++.dg/ext/has_nothrow_copy-4.C: Likewise.
+ * g++.dg/ext/has_nothrow_copy-5.C: Likewise.
+ * g++.dg/ext/has_nothrow_copy-6.C: Likewise.
+ * g++.dg/ext/has_nothrow_copy-7.C: Likewise.
+
2008-07-21 Thomas Koenig <tkoenig@gcc.gnu.org>
PR libfortran/36773
--- /dev/null
+// { dg-do "run" }
+#include <cassert>
+
+struct A
+{
+ double a;
+ double b;
+};
+
+struct B
+{
+ A a;
+};
+
+struct C
+: public A { };
+
+struct D
+{
+ D(const D&) throw() { }
+};
+
+struct E
+{
+ E(const E&) throw(int) { }
+};
+
+struct E1
+{
+ E1(const E1&) throw(int) { throw int(); }
+};
+
+struct F
+{
+ F() throw() { }
+};
+
+struct G
+{
+ G() throw(int) { throw int(); }
+};
+
+struct H
+{
+ H(H&) throw(int) { }
+};
+
+struct H1
+{
+ H1(H1&) throw(int) { throw int(); }
+};
+
+struct I
+{
+ I(I&) throw(int) { }
+ I(const I&) throw() { }
+};
+
+struct I1
+{
+ I1(I1&) throw(int) { throw int(); }
+ I1(const I1&) throw() { }
+};
+
+struct J
+{
+ J(J&) throw() { }
+ J(const J&) throw() { }
+ J(volatile J&) throw() { }
+ J(const volatile J&) throw() { }
+};
+
+template<typename T>
+ bool
+ f()
+ { return __has_nothrow_copy(T); }
+
+template<typename T>
+ class My
+ {
+ public:
+ bool
+ f()
+ { return !!__has_nothrow_copy(T); }
+ };
+
+template<typename T>
+ class My2
+ {
+ public:
+ static const bool trait = __has_nothrow_copy(T);
+ };
+
+template<typename T>
+ const bool My2<T>::trait;
+
+template<typename T, bool b = __has_nothrow_copy(T)>
+ struct My3_help
+ { static const bool trait = b; };
+
+template<typename T, bool b>
+ const bool My3_help<T, b>::trait;
+
+template<typename T>
+ class My3
+ {
+ public:
+ bool
+ f()
+ { return My3_help<T>::trait; }
+ };
+
+#define PTEST(T) (__has_nothrow_copy(T) && f<T>() \
+ && My<T>().f() && My2<T>::trait && My3<T>().f())
+
+#define NTEST(T) (!__has_nothrow_copy(T) && !f<T>() \
+ && !My<T>().f() && !My2<T>::trait && !My3<T>().f())
+
+int main()
+{
+ assert (PTEST (int));
+ assert (NTEST (int (int)));
+ assert (NTEST (void));
+ assert (PTEST (A));
+ assert (PTEST (B));
+ assert (PTEST (C));
+ assert (NTEST (C[]));
+ assert (PTEST (D));
+ assert (NTEST (E));
+ assert (NTEST (E1));
+ assert (PTEST (F));
+ assert (PTEST (G));
+ assert (NTEST (H));
+ assert (NTEST (H1));
+ assert (NTEST (I));
+ assert (NTEST (I1));
+ assert (PTEST (J));
+
+ return 0;
+}
--- /dev/null
+// PR c++/36871
+// { 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); };
+
+int main ()
+{
+ assert (__has_nothrow_copy (A));
+ assert (__has_nothrow_copy (B));
+}
--- /dev/null
+// PR c++/36871
+// { dg-do "run" }
+#include <cassert>
+
+struct F {
+ F (const F&) throw () { }
+ template <class T> F (T) throw () { }
+};
+
+int main ()
+{
+ assert (__has_nothrow_copy (F));
+}
--- /dev/null
+// PR c++/36872
+// { dg-do "run" }
+#include <cassert>
+
+struct S {
+ S (const S&) throw ();
+ S (...) throw (int);
+};
+
+int main ()
+{
+ assert (__has_nothrow_copy (S));
+}
--- /dev/null
+// PR c++/36872
+// { dg-do "run" }
+#include <cassert>
+
+struct S {
+ S (const S&) throw ();
+ S (int) throw (int);
+};
+
+int main ()
+{
+ assert (__has_nothrow_copy (S));
+}
--- /dev/null
+// { dg-do "run" }
+#include <cassert>
+
+struct S {
+ S (S&) throw ();
+ S (const S&, int) throw (int);
+};
+
+int main ()
+{
+ assert (__has_nothrow_copy (S));
+}
--- /dev/null
+// { dg-do "run" }
+// { dg-options "-std=c++0x" }
+#include <cassert>
+
+struct S {
+ S (const S&) throw ();
+ S (S&&) throw (int);
+};
+
+int main ()
+{
+ assert (__has_nothrow_copy (S));
+}
+++ /dev/null
-// { dg-do "run" }
-#include <cassert>
-
-struct A
-{
- double a;
- double b;
-};
-
-struct B
-{
- A a;
-};
-
-struct C
-: public A { };
-
-struct D
-{
- D(const D&) throw() { }
-};
-
-struct E
-{
- E(const E&) throw(int) { }
-};
-
-struct E1
-{
- E1(const E1&) throw(int) { throw int(); }
-};
-
-struct F
-{
- F() throw() { }
-};
-
-struct G
-{
- G() throw(int) { throw int(); }
-};
-
-struct H
-{
- H(H&) throw(int) { }
-};
-
-struct H1
-{
- H1(H1&) throw(int) { throw int(); }
-};
-
-struct I
-{
- I(I&) throw(int) { }
- I(const I&) throw() { }
-};
-
-struct I1
-{
- I1(I1&) throw(int) { throw int(); }
- I1(const I1&) throw() { }
-};
-
-struct J
-{
- J(J&) throw() { }
- J(const J&) throw() { }
- J(volatile J&) throw() { }
- J(const volatile J&) throw() { }
-};
-
-template<typename T>
- bool
- f()
- { return __has_nothrow_copy(T); }
-
-template<typename T>
- class My
- {
- public:
- bool
- f()
- { return !!__has_nothrow_copy(T); }
- };
-
-template<typename T>
- class My2
- {
- public:
- static const bool trait = __has_nothrow_copy(T);
- };
-
-template<typename T>
- const bool My2<T>::trait;
-
-template<typename T, bool b = __has_nothrow_copy(T)>
- struct My3_help
- { static const bool trait = b; };
-
-template<typename T, bool b>
- const bool My3_help<T, b>::trait;
-
-template<typename T>
- class My3
- {
- public:
- bool
- f()
- { return My3_help<T>::trait; }
- };
-
-#define PTEST(T) (__has_nothrow_copy(T) && f<T>() \
- && My<T>().f() && My2<T>::trait && My3<T>().f())
-
-#define NTEST(T) (!__has_nothrow_copy(T) && !f<T>() \
- && !My<T>().f() && !My2<T>::trait && !My3<T>().f())
-
-int main()
-{
- assert (PTEST (int));
- assert (NTEST (int (int)));
- assert (NTEST (void));
- assert (PTEST (A));
- assert (PTEST (B));
- assert (PTEST (C));
- assert (NTEST (C[]));
- assert (PTEST (D));
- assert (NTEST (E));
- assert (NTEST (E1));
- assert (PTEST (F));
- assert (PTEST (G));
- assert (NTEST (H));
- assert (NTEST (H1));
- assert (NTEST (I));
- assert (NTEST (I1));
- assert (PTEST (J));
-
- return 0;
-}