J'utilise la structure is_callable
définie comme suitVérifiez si une fonction est appelable
template <typename F, typename... Args>
struct is_callable {
template <typename U>
static auto test(U* p) -> decltype((*p)(std::declval<Args>()...), void(), std::true_type());
template <typename U>
static auto test(...) -> decltype(std::false_type());
static constexpr bool value = decltype(test<F>(nullptr))::value;
};
J'utilise ceci pour tester un lambda déclaré comme:
template <typename T>
struct runner {
T t;
template <typename F, typename = typename std::enable_if<is_callable<F, T&>::value || is_callable<F, T&&>::value>::type>
void run(F&& f) {
return f(t);
}
};
runner<int> a{0};
a.run([&] (auto& x) {
x++;
});
Pourquoi cette compilation échouent sur la enable_if
sur AppleClang? Est-ce que les auto
ne devraient pas être déduites correctement?
[Fonctionne pour moi] (http://coliru.stacked-crooked.com/a/b83c21fddc4e15cb). Quelle est votre version 'clang' et quel est le message d'erreur spécifique? – Rakete1111
@ Rakete1111 'modèle candidat ignoré: désactivé par 'enable_if'' Apple LLVM version 8.1.0 (clang-802.0.42) – subzero
Pourquoi vérifiez-vous s'il est callable avec' T & '* ou *' T && '? Vous l'appelez avec «T &', vérifiez juste cela. – Barry