提升Hana编译时间列表转换

时间:2017-02-23 15:47:15

标签: c++ boost metaprogramming boost-hana

我试图弄清楚如何使用boost:hana在编译时转换整数常量列表。

我的列表为:

constexpr auto vals = hana::to<hana::tuple_tag>(hana::range_c<int, 0, 3>);

我想申请这个功能:

constexpr auto Pow2(int i) { return 1 << i; }

然而

constexpr auto res = hana::transform(list, Pow2);

生成res hana::tuple<int, int, int>的类型。我没有看到如何将参数移动到lambda到hana::int_c的模板参数

// Compiler error: Non-type template argument is not a constant expression
constexpr auto Pow2(int i)
{
    return hana::int_c<1 << i>{};
}

1 个答案:

答案 0 :(得分:4)

在......

constexpr auto Pow2(int i) { return 1 << i; } 

... i运行时整数。它不是“编译时友好”参数,因为它的值不会存储为其类型的一部分。您应该传递int_代替:

template <int X>
constexpr auto Pow2(hana::int_<X>) { return hana::int_c<1 << X>; }

用法:

constexpr auto vals = hana::to<hana::tuple_tag>(hana::range_c<int, 0, 3>);
constexpr auto res = hana::transform(vals, [](auto x){ return Pow2(x); });

static_assert(std::is_same_v<
    std::decay_t<decltype(res)>,
    hana::tuple<hana::int_<1>, hana::int_<2>, hana::int_<4>>
>);

wandbox example

显然,你也可以用lambda做到这一点。此外,boost::hana::int_operator<<重载,返回int_

hana::transform(vals, [](auto x){ return hana::int_c<1> << x; });

wandbox example