У меня есть этот шаблон функции:
template <class T>
Json::Value write_json(const T& object);
Когда T является int , специализация проста:
template <>
Json::Value write_json(const int& object) {
Json::Value output;
output = object;
return output;
};
Однако для более сложных классов я хочу, чтобы он вызывал метод, если он существует:
template <typename T>
struct has_write_json_method {
template <typename U>
static constexpr decltype(std::declval<U>().write_json(), bool()) test(int) { return true; };
template <typename U>
static constexpr bool test(...) { return false; }
static constexpr bool value = test<T>(int());
};
template <class T>
typename std::enable_if<has_write_json_method<T>::value, Json::Value>::type write_json(const T& object) {
object.write_json();
};
Например, для класса foo :
Json::Value foo::write_json(void) {
Json::Value output;
output = 42;
return output;
};
Iхочу называть каждый класс как:
int x_int;
write_json(x_int);
foo x_foo;
write_json(x_foo);
Однако я получил:
error: call of overloaded 'write_json(const foo&)' is ambiguous
Как мне убрать эту двусмысленность?