2015-03-03 19:34:12 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Hamburg University of Applied Sciences (HAW)
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup cpp11-compat
|
|
|
|
* @{
|
|
|
|
*
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2015-03-03 19:34:12 +01:00
|
|
|
* @brief utility functions
|
|
|
|
*
|
|
|
|
* @author Dominik Charousset <dominik.charousset (at) haw-hamburg.de>
|
|
|
|
* @author Raphael Hiesgen <raphael.hiesgen (at) haw-hamburg.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef RIOT_THREAD_UTILS_HPP
|
|
|
|
#define RIOT_THREAD_UTILS_HPP
|
|
|
|
|
|
|
|
#include <tuple>
|
|
|
|
#include <utility>
|
|
|
|
|
|
|
|
namespace riot {
|
|
|
|
namespace detail {
|
|
|
|
|
|
|
|
/**
|
2017-03-06 15:28:22 +01:00
|
|
|
* @brief A list of integers (wraps a long... template parameter pack).
|
2015-03-03 19:34:12 +01:00
|
|
|
*/
|
|
|
|
template <long... Is>
|
|
|
|
struct int_list {};
|
|
|
|
|
|
|
|
/**
|
2017-03-06 15:28:22 +01:00
|
|
|
* @brief Creates indices from `Pos` to `Max`.
|
2015-03-03 19:34:12 +01:00
|
|
|
*/
|
|
|
|
template <long Max, long Pos = 0, typename Indices = int_list<>>
|
|
|
|
struct il_indices;
|
|
|
|
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief End of recursion, `Pos` reached `Max`.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
template <long Pos, long... Is>
|
|
|
|
struct il_indices<Pos, Pos, int_list<Is...>> {
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Result is the list containing `Is...`.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
using type = int_list<Is...>;
|
|
|
|
};
|
|
|
|
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Recursion step.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
template <long Max, long Pos, long... Is>
|
|
|
|
struct il_indices<Max, Pos, int_list<Is...>> {
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Append `Pos` to list and increment for the next step.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
using type = typename il_indices<Max, Pos + 1, int_list<Is..., Pos>>::type;
|
|
|
|
};
|
|
|
|
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Function to create a list of indices from `From` to `To`.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
template <long To, long From = 0>
|
|
|
|
typename il_indices<To, From>::type get_indices() {
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-03-06 15:28:22 +01:00
|
|
|
* @brief Apply arguments in a tuple to function.
|
2015-03-03 19:34:12 +01:00
|
|
|
*/
|
|
|
|
template <class F, long... Is, class Tuple>
|
|
|
|
inline auto apply_args(F& f, detail::int_list<Is...>, Tuple&& tup)
|
|
|
|
-> decltype(f(std::get<Is>(tup)...)) {
|
|
|
|
return f(std::get<Is>(tup)...);
|
|
|
|
}
|
|
|
|
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Prefix the argument tuple with additonal arguments.
|
|
|
|
* In this case the tuple is empty.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
template <class F, class Tuple, class... Ts>
|
|
|
|
inline auto apply_args_prefixed(F& f, detail::int_list<>, Tuple&, Ts&&... args)
|
|
|
|
-> decltype(f(std::forward<Ts>(args)...)) {
|
|
|
|
return f(std::forward<Ts>(args)...);
|
|
|
|
}
|
|
|
|
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Prefix the argument tuple with additonal arguments.
|
|
|
|
* In this case the tuple is contains arguments.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
template <class F, long... Is, class Tuple, class... Ts>
|
|
|
|
inline auto apply_args_prefixed(F& f, detail::int_list<Is...>, Tuple& tup,
|
|
|
|
Ts&&... args)
|
|
|
|
-> decltype(f(std::forward<Ts>(args)..., std::get<Is>(tup)...)) {
|
|
|
|
return f(std::forward<Ts>(args)..., std::get<Is>(tup)...);
|
|
|
|
}
|
|
|
|
|
2017-03-06 15:28:22 +01:00
|
|
|
/**
|
|
|
|
* @brief Suffix the tuple with additonal arguments.
|
|
|
|
*/
|
2015-03-03 19:34:12 +01:00
|
|
|
template <class F, long... Is, class Tuple, class... Ts>
|
|
|
|
inline auto apply_args_suffxied(F& f, detail::int_list<Is...>, Tuple& tup,
|
|
|
|
Ts&&... args)
|
|
|
|
-> decltype(f(std::get<Is>(tup)..., std::forward<Ts>(args)...)) {
|
|
|
|
return f(std::get<Is>(tup)..., std::forward<Ts>(args)...);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace detail
|
|
|
|
} // namespace riot
|
|
|
|
|
|
|
|
#endif // RIOT_THREAD_UTILS_HPP
|