что F(x, f0, f1, ..., fn) это эквивалент fn(...(f1(f0(x)))...)?
через рекурсию?
думал, может быть есть что-то готовое
Что-нибудь вроде std::accumulate(begin(fs), end(fs), x, [](auto x, auto f){ return f(x); });
template <typename Func, typename Arg> auto F(Arg&& arg, Func&& func) { return func(std::forward<Arg>(arg)); } template <typename FirstFunc, typename... OtherFuncs, typename Arg> auto F(Arg&& arg, FirstFunc&& firstFunc, OtherFuncs&&... otherFuncs) { return F(firstFunc(std::forward<Arg>(arg)), std::forward<OtherFuncs>(otherFuncs)...); } мб так
может что-то такое? ```template <typename T> int operator| (int x, T t) { return t(x); } template <typename ...Ts> int foo(int x, Ts ...ts) { return (x | ... | ts); }```
https://godbolt.org/z/7hYeejssM
разве что на void взорвется, но чинится в 3 строки
я так сделал
ну, свертка лучше чем рекурсия(тем более вы это в userver коммитите), но решать вам конечно
А в чем разница? В фолде с врапперами может инстанцироваться такое же количество шаблонов, как в решении с рекурсией. Не уверен что это сильно лучше.
если хозяева скажут, переделаю
Обсуждают сегодня