I am trying to use compact fold expression without success.
For instance here is a working C++17 code
template <bool... B>
struct Fold_And : std::integral_constant<bool, (B && ...)>
{
};
template <bool... B>
constexpr auto Fold_And_v = Fold_And<B...>::value;
template <typename V, typename... Vs>
std::enable_if_t<
    Fold_And_v<std::is_floating_point_v<V>,
               std::is_floating_point_v<Vs>...> >
foo(const V& v, const Vs&...)
{
}
I want to translate it into a more compact form (not using the intermediate Fold_And)
template <typename V, typename... Vs>
std::enable_if_t<std::is_floating_point_v<V> && ... &&
                 std::is_floating_point_v<Vs> >
foo_compact(const V& v, const Vs&...)
{
}
However, this is apparently illegal C++ as both g++ and clang++ compilers fail to compile it.
My question:
foo_compact()? (what is the right one?) Or
foo() code using the Fold_And struct)?You almost got it! Fold expressions have to be surrounded by parentheses:
template <typename V, typename... Vs>
std::enable_if_t<(std::is_floating_point_v<V> && ... &&
                 std::is_floating_point_v<Vs>)>
foo_compact(const V& v, const Vs&...)
{
}
Notice the parentheses after < and before the last >.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With