|
template<class T> |
using | q23::detail::remove_const_t = typename std::remove_const<T>::type |
template<class T> |
using | q23::detail::remove_reference_t = typename std::remove_reference<T>::type |
template<class T> |
using | q23::detail::decay_t = typename std::decay<T>::type |
template<bool E, class T = void> |
using | q23::detail::enable_if_t = typename std::enable_if<E, T>::type |
template<bool B, class T, class F> |
using | q23::detail::conditional_t = typename std::conditional<B, T, F>::type |
template<class F, class... Us> |
using | q23::detail::invoke_result = invoke_result_impl<F, void, Us...> |
template<class F, class... Us> |
using | q23::detail::invoke_result_t = typename invoke_result<F, Us...>::type |
template<class T> |
using | q23::detail::is_expected = is_expected_impl<decay_t<T>> |
template<class T, class E, class U> |
using | q23::detail::expected_enable_forward_value |
template<class T, class E, class U, class G, class UR, class GR> |
using | q23::detail::expected_enable_from_other |
template<class T, class U> |
using | q23::detail::is_void_or = conditional_t<std::is_void<T>::value, std::true_type, U> |
template<class T> |
using | q23::detail::is_copy_constructible_or_void |
template<class T> |
using | q23::detail::is_move_constructible_or_void |
template<class T> |
using | q23::detail::is_copy_assignable_or_void = is_void_or<T, std::is_copy_assignable<T>> |
template<class T> |
using | q23::detail::is_move_assignable_or_void = is_void_or<T, std::is_move_assignable<T>> |
template<class Exp> |
using | q23::detail::exp_t = typename detail::decay_t<Exp>::value_type |
template<class Exp> |
using | q23::detail::err_t = typename detail::decay_t<Exp>::error_type |
template<class Exp, class Ret> |
using | q23::detail::ret_t = expected<Ret, err_t<Exp>> |
|
template<class E> |
constexpr bool | q23::operator== (const unexpected< E > &lhs, const unexpected< E > &rhs) |
template<class E> |
constexpr bool | q23::operator!= (const unexpected< E > &lhs, const unexpected< E > &rhs) |
template<class E> |
constexpr bool | q23::operator< (const unexpected< E > &lhs, const unexpected< E > &rhs) |
template<class E> |
constexpr bool | q23::operator<= (const unexpected< E > &lhs, const unexpected< E > &rhs) |
template<class E> |
constexpr bool | q23::operator> (const unexpected< E > &lhs, const unexpected< E > &rhs) |
template<class E> |
constexpr bool | q23::operator>= (const unexpected< E > &lhs, const unexpected< E > &rhs) |
template<class E> |
unexpected< typename std::decay< E >::type > | q23::make_unexpected (E &&e) |
template<typename E> |
TL_EXPECTED_11_CONSTEXPR void | q23::detail::throw_exception (E &&e) |
template<typename Fn, typename... Args, typename = enable_if_t<std::is_member_pointer<decay_t<Fn>>::value>, int = 0> |
constexpr auto | q23::detail::invoke (Fn &&f, Args &&...args) noexcept(noexcept(std::mem_fn(f)(std::forward< Args >(args)...))) -> decltype(std::mem_fn(f)(std::forward< Args >(args)...)) |
template<typename Fn, typename... Args, typename = enable_if_t<!std::is_member_pointer<decay_t<Fn>>::value>> |
constexpr auto | q23::detail::invoke (Fn &&f, Args &&...args) noexcept(noexcept(std::forward< Fn >(f)(std::forward< Args >(args)...))) -> decltype(std::forward< Fn >(f)(std::forward< Args >(args)...)) |
template<class T> |
tag | q23::detail::swap_adl_tests::swap (T &, T &) |
template<class T, std::size_t N> |
tag | q23::detail::swap_adl_tests::swap (T(&a)[N], T(&b)[N]) |
template<class, class> |
std::false_type | q23::detail::swap_adl_tests::can_swap (...) noexcept(false) |
template<class T, class U, class = decltype(swap(std::declval<T &>(), std::declval<U &>()))> |
std::true_type | q23::detail::swap_adl_tests::can_swap (int) noexcept(noexcept(swap(std::declval< T & >(), std::declval< U & >()))) |
template<class, class> |
std::false_type | q23::detail::swap_adl_tests::uses_std (...) |
template<class T, class U> |
std::is_same< decltype(swap(std::declval< T & >(), std::declval< U & >())), tag > | q23::detail::swap_adl_tests::uses_std (int) |
template<class Exp, class F, class Ret = decltype(detail::invoke(std::declval<F>(), *std::declval<Exp>())), detail::enable_if_t<!std::is_void< exp_t< Exp > >::value > * = nullptr> |
auto | q23::detail::and_then_impl (Exp &&exp, F &&f) -> Ret |
template<class Exp, class F, class Ret = decltype(detail::invoke(std::declval<F>())), detail::enable_if_t< std::is_void< exp_t< Exp > >::value > * = nullptr> |
constexpr auto | q23::detail::and_then_impl (Exp &&exp, F &&f) -> Ret |
template<class Exp, class F, detail::enable_if_t<!std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>(), *std::declval<Exp>())), detail::enable_if_t<!std::is_void< Ret >::value > * = nullptr> |
constexpr auto | q23::detail::expected_map_impl (Exp &&exp, F &&f) -> ret_t< Exp, detail::decay_t< Ret > > |
template<class Exp, class F, detail::enable_if_t<!std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>(), *std::declval<Exp>())), detail::enable_if_t< std::is_void< Ret >::value > * = nullptr> |
auto | q23::detail::expected_map_impl (Exp &&exp, F &&f) -> expected< void, err_t< Exp > > |
template<class Exp, class F, detail::enable_if_t< std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>())), detail::enable_if_t<!std::is_void< Ret >::value > * = nullptr> |
constexpr auto | q23::detail::expected_map_impl (Exp &&exp, F &&f) -> ret_t< Exp, detail::decay_t< Ret > > |
template<class Exp, class F, detail::enable_if_t< std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>())), detail::enable_if_t< std::is_void< Ret >::value > * = nullptr> |
auto | q23::detail::expected_map_impl (Exp &&exp, F &&f) -> expected< void, err_t< Exp > > |
template<class Exp, class F, detail::enable_if_t<!std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>(), std::declval<Exp>().error())), detail::enable_if_t<!std::is_void< Ret >::value > * = nullptr> |
constexpr auto | q23::detail::map_error_impl (Exp &&exp, F &&f) -> expected< exp_t< Exp >, detail::decay_t< Ret > > |
template<class Exp, class F, detail::enable_if_t<!std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>(), std::declval<Exp>().error())), detail::enable_if_t< std::is_void< Ret >::value > * = nullptr> |
auto | q23::detail::map_error_impl (Exp &&exp, F &&f) -> expected< exp_t< Exp >, monostate > |
template<class Exp, class F, detail::enable_if_t< std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>(), std::declval<Exp>().error())), detail::enable_if_t<!std::is_void< Ret >::value > * = nullptr> |
constexpr auto | q23::detail::map_error_impl (Exp &&exp, F &&f) -> expected< exp_t< Exp >, detail::decay_t< Ret > > |
template<class Exp, class F, detail::enable_if_t< std::is_void< exp_t< Exp > >::value > * = nullptr, class Ret = decltype(detail::invoke(std::declval<F>(), std::declval<Exp>().error())), detail::enable_if_t< std::is_void< Ret >::value > * = nullptr> |
auto | q23::detail::map_error_impl (Exp &&exp, F &&f) -> expected< exp_t< Exp >, monostate > |
template<class Exp, class F, class Ret = decltype(detail::invoke(std::declval<F>(), std::declval<Exp>().error())), detail::enable_if_t<!std::is_void< Ret >::value > * = nullptr> |
auto | q23::detail::or_else_impl (Exp &&exp, F &&f) -> Ret |
template<class Exp, class F, class Ret = decltype(detail::invoke(std::declval<F>(), std::declval<Exp>().error())), detail::enable_if_t< std::is_void< Ret >::value > * = nullptr> |
detail::decay_t< Exp > | q23::detail::or_else_impl (Exp &&exp, F &&f) |
template<class T, class E, class U, class F> |
constexpr bool | q23::operator== (const expected< T, E > &lhs, const expected< U, F > &rhs) |
template<class T, class E, class U, class F> |
constexpr bool | q23::operator!= (const expected< T, E > &lhs, const expected< U, F > &rhs) |
template<class E, class F> |
constexpr bool | q23::operator== (const expected< void, E > &lhs, const expected< void, F > &rhs) |
template<class E, class F> |
constexpr bool | q23::operator!= (const expected< void, E > &lhs, const expected< void, F > &rhs) |
template<class T, class E, class U> |
constexpr bool | q23::operator== (const expected< T, E > &x, const U &v) |
template<class T, class E, class U> |
constexpr bool | q23::operator== (const U &v, const expected< T, E > &x) |
template<class T, class E, class U> |
constexpr bool | q23::operator!= (const expected< T, E > &x, const U &v) |
template<class T, class E, class U> |
constexpr bool | q23::operator!= (const U &v, const expected< T, E > &x) |
template<class T, class E> |
constexpr bool | q23::operator== (const expected< T, E > &x, const unexpected< E > &e) |
template<class T, class E> |
constexpr bool | q23::operator== (const unexpected< E > &e, const expected< T, E > &x) |
template<class T, class E> |
constexpr bool | q23::operator!= (const expected< T, E > &x, const unexpected< E > &e) |
template<class T, class E> |
constexpr bool | q23::operator!= (const unexpected< E > &e, const expected< T, E > &x) |
template<class T, class E, detail::enable_if_t<(std::is_void< T >::value||std::is_move_constructible< T >::value) &&detail::is_swappable< T >::value &&std::is_move_constructible< E >::value &&detail::is_swappable< E >::value > * = nullptr> |
void | q23::swap (expected< T, E > &lhs, expected< T, E > &rhs) noexcept(noexcept(lhs.swap(rhs))) |