2

我想根据boost::fusion::invoke()特定的融合序列是否有效来实现部分类模板专业化。但在这种情况下,替换失败似乎是一个错误。

我想我需要一个is_callable_with_these_sequence_parameters<F, Seq>有效的元函数。任何人都可以帮忙吗?

struct F
{
    template<class> struct result;
    template<class F> struct result<F(float)> { typedef int type; };
    int operator()(float) { std::cout << "invoked (float)\n"; }
};

template <class Sequence, class Enable=void>
struct A
{
    A() { std::cout << "invoked nothing\n"; }
};

// Partial specialization
template <class Sequence>
struct A<Sequence, typename boost::fusion::result_of::invoke<F, Sequence>::type>
{
    A() { boost::fusion::invoke(F(), Sequence()); }
};

static void test()
{
    A<boost::fusion::vector<float> >(); // should print "invoked (float)"
    A<boost::fusion::vector<char, char> >(); // should print "invoked nothing"
}
4

1 回答 1

3

经过一番调查,我认为这是提升中的一个错误。

在这里报告,到目前为止没有解决方法。


更新:boost::fusion根据票证,一些不正确的行为已得到修复。

于 2012-05-17T17:43:32.803 回答