1 #ifndef LIBFILEZILLA_APPLY_HEADER 2 #define LIBFILEZILLA_APPLY_HEADER 21 template<
typename F,
typename Tuple,
size_t... I>
22 auto apply_(F&& f, Tuple&& t, std::index_sequence<I...>
const&) -> decltype(std::forward<F>(f)(std::get<I>(std::forward<Tuple>(t))...))
24 return std::forward<F>(f)(std::get<I>(std::forward<Tuple>(t))...);
42 template<typename F, typename Tuple, typename Seq = typename std::make_index_sequence<std::tuple_size<typename std::remove_reference<Tuple>::type>::value>>
43 auto apply(F && f, Tuple&& args) -> decltype(apply_(std::forward<F>(f), std::forward<Tuple>(args), Seq()))
45 return apply_(std::forward<F>(f), std::forward<Tuple>(args), Seq());
51 template<
typename Obj,
typename F,
typename Tuple,
size_t... I>
52 auto apply_(Obj&& obj, F&& f, Tuple&& t, std::index_sequence<I...>
const&) -> decltype((std::forward<Obj>(obj)->*std::forward<F>(f))(std::get<I>(std::forward<Tuple>(t))...))
54 return (std::forward<Obj>(obj)->*std::forward<F>(f))(std::get<I>(std::forward<Tuple>(t))...);
76 template<typename Obj, typename F, typename Tuple, typename Seq = typename std::make_index_sequence<std::tuple_size<typename std::remove_reference<Tuple>::type>::value>>
77 auto apply(Obj&& obj, F && f, Tuple&& args) -> decltype(apply_(std::forward<Obj>(obj), std::forward<F>(f), std::forward<Tuple>(args), Seq()))
79 return apply_(std::forward<Obj>(obj), std::forward<F>(f), std::forward<Tuple>(args), Seq());
auto apply(F &&f, Tuple &&args) -> decltype(apply_(std::forward< F >(f), std::forward< Tuple >(args), Seq()))
Apply tuple to ordinary functor.
Definition: apply.hpp:43
The namespace used by libfilezilla.
Definition: apply.hpp:16