diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-01-02 19:18:58 +0000 |
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-01-02 19:18:58 +0000 |
| commit | 53a420fba21cf1644972b34dcd811a43cdb8368d (patch) | |
| tree | 66a19f6f8b65215772549a51d688492ab8addc0d /test/libcxx/utilities/optional/optional.object | |
| parent | b50f1549701eb950921e5d6f2e55ba1a1dadbb43 (diff) | |
Notes
Diffstat (limited to 'test/libcxx/utilities/optional/optional.object')
5 files changed, 330 insertions, 0 deletions
diff --git a/test/libcxx/utilities/optional/optional.object/optional.object.assign/copy.pass.cpp b/test/libcxx/utilities/optional/optional.object/optional.object.assign/copy.pass.cpp new file mode 100644 index 000000000000..cc04e4e87f0c --- /dev/null +++ b/test/libcxx/utilities/optional/optional.object/optional.object.assign/copy.pass.cpp @@ -0,0 +1,74 @@ +//===----------------------------------------------------------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// <optional> + +// optional<T>& operator=(const optional<T>& rhs); + +#include <optional> +#include <string> +#include <type_traits> + +using std::optional; + +struct X {}; + +struct Y +{ + Y() = default; + Y& operator=(const Y&) { return *this; } +}; + +struct Z1 +{ + Z1() = default; + Z1(Z1&&) = default; + Z1(const Z1&) = default; + Z1& operator=(Z1&&) = default; + Z1& operator=(const Z1&) = delete; +}; + +struct Z2 +{ + Z2() = default; + Z2(Z2&&) = default; + Z2(const Z2&) = delete; + Z2& operator=(Z2&&) = default; + Z2& operator=(const Z2&) = default; +}; + +template <class T> +constexpr bool +test() +{ + optional<T> opt; + optional<T> opt2; + opt = opt2; + return true; +} + +int main() +{ + { + using T = int; + static_assert((std::is_trivially_copy_assignable<optional<T>>::value), ""); + static_assert(test<T>(), ""); + } + { + using T = X; + static_assert((std::is_trivially_copy_assignable<optional<T>>::value), ""); + static_assert(test<T>(), ""); + } + static_assert(!(std::is_trivially_copy_assignable<optional<Y>>::value), ""); + static_assert(!(std::is_trivially_copy_assignable<optional<std::string>>::value), ""); + + static_assert(!(std::is_copy_assignable<optional<Z1>>::value), ""); + static_assert(!(std::is_copy_assignable<optional<Z2>>::value), ""); +} diff --git a/test/libcxx/utilities/optional/optional.object/optional.object.assign/move.pass.cpp b/test/libcxx/utilities/optional/optional.object/optional.object.assign/move.pass.cpp new file mode 100644 index 000000000000..6f421153cafb --- /dev/null +++ b/test/libcxx/utilities/optional/optional.object/optional.object.assign/move.pass.cpp @@ -0,0 +1,71 @@ +//===----------------------------------------------------------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// <optional> + +// optional<T>& operator=(optional<T>&& rhs); + +#include <optional> +#include <string> +#include <type_traits> +#include <utility> + +using std::optional; + +struct X {}; + +struct Y +{ + Y() = default; + Y& operator=(Y&&) { return *this; } +}; + +struct Z1 +{ + Z1() = default; + Z1(Z1&&) = default; + Z1& operator=(Z1&&) = delete; +}; + +struct Z2 +{ + Z2() = default; + Z2(Z2&&) = delete; + Z2& operator=(Z2&&) = default; +}; + +template <class T> +constexpr bool +test() +{ + optional<T> opt; + optional<T> opt2; + opt = std::move(opt2); + return true; +} + +int main() +{ + { + using T = int; + static_assert((std::is_trivially_copy_constructible<optional<T>>::value), ""); + static_assert(test<T>(), ""); + } + { + using T = X; + static_assert((std::is_trivially_copy_constructible<optional<T>>::value), ""); + static_assert(test<T>(), ""); + } + static_assert(!(std::is_trivially_move_assignable<optional<Y>>::value), ""); + static_assert(!(std::is_trivially_move_assignable<optional<std::string>>::value), ""); + + static_assert(!(std::is_move_assignable<optional<Z1>>::value), ""); + static_assert(!(std::is_move_assignable<optional<Z2>>::value), ""); +} diff --git a/test/libcxx/utilities/optional/optional.object/optional.object.ctor/copy.pass.cpp b/test/libcxx/utilities/optional/optional.object/optional.object.ctor/copy.pass.cpp new file mode 100644 index 000000000000..62eb6cd34880 --- /dev/null +++ b/test/libcxx/utilities/optional/optional.object/optional.object.ctor/copy.pass.cpp @@ -0,0 +1,59 @@ +//===----------------------------------------------------------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: c++98, c++03, c++11, c++14 + +// <optional> + +// optional(const optional<T>& rhs); + +#include <optional> +#include <string> +#include <type_traits> + +using std::optional; + +struct X {}; + +struct Y +{ + Y() = default; + Y(const Y&) {} +}; + +struct Z +{ + Z() = default; + Z(Z&&) = delete; + Z(const Z&) = delete; + Z& operator=(Z&&) = delete; + Z& operator=(const Z&) = delete; +}; + +int main() +{ + { + using T = int; + static_assert((std::is_trivially_copy_constructible<optional<T>>::value), ""); + constexpr optional<T> opt; + constexpr optional<T> opt2 = opt; + (void)opt2; + } + { + using T = X; + static_assert((std::is_trivially_copy_constructible<optional<T>>::value), ""); + constexpr optional<T> opt; + constexpr optional<T> opt2 = opt; + (void)opt2; + } + static_assert(!(std::is_trivially_copy_constructible<optional<Y>>::value), ""); + static_assert(!(std::is_trivially_copy_constructible<optional<std::string>>::value), ""); + + static_assert(!(std::is_copy_constructible<optional<Z>>::value), ""); +} diff --git a/test/libcxx/utilities/optional/optional.object/optional.object.ctor/move.pass.cpp b/test/libcxx/utilities/optional/optional.object/optional.object.ctor/move.pass.cpp new file mode 100644 index 000000000000..f13ca92e2807 --- /dev/null +++ b/test/libcxx/utilities/optional/optional.object/optional.object.ctor/move.pass.cpp @@ -0,0 +1,60 @@ +//===----------------------------------------------------------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: c++98, c++03, c++11, c++14 + +// <optional> + +// optional(optional<T>&& rhs); + +#include <optional> +#include <string> +#include <type_traits> +#include <utility> + +using std::optional; + +struct X {}; + +struct Y +{ + Y() = default; + Y(Y&&) {} +}; + +struct Z +{ + Z() = default; + Z(Z&&) = delete; + Z(const Z&) = delete; + Z& operator=(Z&&) = delete; + Z& operator=(const Z&) = delete; +}; + +int main() +{ + { + using T = int; + static_assert((std::is_trivially_copy_constructible<optional<T>>::value), ""); + constexpr optional<T> opt; + constexpr optional<T> opt2 = std::move(opt); + (void)opt2; + } + { + using T = X; + static_assert((std::is_trivially_copy_constructible<optional<T>>::value), ""); + constexpr optional<T> opt; + constexpr optional<T> opt2 = std::move(opt); + (void)opt2; + } + static_assert(!(std::is_trivially_move_constructible<optional<Y>>::value), ""); + static_assert(!(std::is_trivially_move_constructible<optional<std::string>>::value), ""); + + static_assert(!(std::is_move_constructible<optional<Z>>::value), ""); +} diff --git a/test/libcxx/utilities/optional/optional.object/special_member_gen.pass.cpp b/test/libcxx/utilities/optional/optional.object/special_member_gen.pass.cpp new file mode 100644 index 000000000000..9493d6bb766c --- /dev/null +++ b/test/libcxx/utilities/optional/optional.object/special_member_gen.pass.cpp @@ -0,0 +1,66 @@ +//===----------------------------------------------------------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// <optional> + + +#include <optional> +#include <type_traits> +#include <cassert> + +#include "archetypes.hpp" + +template <class T> +struct SpecialMemberTest { + using O = std::optional<T>; + + template <template <class> class TestMF> + static constexpr bool check_same() { + return TestMF<O>::value == TestMF<T>::value; + } + + // Test that optional inherits the correct trivial/non-trivial members + static_assert(check_same<std::is_trivially_destructible>(), ""); + static_assert(check_same<std::is_trivially_copyable>(), ""); +}; + +template <class ...Args> static void sink(Args&&...) {} + +template <class ...TestTypes> +struct DoTestsMetafunction { + DoTestsMetafunction() { sink(SpecialMemberTest<TestTypes>{}...); } +}; + +struct TrivialMoveNonTrivialCopy { + TrivialMoveNonTrivialCopy() = default; + TrivialMoveNonTrivialCopy(const TrivialMoveNonTrivialCopy&) {} + TrivialMoveNonTrivialCopy(TrivialMoveNonTrivialCopy&&) = default; + TrivialMoveNonTrivialCopy& operator=(const TrivialMoveNonTrivialCopy&) { return *this; } + TrivialMoveNonTrivialCopy& operator=(TrivialMoveNonTrivialCopy&&) = default; +}; + +struct TrivialCopyNonTrivialMove { + TrivialCopyNonTrivialMove() = default; + TrivialCopyNonTrivialMove(const TrivialCopyNonTrivialMove&) = default; + TrivialCopyNonTrivialMove(TrivialCopyNonTrivialMove&&) {} + TrivialCopyNonTrivialMove& operator=(const TrivialCopyNonTrivialMove&) = default; + TrivialCopyNonTrivialMove& operator=(TrivialCopyNonTrivialMove&&) { return *this; } +}; + +int main() +{ + sink( + ImplicitTypes::ApplyTypes<DoTestsMetafunction>{}, + ExplicitTypes::ApplyTypes<DoTestsMetafunction>{}, + NonLiteralTypes::ApplyTypes<DoTestsMetafunction>{}, + NonTrivialTypes::ApplyTypes<DoTestsMetafunction>{}, + DoTestsMetafunction<TrivialMoveNonTrivialCopy, TrivialCopyNonTrivialMove>{} + ); +} |
