目前,只有双打可以在用户定义的文字中生成字符模板:
template <char...> double operator "" _x(); // Later 1.3_x; // OK "1.3"_y; // C++14 does not allow a _y user- // defined operator to parse that as a template of chars
是否有一种聪明的方法来使用用户定义的文字生成字符的std :: integer_sequence.换句话说,_y(const char *,std :: size_t)的代码是什么,以便我最终得到一个std :: integer_sequence< char,'1','.','3'>?
解决方法
在这个时间点,我们可以(便携)做的最好的是一个宏技巧,如
for
vtmpl::string
所示.基本上,我们创建一个访问列表,如
"abcd" -> {(0 < sizeof "abcd"? "abcd"[0] : 0),(1 < sizeof "abcd"? "abcd"[1] : 0),...}
…我们修剪以获得所需的结果.
第一步很容易通过BOOST_PP_ENUM
完成,虽然递归宏也很好(从here定义):
#define VTMPL_SPLIT_1(s,x,m) m(s,x) #define VTMPL_SPLIT_4(s,m) VTMPL_SPLIT_1 (s,m),VTMPL_SPLIT_1 (s,x+1,x+2,x+3,m) #define VTMPL_SPLIT_16(s,m) VTMPL_SPLIT_4 (s,VTMPL_SPLIT_4 (s,x+4,x+8,x+12,m) #define VTMPL_SPLIT_64(s,m) VTMPL_SPLIT_16 (s,VTMPL_SPLIT_16 (s,x+16,x+32,x+48,m) #define VTMPL_SPLIT_256(s,m) VTMPL_SPLIT_64 (s,VTMPL_SPLIT_64 (s,x+64,x+128,x+194,m) #define VTMPL_SPLIT_1024(s,m) VTMPL_SPLIT_256(s,VTMPL_SPLIT_256(s,x+256,x+512,x+768,m)
#define VTMPL_STRING_IMPL(str,n) vtmpl::rtrim<vtmpl::value_list<decltype(*str),VTMPL_SPLIT_##n(str,VTMPL_ARRAY_SPLIT)>>::type # #define VTMPL_STRING(str) VTMPL_STRING_IMPL(str,64 )
rtrim的定义见algorithms.hxx
.