我有一些旧代码使用与此处和此处str_const
描述的非常相似的东西来执行一些 constexpr 字符串操作。是 Scott Schurr 描述的文字类型,可以从字符串文字构造,因为它有一个模板构造函数来自.str_const
const char (&)[]
我现在也有一些使用boost::hana
.
我希望能够采用hana::string
并创建str_const
引用它的 a。最简单的方法是将 a 转换hana::string
为 a constexpr const char (&)[]
。(实际上,在这一点上这不是最简单的方法,最简单的方法肯定是在我的str_const
实现中添加一个新的模板构造函数。但此时问题已经有了自己的生命,我主要感兴趣的是这是否可以用 . 来完成hana::string
。所以让我们假设我不允许更改str_const
实现。)
但是,在hana
文档中转换hana::string
为运行时字符串的方法是hana::to<const char *>
.
乐观地,我尝试了各种形式,hana::to<const char (&)[hana::length(...)]> (...)
但这会导致静态断言hana
失败。
文档建议的另一个选项hana
是自己使用hana::unpack
然后将字符粘贴到数组中。我写了这段代码
template <typename T, size_t N>
struct array {
T arr[N];
};
struct char_packer {
template <typename... Ts>
constexpr auto operator()(Ts... ts) -> array<const char, sizeof...(ts) + 1> {
return array<const char, sizeof...(ts) + 1>{{ ts... , 0 }};
}
};
template <typename S>
struct string_keeper {
static constexpr auto my_array = hana::unpack(S{}, char_packer{});
};
template <int N>
using char_arr = const char [N];
template <typename S>
constexpr auto to_string_literal(S &&) -> const char_arr<decltype(hana::length(S{}))::value + 1> & {
return string_keeper<S>::my_array.arr;
}
我认为这几乎可以工作,至少它可以编译。但是,如果在运行时也使用了引用,那么它会失败并出现链接器错误:undefined reference to ... string_keeper<boost::hana::string<(char)97> >::my_array
.
(实际上我想我明白为什么这是一个 ODR 问题,如果我再想一想,我可能会记得如何解决它......不确定......)
直觉上,我觉得一定有办法做到这一点。因为,hana
已经允许我转换hana::string
到constexpr const char *
指针指向我想要的数组的位置。事实上,它甚至暗示可能存在一个邪恶的选择,我试图强制const char *
回(&)[]
打字,尽管这似乎也需要做一些constexpr
函数中不允许的事情。无论如何,如果hana
可以制作该数组,那么我当然也可以,或者以某种方式说服它更准确地给我。
有没有办法修复我上面的代码?hana
在我忽略的范围内有没有更简单的方法来做到这一点?由于某种原因,这实际上是不可能的吗?