diff options
author | Marshall Clow <mclow.lists@gmail.com> | 2015-05-27 20:15:33 +0000 |
---|---|---|
committer | Marshall Clow <mclow.lists@gmail.com> | 2015-05-27 20:15:33 +0000 |
commit | 263a0f7681825915b933c5941cf772bba2e8aee2 (patch) | |
tree | 7969a01c0e136a0c302cac75692706ce90d23cff /libcxx | |
parent | 66b682ab043dac8108b44b8a7069a547bb0071ee (diff) | |
download | bcm5719-llvm-263a0f7681825915b933c5941cf772bba2e8aee2.tar.gz bcm5719-llvm-263a0f7681825915b933c5941cf772bba2e8aee2.zip |
Fix PR#23647 - make_shared<volatile bool>
llvm-svn: 238354
Diffstat (limited to 'libcxx')
-rw-r--r-- | libcxx/include/memory | 4 | ||||
-rw-r--r-- | libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared/util.smartptr.shared.create/make_shared.volatile.pass.cpp | 61 |
2 files changed, 63 insertions, 2 deletions
diff --git a/libcxx/include/memory b/libcxx/include/memory index 4af72c3da0f..8dbc4cb9039 100644 --- a/libcxx/include/memory +++ b/libcxx/include/memory @@ -4040,14 +4040,14 @@ private: template <class _Yp> _LIBCPP_INLINE_VISIBILITY void - __enable_weak_this(const enable_shared_from_this<_Yp>* __e) _NOEXCEPT + __enable_weak_this(const volatile enable_shared_from_this<_Yp>* __e) _NOEXCEPT { if (__e) __e->__weak_this_ = *this; } _LIBCPP_INLINE_VISIBILITY - void __enable_weak_this(const void*) _NOEXCEPT {} + void __enable_weak_this(const volatile void*) _NOEXCEPT {} template <class _Up> friend class _LIBCPP_TYPE_VIS_ONLY shared_ptr; template <class _Up> friend class _LIBCPP_TYPE_VIS_ONLY weak_ptr; diff --git a/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared/util.smartptr.shared.create/make_shared.volatile.pass.cpp b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared/util.smartptr.shared.create/make_shared.volatile.pass.cpp new file mode 100644 index 00000000000..1045f9347b3 --- /dev/null +++ b/libcxx/test/std/utilities/memory/util.smartptr/util.smartptr.shared/util.smartptr.shared.create/make_shared.volatile.pass.cpp @@ -0,0 +1,61 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// <memory> + +// shared_ptr + +// template<class T, class... Args> shared_ptr<T> make_shared(Args&&... args); + +#include <memory> +#include <cassert> + +template <typename T> +void test(const T &t0) +{ + { + T t1 = t0; + std::shared_ptr<T> p0 = std::make_shared<T>(t0); + std::shared_ptr<T> p1 = std::make_shared<T>(t1); + assert(*p0 == t0); + assert(*p1 == t1); + } + + { + const T t1 = t0; + std::shared_ptr<const T> p0 = std::make_shared<const T>(t0); + std::shared_ptr<const T> p1 = std::make_shared<const T>(t1); + assert(*p0 == t0); + assert(*p1 == t1); + } + + { + volatile T t1 = t0; + std::shared_ptr<volatile T> p0 = std::make_shared<volatile T>(t0); + std::shared_ptr<volatile T> p1 = std::make_shared<volatile T>(t1); + assert(*p0 == t0); + assert(*p1 == t1); + } + + { + const volatile T t1 = t0; + std::shared_ptr<const volatile T> p0 = std::make_shared<const volatile T>(t0); + std::shared_ptr<const volatile T> p1 = std::make_shared<const volatile T>(t1); + assert(*p0 == t0); + assert(*p1 == t1); + } + +} + +int main() +{ + test<bool>(true); + test<int>(3); + test<double>(5.0); +} |