aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Wakely <jwakely@redhat.com>2023-08-08 16:24:31 +0100
committerJonathan Wakely <jwakely@redhat.com>2023-08-09 15:19:15 +0100
commit008e439f34d4b356825a6c9b70245143f00bd353 (patch)
treec5396025519c70fb32090e0c07cdd266b601fafc
parentb9e5a4b4f035ba85b1a4065b751c2d583206b4e3 (diff)
downloadgcc-008e439f34d4b356825a6c9b70245143f00bd353.zip
gcc-008e439f34d4b356825a6c9b70245143f00bd353.tar.gz
gcc-008e439f34d4b356825a6c9b70245143f00bd353.tar.bz2
libstdc++: Explicitly default some copy ctors and assignments
The standard says that the implicit copy assignment operator is deprecated for classes that have a user-provided copy constructor, and vice versa. libstdc++-v3/ChangeLog: * include/bits/new_allocator.h (__new_allocator): Define copy assignment operator as defaulted. * include/std/complex (complex<float>, complex<double>) (complex<long double>): Define copy constructor as defaulted.
-rw-r--r--libstdc++-v3/include/bits/new_allocator.h4
-rw-r--r--libstdc++-v3/include/std/complex13
2 files changed, 17 insertions, 0 deletions
diff --git a/libstdc++-v3/include/bits/new_allocator.h b/libstdc++-v3/include/bits/new_allocator.h
index 0a0b12e..3577002 100644
--- a/libstdc++-v3/include/bits/new_allocator.h
+++ b/libstdc++-v3/include/bits/new_allocator.h
@@ -96,6 +96,10 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
_GLIBCXX20_CONSTEXPR
__new_allocator(const __new_allocator<_Tp1>&) _GLIBCXX_USE_NOEXCEPT { }
+#if __cplusplus >= 201103L
+ __new_allocator& operator=(const __new_allocator&) = default;
+#endif
+
#if __cplusplus <= 201703L
~__new_allocator() _GLIBCXX_USE_NOEXCEPT { }
diff --git a/libstdc++-v3/include/std/complex b/libstdc++-v3/include/std/complex
index f01a3af..0ba2167 100644
--- a/libstdc++-v3/include/std/complex
+++ b/libstdc++-v3/include/std/complex
@@ -1359,6 +1359,10 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
}
#endif
+#if __cplusplus >= 201103L
+ _GLIBCXX14_CONSTEXPR complex(const complex&) = default;
+#endif
+
#if __cplusplus > 202002L
template<typename _Up>
explicit(!requires(_Up __u) { value_type{__u}; })
@@ -1512,6 +1516,10 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
}
#endif
+#if __cplusplus >= 201103L
+ _GLIBCXX14_CONSTEXPR complex(const complex&) = default;
+#endif
+
#if __cplusplus > 202002L
template<typename _Up>
explicit(!requires(_Up __u) { value_type{__u}; })
@@ -1666,6 +1674,10 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
}
#endif
+#if __cplusplus >= 201103L
+ _GLIBCXX14_CONSTEXPR complex(const complex&) = default;
+#endif
+
#if __cplusplus > 202002L
template<typename _Up>
explicit(!requires(_Up __u) { value_type{__u}; })
@@ -1901,6 +1913,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
// Let the compiler synthesize the copy and assignment
// operator. It always does a pretty good job.
+ constexpr complex(const complex&) = default;
constexpr complex& operator=(const complex&) = default;
template<typename _Up>