Define std::enable_shared_from_this::weak_from_this
authorJonathan Wakely <jwakely@redhat.com>
Thu, 4 Aug 2016 12:33:10 +0000 (13:33 +0100)
committerJonathan Wakely <redi@gcc.gnu.org>
Thu, 4 Aug 2016 12:33:10 +0000 (13:33 +0100)
* testsuite/20_util/enable_shared_from_this/members/reinit.cc: Use
effective target not dg-options. Move check for feature-test macro to:
* testsuite/20_util/enable_shared_from_this/members/weak_from_this.cc:
New test.

From-SVN: r239121

libstdc++-v3/ChangeLog
libstdc++-v3/include/bits/shared_ptr.h
libstdc++-v3/include/bits/shared_ptr_base.h
libstdc++-v3/testsuite/20_util/enable_shared_from_this/members/reinit.cc

index b124d757ff38d812177444d11167ddd5f4dc96fd..bf22550a6e38b9bce3c6e8b78b746d324750164f 100644 (file)
@@ -1,5 +1,10 @@
 2016-08-04  Jonathan Wakely  <jwakely@redhat.com>
 
+       * testsuite/20_util/enable_shared_from_this/members/reinit.cc: Use
+       effective target not dg-options. Move check for feature-test macro to:
+       * testsuite/20_util/enable_shared_from_this/members/weak_from_this.cc:
+       New test.
+
        * include/std/functional (_Unwrap): Rename to __inv_unwrap.
        (__invfwd): Adjust.
        (__invoke_impl): Remove unused template parameters.
index 483c2bcecd7750f233fdc9ff4c902ad4fd3beea9..747b09a2155e20dcb67b2c52242d2057751e09a9 100644 (file)
@@ -586,6 +586,17 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
       shared_from_this() const
       { return shared_ptr<const _Tp>(this->_M_weak_this); }
 
+#if __cplusplus > 201402L || !defined(__STRICT_ANSI__) // c++1z or gnu++11
+#define __cpp_lib_enable_shared_from_this 201603
+      weak_ptr<_Tp>
+      weak_from_this()
+      { return this->_M_weak_this; }
+
+      weak_ptr<const _Tp>
+      weak_from_this() const
+      { return this->_M_weak_this; }
+#endif
+
     private:
       template<typename _Tp1>
        void
index 2698ba453a6a5ac9c2d24574494e519ab5b2a94d..787dc9b865885045426be7238e4b4a6f5e370dab 100644 (file)
@@ -1472,7 +1472,6 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
       void
       _M_assign(_Tp* __ptr, const __shared_count<_Lp>& __refcount) noexcept
       {
-#define __cpp_lib_enable_shared_from_this 201603
        if (use_count() == 0)
          {
            _M_ptr = __ptr;
@@ -1557,6 +1556,16 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
       shared_from_this() const
       { return __shared_ptr<const _Tp, _Lp>(this->_M_weak_this); }
 
+#if __cplusplus > 201402L || !defined(__STRICT_ANSI__) // c++1z or gnu++11
+      __weak_ptr<_Tp, _Lp>
+      weak_from_this()
+      { return this->_M_weak_this; }
+
+      __weak_ptr<const _Tp, _Lp>
+      weak_from_this() const
+      { return this->_M_weak_this; }
+#endif
+
     private:
       template<typename _Tp1>
        void
index 1cf914805a478ef95df5a5d3b7a21993af5d55cf..3209f87026a4e593f59d7589cc5dc3484812b14f 100644 (file)
 // with this library; see the file COPYING3.  If not see
 // <http://www.gnu.org/licenses/>.
 
-// { dg-options "-std=gnu++11" }
+// { dg-do run { target c++11 } }
 
 #include <memory>
 #include <testsuite_hooks.h>
 
-#if __cpp_lib_enable_shared_from_this < 201603
-# error "__cpp_lib_enable_shared_from_this < 201603"
-#endif
-
 struct X : public std::enable_shared_from_this<X> { };
 
 bool