我想在编译时检查用户字面量_name
的定义是否为Ret
和参数Arg
。虽然我有一半的解决方案,它要求的字面operator
被至少一次定义:是否有可能检查用户文本是否为给定的类型和参数定义?
#include <iostream>
#include <type_traits>
struct one { };
struct two { };
// we need at least one of these definitions for template below to compile
one operator"" _x(char const*) {return {};}
two operator"" _x(unsigned long long int) {return {};}
template<class T, class S, class = void>
struct has_literal_x : std::false_type
{ };
template<class T, class S>
struct has_literal_x <T, S,
std::void_t<decltype((T(*)(S))(operator"" _x))>
> : std::true_type
{ };
int main()
{
std::cout << has_literal_x<one, char const*>::value << std::endl;
std::cout << has_literal_x<two, unsigned long long int>::value << std::endl;
std::cout << has_literal_x<one, unsigned long long int>::value << std::endl;
std::cout << has_literal_x<two, char const*>::value << std::endl;
std::cout << has_literal_x<int, char const*>::value << std::endl;
}
输出:
1
1
0
0
0
但是,如果有可能不重载用户文字中的至少一个定义,这个解决方案将不起作用。是否有任何方法可以检查它,即使是不存在的文字(可能与我们可以检查类X
是否有成员member
一样,但我不知道在这种情况下它是否可行)?
注意测试一下这个解决方案确实,如果经营者类型之后定义不太工作特征至少在GCC中定义:http://coliru.stacked-crooked.com/a/6f70eb6cbf236473 – xinaiz