diff options
author | paolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-11-06 00:11:57 +0000 |
---|---|---|
committer | paolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-11-06 00:11:57 +0000 |
commit | e50a7faac600da70a5486a897460349160cec62e (patch) | |
tree | 68897208905b15c8ebef7fedfd4db48f0bbfa56e /libstdc++-v3/include/bits | |
parent | 567123633cde83d84b94e0051ac8668c03a33104 (diff) | |
download | gcc-e50a7faac600da70a5486a897460349160cec62e.tar.gz |
2010-11-05 Paolo Carlini <paolo.carlini@oracle.com>
* include/bits/shared_ptr.h (shared_ptr<>::__shared_ptr(),
shared_ptr<>::shared_ptr(nullptr_t), weak_ptr<>::weak_ptr(),
enable_shared_from_this::enable_shared_from_this()): Add constexpr
specifier.
* include/bits/shared_ptr_base.h (__shared_count::__shared_count(),
__shared_count::__shared_count(), __shared_ptr<>::__shared_ptr(),
__shared_ptr<>::__shared_ptr(nullptr_t), __weak_ptr<>::__weak_ptr(),
__enable_shared_from_this::__enable_shared_from_this()): Likewise.
* include/bits/unique_ptr.h (default_delete,
unique_ptr<>::unique_ptr(), unique_ptr<>::unique_ptr(nullptr_t)):
Likewise.
* testsuite/20_util/default_delete/cons/constexpr.cc: Do not xfail.
* testsuite/20_util/shared_ptr/cons/constexpr.cc: Remove, the test
cannot work for a non-literal type like std::shared_ptr.
* testsuite/20_util/weak_ptr/cons/constexpr.cc: Likewise.
* testsuite/util/testsuite_common_types.h: Add comments.
* testsuite/20_util/unique_ptr/cons/constexpr.cc: Likewise.
* testsuite/20_util/shared_ptr/cons/43820.cc: Adjust dg-error line
numbers.
* testsuite/20_util/weak_ptr/comparison/cmp_neg.cc: Likewise.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@166386 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3/include/bits')
-rw-r--r-- | libstdc++-v3/include/bits/shared_ptr.h | 14 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/shared_ptr_base.h | 18 | ||||
-rw-r--r-- | libstdc++-v3/include/bits/unique_ptr.h | 36 |
3 files changed, 39 insertions, 29 deletions
diff --git a/libstdc++-v3/include/bits/shared_ptr.h b/libstdc++-v3/include/bits/shared_ptr.h index 2d9e6f771a6..0e6f7a6d0b3 100644 --- a/libstdc++-v3/include/bits/shared_ptr.h +++ b/libstdc++-v3/include/bits/shared_ptr.h @@ -95,7 +95,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) * @brief Construct an empty %shared_ptr. * @post use_count()==0 && get()==0 */ - shared_ptr() : __shared_ptr<_Tp>() { } + constexpr shared_ptr() + : __shared_ptr<_Tp>() { } /** * @brief Construct a %shared_ptr that owns the pointer @a __p. @@ -104,7 +105,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) * @throw std::bad_alloc, in which case @c delete @a __p is called. */ template<typename _Tp1> - explicit shared_ptr(_Tp1* __p) : __shared_ptr<_Tp>(__p) { } + explicit shared_ptr(_Tp1* __p) + : __shared_ptr<_Tp>(__p) { } /** * @brief Construct a %shared_ptr that owns the pointer @a __p @@ -256,7 +258,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) * @param __p A null pointer constant. * @post use_count() == 0 && get() == nullptr */ - shared_ptr(nullptr_t __p) : __shared_ptr<_Tp>(__p) { } + constexpr shared_ptr(nullptr_t __p) + : __shared_ptr<_Tp>(__p) { } template<typename _Tp1> shared_ptr& @@ -387,7 +390,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) class weak_ptr : public __weak_ptr<_Tp> { public: - weak_ptr() : __weak_ptr<_Tp>() { } + constexpr weak_ptr() + : __weak_ptr<_Tp>() { } template<typename _Tp1, typename = typename std::enable_if<std::is_convertible<_Tp1*, _Tp*>::value>::type> @@ -466,7 +470,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std) class enable_shared_from_this { protected: - enable_shared_from_this() { } + constexpr enable_shared_from_this() { } enable_shared_from_this(const enable_shared_from_this&) { } diff --git a/libstdc++-v3/include/bits/shared_ptr_base.h b/libstdc++-v3/include/bits/shared_ptr_base.h index 4a30ea4da6a..d39050fcc8d 100644 --- a/libstdc++-v3/include/bits/shared_ptr_base.h +++ b/libstdc++-v3/include/bits/shared_ptr_base.h @@ -443,7 +443,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std) class __shared_count { public: - __shared_count() : _M_pi(0) // nothrow + constexpr __shared_count() : _M_pi(0) // nothrow { } template<typename _Ptr> @@ -635,7 +635,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std) class __weak_count { public: - __weak_count() : _M_pi(0) // nothrow + constexpr __weak_count() : _M_pi(0) // nothrow { } __weak_count(const __shared_count<_Lp>& __r) : _M_pi(__r._M_pi) // nothrow @@ -751,11 +751,13 @@ _GLIBCXX_BEGIN_NAMESPACE(std) public: typedef _Tp element_type; - __shared_ptr() : _M_ptr(0), _M_refcount() // never throws + constexpr __shared_ptr() + : _M_ptr(0), _M_refcount() // never throws { } template<typename _Tp1> - explicit __shared_ptr(_Tp1* __p) : _M_ptr(__p), _M_refcount(__p) + explicit __shared_ptr(_Tp1* __p) + : _M_ptr(__p), _M_refcount(__p) { __glibcxx_function_requires(_ConvertibleConcept<_Tp1*, _Tp*>) static_assert( sizeof(_Tp1) > 0, "incomplete type" ); @@ -856,7 +858,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) #endif /* TODO: use delegating constructor */ - __shared_ptr(nullptr_t) : _M_ptr(0), _M_refcount() // never throws + constexpr __shared_ptr(nullptr_t) + : _M_ptr(0), _M_refcount() // never throws { } template<typename _Tp1> @@ -1163,7 +1166,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) public: typedef _Tp element_type; - __weak_ptr() : _M_ptr(0), _M_refcount() // never throws + constexpr __weak_ptr() + : _M_ptr(0), _M_refcount() // never throws { } // Generated copy constructor, assignment, destructor are fine. @@ -1324,7 +1328,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std) class __enable_shared_from_this { protected: - __enable_shared_from_this() { } + constexpr __enable_shared_from_this() { } __enable_shared_from_this(const __enable_shared_from_this&) { } diff --git a/libstdc++-v3/include/bits/unique_ptr.h b/libstdc++-v3/include/bits/unique_ptr.h index ebbc521873a..4dc4dddb28e 100644 --- a/libstdc++-v3/include/bits/unique_ptr.h +++ b/libstdc++-v3/include/bits/unique_ptr.h @@ -46,20 +46,20 @@ _GLIBCXX_BEGIN_NAMESPACE(std) /// Primary template, default_delete. template<typename _Tp> struct default_delete - { - default_delete() { } + { + constexpr default_delete() { } - template<typename _Up, typename = typename - std::enable_if<std::is_convertible<_Up*, _Tp*>::value>::type> - default_delete(const default_delete<_Up>&) { } + template<typename _Up, typename = typename + std::enable_if<std::is_convertible<_Up*, _Tp*>::value>::type> + default_delete(const default_delete<_Up>&) { } - void - operator()(_Tp* __ptr) const - { - static_assert(sizeof(_Tp)>0, - "can't delete pointer to incomplete type"); - delete __ptr; - } + void + operator()(_Tp* __ptr) const + { + static_assert(sizeof(_Tp)>0, + "can't delete pointer to incomplete type"); + delete __ptr; + } }; // _GLIBCXX_RESOLVE_LIB_DEFECTS @@ -68,6 +68,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) template<typename _Tp> struct default_delete<_Tp[]> { + constexpr default_delete() { } + void operator()(_Tp* __ptr) const { @@ -108,8 +110,8 @@ _GLIBCXX_BEGIN_NAMESPACE(std) "constructed with null function pointer deleter"); // Constructors. - unique_ptr() - : _M_t(pointer(), deleter_type()) + constexpr unique_ptr() + : _M_t() { } explicit @@ -129,7 +131,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std) { static_assert(!std::is_reference<deleter_type>::value, "rvalue deleter bound to reference"); } - unique_ptr(nullptr_t) + constexpr unique_ptr(nullptr_t) : _M_t(pointer(), deleter_type()) { } @@ -271,7 +273,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std) "constructed with null function pointer deleter"); // Constructors. - unique_ptr() + constexpr unique_ptr() : _M_t(pointer(), deleter_type()) { } @@ -292,7 +294,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std) "rvalue deleter bound to reference"); } /* TODO: use delegating constructor */ - unique_ptr(nullptr_t) + constexpr unique_ptr(nullptr_t) : _M_t(pointer(), deleter_type()) { } |