diff options
| author | Marshall Clow <mclow.lists@gmail.com> | 2014-12-09 15:07:42 +0000 |
|---|---|---|
| committer | Marshall Clow <mclow.lists@gmail.com> | 2014-12-09 15:07:42 +0000 |
| commit | 8ad78e905f28d72a9122302e381503159a208485 (patch) | |
| tree | 73198a934efc2869b6d2836d9795cc8f2eb85a67 /libcxx/test/experimental/optional/optional.object/optional.object.observe/value_or.pass.cpp | |
| parent | b0a9b703739aa0e0661fec9181863cd6745b63c9 (diff) | |
| download | bcm5719-llvm-8ad78e905f28d72a9122302e381503159a208485.tar.gz bcm5719-llvm-8ad78e905f28d72a9122302e381503159a208485.zip | |
Move the optional tests into test/experimental. They were put into test/utilities because optional was going to be part of C++14, and then was pulled and put into the Library Fundamentals TS instead. No funcitonality change here; just moving files around.
llvm-svn: 223778
Diffstat (limited to 'libcxx/test/experimental/optional/optional.object/optional.object.observe/value_or.pass.cpp')
| -rw-r--r-- | libcxx/test/experimental/optional/optional.object/optional.object.observe/value_or.pass.cpp | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/libcxx/test/experimental/optional/optional.object/optional.object.observe/value_or.pass.cpp b/libcxx/test/experimental/optional/optional.object/optional.object.observe/value_or.pass.cpp new file mode 100644 index 00000000000..6118c44bb5b --- /dev/null +++ b/libcxx/test/experimental/optional/optional.object/optional.object.observe/value_or.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. +// +//===----------------------------------------------------------------------===// + +// <optional> + +// template <class U> T optional<T>::value_or(U&& v) &&; + +#include <experimental/optional> +#include <type_traits> +#include <cassert> + +#if _LIBCPP_STD_VER > 11 + +using std::experimental::optional; +using std::experimental::in_place_t; +using std::experimental::in_place; + +struct Y +{ + int i_; + + Y(int i) : i_(i) {} +}; + +struct X +{ + int i_; + + X(int i) : i_(i) {} + X(X&& x) : i_(x.i_) {x.i_ = 0;} + X(const Y& y) : i_(y.i_) {} + X(Y&& y) : i_(y.i_+1) {} + friend constexpr bool operator==(const X& x, const X& y) + {return x.i_ == y.i_;} +}; + +#endif // _LIBCPP_STD_VER > 11 + +int main() +{ +#if _LIBCPP_STD_VER > 11 + { + optional<X> opt(in_place, 2); + Y y(3); + assert(std::move(opt).value_or(y) == 2); + assert(*opt == 0); + } + { + optional<X> opt(in_place, 2); + assert(std::move(opt).value_or(Y(3)) == 2); + assert(*opt == 0); + } + { + optional<X> opt; + Y y(3); + assert(std::move(opt).value_or(y) == 3); + assert(!opt); + } + { + optional<X> opt; + assert(std::move(opt).value_or(Y(3)) == 4); + assert(!opt); + } +#endif // _LIBCPP_STD_VER > 11 +} |

