如何建立一个hana :: tuple_t <T,T,T,...>给定T和元素数n

iol*_*olo 5 c++ metaprogramming template-meta-programming c++14 boost-hana

这似乎是一个相当基本的事情,所以我正在寻找一个或多或少的简短,内置和易读的解决方案.
我设想的最短的事情就是

hana::unfold_left<hana::tuple_tag>( hana::int_c<n>, [] ( auto count ) {
            return hana::if_( count == hana::int_c<0>, hana::nothing,
                             hana::just( hana::make_pair( count - hana::int_c<1>,
                                                        hana::type_c<T> ) ) );
        } );
Run Code Online (Sandbox Code Playgroud)

这远非短暂和可读...

iol*_*olo 3

正如@jv_ 所指出的,hana::replicate完全可以做到这一点。
参考文档中的示例提供了有关如何实现此目的的足够信息:

// Copyright Louis Dionne 2013-2016
// Distributed under the Boost Software License, Version 1.0.
// (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt)

#include <boost/hana/equal.hpp>
#include <boost/hana/integral_constant.hpp>
#include <boost/hana/optional.hpp>
#include <boost/hana/replicate.hpp>
#include <boost/hana/tuple.hpp>

namespace hana = boost::hana;
static_assert(hana::replicate<hana::tuple_tag>('x', hana::size_c<2>) == hana::make_tuple('x', 'x'), "");
// Of course, there can't be more than one element in an `optional`.
static_assert(hana::replicate<hana::optional_tag>('x', hana::size_c<2>) == hana::just('x'), "");
int main() { }
Run Code Online (Sandbox Code Playgroud)