33 #include <boost/optional.hpp> 114 return detail::IsFunctorImpl<T> (0);
124 template<
typename T,
typename F>
147 template<
typename T,
typename F,
typename = std::enable_if_t<IsFunctor<T> ()>>
173 template<
typename T,
typename F>
174 auto operator* (
const F&
function,
const T& functor) -> decltype (
Fmap (functor,
function))
176 return Fmap (functor,
function);
199 template<
typename T,
typename F>
200 auto operator* (
const T& functor,
const F&
function) -> decltype (
Fmap (functor,
function))
202 return Fmap (functor,
function);
237 using FmapResult_t = boost::optional<detail::WrapVoidResult_t<std::decay_t<std::result_of_t<F (T)>>>>;
251 return { std::invoke (
f, *t) };
constexpr detail::ExprTree< detail::ExprType::LeafStaticPlaceholder, detail::MemberPtrs< Ptr > > f
auto operator*(const AF &af, const AV &av) -> decltype(GSL(af, av))
static FmapResult_t< F > Apply(const T &functor, const F &function)
Applies the function to the each of the elements inside the functor.
typename WrapVoidResult< T >::Type WrapVoidResult_t
constexpr bool IsFunctorImpl(int, typename InstanceFunctor< T >::UndefinedTag *=nullptr)
boost::optional< detail::WrapVoidResult_t< std::decay_t< std::result_of_t< F(T)> >> > FmapResult_t
A proper void type, akin to unit (or ()) type in functional languages.
constexpr bool IsFunctor()
Checks whether the given type has a Functor instance for it.
FmapResult_t< T, F > Fmap(const T &functor, const F &function)
Apply the function f to the elements in functor.
static FmapResult_t< F > Apply(const boost::optional< T > &t, const F &f)
typename InstanceFunctor< T >::template FmapResult_t< F > FmapResult_t
The result type of the contents of the functor T mapped by function F.
The Functor class is used for types that can be mapped over.
detail::ImplementationType FmapResult_t
The type of the functor after its elements were mapped by the function F.