//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // // template constexpr T optional::value_or(U&& v) const&; #include #include #include #if _LIBCPP_STD_VER > 11 using std::experimental::optional; struct Y { int i_; constexpr Y(int i) : i_(i) {} }; struct X { int i_; constexpr X(int i) : i_(i) {} constexpr X(const Y& y) : i_(y.i_) {} constexpr 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 { constexpr optional opt(2); constexpr Y y(3); static_assert(opt.value_or(y) == 2, ""); } { constexpr optional opt(2); static_assert(opt.value_or(Y(3)) == 2, ""); } { constexpr optional opt; constexpr Y y(3); static_assert(opt.value_or(y) == 3, ""); } { constexpr optional opt; static_assert(opt.value_or(Y(3)) == 4, ""); } { const optional opt(2); const Y y(3); assert(opt.value_or(y) == 2); } { const optional opt(2); assert(opt.value_or(Y(3)) == 2); } { const optional opt; const Y y(3); assert(opt.value_or(y) == 3); } { const optional opt; assert(opt.value_or(Y(3)) == 4); } #endif // _LIBCPP_STD_VER > 11 }