это можно вынести красиво?
Тип нужен цикл по типах?
Создаёшь тайплист. Разворачиваешь его через вариадик как идея
Можно тайплист сделать и для него аналог for_each (более общее решение) Гуглится быстро Ну либо да, развернуть вариадик просто
Спс, пойду погуглю тайплист.
Это условно просто тип template<class...> struct TypeList {};
Массив указателей сделай и по нему пройдись
Хм, понял. А если нужно индексацию, то можно как-то сделать? То есть условно process<Type_i>(args[i])?
массив указателей на типы?
Ну да. Можно пару складывать с типом и интом
Тут можно как раз аналог for_each сделать К нему достаточно тривиально индексы прикручиваются
Это как? Указатель на тип
Это как?
А, у тебя ещё и типы разные, сорри, тогда надо type erasure делать и полиморфизацию какая-то
По факту, вот описание.
Я не понимаю, что за задача и зачем там typeid
template <class Duration, class Container, class Produce, class Consume, class Pred, class DataIngestor> std::vector<std::pair<bool, Duration>> getTestResults(Produce&& produce, Consume&& consume, Pred&& pred, DataIngestor&& get_next_data, std::vector<std::array<int, 3>> input_data, bool verbose = false) { Есть какой-то такой метод, который хочу вызывать для разных Container. Соотвественно и разные типы будут у Produce, Consume, Pred, который зависят от Container
То есть в цикле пройтись по типах из аргумента и вызвать для них тесты.
Выглядит переусложненно) Как тело выглядит сейчас?
template<typename...> struct TypeList {}; template<typename F, typename... Ts> void for_each(TypeList<Ts...>, F&& f) { int dummy[] = { (std::forward<F>(f)(std::declval<Ts>()), 0)... }; } for_each(type_list, [](auto&& arg) { using T = std::decay_t<decltype(arg)>; foo<T>(); });
А как выглядит type_list?
TypeList<int, char, void*> type_list;
Мощно, спасибо. Попробую сейчас.
мощно, только работать не будет
Поправил Теперь работает
сомневаюсь)
А почему? Пока что не компилится, но в чём трабл?
Обсуждают сегодня