gpt4 book ai didi

c++ - 包装一个 Boost.Fusion 序列

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:35:56 25 4
gpt4 key购买 nike

我正在寻找一种方法来创建 Boost.Fusion 序列包装器,它本身就是一个 Fusion 序列,并将所有“调用”转发到它的包装序列。行内的东西

template< typename Sequence >
struct sequence_wrapper
{
explicit sequence_wrapper( Sequence const& s ) : seq( s ){}

Sequence seq;
};

哪里sequence_wrapper< Sequence >也是一个 Fusion 序列,并且与 Sequence 一样工作将。我需要这个的原因是我有几个函数可以在 Fusion 序列上运行(其中所有元素都满足一些特殊要求),我想添加一些语法糖,我需要一个自定义类型来将重载运算符添加到。我不需要对 sequence_wrapper 的操作结果也返回 sequence_wrapper,只有与语法糖相关的调用会返回(手动)包装的序列。例如,使用逗号运算符将元素附加到序列(有点像 Fusion 序列的 Boost.Assign):

template< typename Sequence, typename T >
sequence_wrapper<
typename boost::fusion::result_of::push_back<
Sequence const&
, T
>::type
> operator ,( Sequence const& seq, T const& v )
{
return
sequence_wrapper<
typename boost::fusion::result_of::push_back<
Sequence const&
, T
>::type
>( boost::fusion::push_back( seq, v ) )
;
}

实现此目标的最佳方法是什么(如果图书馆确实支持)?我特别想避免从头开始创建 Fusion 序列,因为我想使用 Fusion 操作返回的任何序列。会继承+特化tag_of返回包装序列的标签才有效?或者我是否需要定义自己的标签并实现所有必需的功能以仅转发调用?

最佳答案

这就是我最终做的:

template<
typename Derived
, typename Sequence
, typename TraversalTag =
typename boost::fusion::traits::category_of< Sequence >::type
, typename IsView =
typename boost::fusion::traits::is_view< Sequence >::type
>
class fusion_sequence_wrapper
: public boost::fusion::sequence_facade< Derived, TraversalTag, IsView >
{
typedef Sequence base_sequence_type;

public:
explicit fusion_sequence_wrapper( base_sequence_type const& sequence )
: _seq( sequence )
{}

base_sequence_type const& base() const
{
return _seq;
}
base_sequence_type& base()
{
return _seq;
}

public:
template< typename Seq >
struct begin
{
typedef
typename boost::fusion::result_of::begin<
typename boost::mpl::if_<
boost::is_const< Seq >
, base_sequence_type const
, base_sequence_type
>::type
>::type type;

static type call( Seq& s ){ return boost::fusion::begin( s._seq ); }
};

template< typename Seq >
struct end
{
typedef
typename boost::fusion::result_of::end<
typename boost::mpl::if_<
boost::is_const< Seq >
, base_sequence_type const
, base_sequence_type
>::type
>::type type;

static type call( Seq& s ){ return boost::fusion::end( s._seq ); }
};

template< typename Seq >
struct size
{
typedef
typename boost::fusion::result_of::size<
typename boost::mpl::if_<
boost::is_const< Seq >
, base_sequence_type const
, base_sequence_type
>::type
>::type type;

static type call( Seq& s ){ return boost::fusion::size( s._seq ); }
};

template< typename Seq >
struct empty
{
typedef
typename boost::fusion::result_of::empty<
typename boost::mpl::if_<
boost::is_const< Seq >
, base_sequence_type const
, base_sequence_type
>::type
>::type type;

static type call( Seq& s ){ return boost::fusion::empty( s._seq ); }
};

template< typename Seq, typename N >
struct at
{
typedef
typename boost::fusion::result_of::at<
typename boost::mpl::if_<
boost::is_const< Seq >
, base_sequence_type const
, base_sequence_type
>::type
, N
>::type type;

static type call( Seq& s ){ return boost::fusion::at( s._seq ); }
};

template< typename Seq, typename N >
struct value_at
{
typedef
typename boost::fusion::result_of::value_at<
typename boost::mpl::if_<
boost::is_const< Seq >
, base_sequence_type const
, base_sequence_type
>::type
, N
>::type type;
};

private:
base_sequence_type _seq;
};

关于c++ - 包装一个 Boost.Fusion 序列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12205124/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com