Related to this question I was wondering if something like this would be achievable in a straightforward way using boost::hana:
#include <boost/hana.hpp>
#include <boost/hana/unpack.hpp>
namespace hana = boost::hana;
template<typename ... T>
struct A {};
int main() {
auto my_tuple = hana::tuple_t<int, double, float>;
// Is there any way to unpack my_tuple as template arguments for A?
// Something like
using MyStruct = A<hana::unpack_types(my_tuple)...>;
static_assert(std::is_same<MyStruct, A<int, double, float>>::value, "Ooops!");
}
You may do it yourself with:
template <template <typename...> class C, typename Tuple> struct RebindImpl;
template <template <typename...> class C, typename ... Ts>
struct RebindImpl<C, hana::tuple_t<Ts...>>{
using type = C<Ts...>;
};
template <template <typename...> class C, typename Tuple>
using Rebind = typename RebindImpl<C, Tuple>::type;
Use template_
to lift A
into a metafunction, then call unpack
:
using MyStruct = decltype(hana::unpack(my_tuple, hana::template_<A>))::type;
Example.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With