Сообщение Re[3]: Получить сигнатуру из ламбды от 18.08.2020 9:15
Изменено 18.08.2020 9:22 Маркуша Шулин
Re[3]: Получить сигнатуру из ламбды
Здравствуйте, Went, Вы писали:
W>Здравствуйте, rg45.
W>Блин, когда 101% времени сидишь за прикладным кодом, голова вообще отказывается работать в направлении шаблонов
W>Пишу в рамках С++11. Хочу сделать функцию, которая принимает произвольный вызываемый объект (без учета возвратного значения), и возвращает функтор с подобной сигнатурой, но этот функтор не вызывает исходный объект, а лишь ставит его в очередь сообщений, прибиндивая к нему те параметры, с которыми был вызван этот функтор. По-моему, это что-то похожее на async.
так чтобы по быстрому. можно выдрать из сигнатуры тупл и т/к это локальная лямбда, в смысле не влияет на внешний интерфейс ? если да, то
W>Здравствуйте, rg45.
W>Блин, когда 101% времени сидишь за прикладным кодом, голова вообще отказывается работать в направлении шаблонов
W>Пишу в рамках С++11. Хочу сделать функцию, которая принимает произвольный вызываемый объект (без учета возвратного значения), и возвращает функтор с подобной сигнатурой, но этот функтор не вызывает исходный объект, а лишь ставит его в очередь сообщений, прибиндивая к нему те параметры, с которыми был вызван этот функтор. По-моему, это что-то похожее на async.
Скрытый текст | |
W>Что-то такое: W>
| |
так чтобы по быстрому. можно выдрать из сигнатуры тупл и т/к это локальная лямбда, в смысле не влияет на внешний интерфейс ? если да, то
typedef typename convert_2args_type<typename stdext::call_traits<T>::signature>::type args_tuple_type;
std::function<typename stdext::call_traits<T>::signature> result = [fnc](args_tuple_type const& args)
{
// Здесь форейч по всем аргументам и в конце итерации вызов непосредственно функции
call_func_add_message_in_queue<0>(args);
};
Re[3]: Получить сигнатуру из ламбды
Здравствуйте, Went, Вы писали:
W>Здравствуйте, rg45.
W>Блин, когда 101% времени сидишь за прикладным кодом, голова вообще отказывается работать в направлении шаблонов
W>Пишу в рамках С++11. Хочу сделать функцию, которая принимает произвольный вызываемый объект (без учета возвратного значения), и возвращает функтор с подобной сигнатурой, но этот функтор не вызывает исходный объект, а лишь ставит его в очередь сообщений, прибиндивая к нему те параметры, с которыми был вызван этот функтор. По-моему, это что-то похожее на async.
так чтобы по быстрому. можно выдрать из сигнатуры тупл и т/к это локальная лямбда, в смысле не влияет на внешний интерфейс ? если да, то
если же у тебя внешний интерфейс и локальная типизация извне не видна можно пихать в некий абстрактнфй тип вроде boost::any кастить перед вызовом.
W>Здравствуйте, rg45.
W>Блин, когда 101% времени сидишь за прикладным кодом, голова вообще отказывается работать в направлении шаблонов
W>Пишу в рамках С++11. Хочу сделать функцию, которая принимает произвольный вызываемый объект (без учета возвратного значения), и возвращает функтор с подобной сигнатурой, но этот функтор не вызывает исходный объект, а лишь ставит его в очередь сообщений, прибиндивая к нему те параметры, с которыми был вызван этот функтор. По-моему, это что-то похожее на async.
Скрытый текст | |
W>Что-то такое: W>
| |
так чтобы по быстрому. можно выдрать из сигнатуры тупл и т/к это локальная лямбда, в смысле не влияет на внешний интерфейс ? если да, то
typedef typename convert_2args_type<typename stdext::call_traits<T>::signature>::type args_tuple_type;
std::function<typename stdext::call_traits<T>::signature> result = [fnc](args_tuple_type const& args)
{
// Здесь форейч по всем аргументам и в конце итерации вызов непосредственно функции
call_func_add_message_in_queue<0>(args);
};
если же у тебя внешний интерфейс и локальная типизация извне не видна можно пихать в некий абстрактнфй тип вроде boost::any кастить перед вызовом.