У меня есть вектор слияния с элементами, которые имеют несколько данных элементов разных типов, и я хотел бы создать новый вектор (ы) слияния, который будет проецировать только определенные элементы данных.
Я уже давно в этом разбираюсь, но прогресса нет.
#include <iostream>
#include <string>
#include <boost/fusion/adapted/boost_tuple.hpp>
#include <boost/fusion/include/fold.hpp>
#include <boost/fusion/include/sequence.hpp>
#include <boost/fusion/algorithm.hpp>
#include <boost/spirit/include/phoenix.hpp>
#include <boost/fusion/include/make_vector.hpp>
#include <boost/bind.hpp>
namespace phx = boost::phoenix;
namespace fusion = boost::fusion;
using namespace phx::arg_names;
struct mprint
{
template<typename T>
void operator()(T& t) const
{
std::cout << t << std::endl;
}
};
struct TStruct
{
std::string val1_;
double val2_;
int val3_;
bool val4_;
TStruct( const std::string &val1, double val2, int val3, bool val4 ) :
val1_(val1), val2_(val2), val3_(val3), val4_(val4) { }
};
template <typename Sequence>
void viewVal1( const std::string &dummy,const Sequence& args )
{
fusion::for_each( boost::tie(phx::bind(&TStruct::val1_, arg1)(args)), mprint() );
}
template <typename Sequence>
void viewVal2( const std::string &dummy,const Sequence& args )
{
//fusion::for_each( boost::tie(phx::bind(&TStruct::val2_, arg1)(args)), mprint() );
}
int main( int argc, char* argv[] )
{
auto mdata = fusion::make_vector(
TStruct( "test1", 2.3, 1, true ),
TStruct( "test2", 3.3, 2, false ),
TStruct( "test3", 4.3, 3, true )
);
viewVal1( "dummy", mdata );
viewVal2( "dummy", mdata );
return 0;
}
Я думаю (то есть я не уверен), что вам нужно использовать fusion::transform_view
:
#include <iostream>
#include <string>
#include <boost/fusion/adapted/boost_tuple.hpp>
#include <boost/fusion/include/fold.hpp>
#include <boost/fusion/include/sequence.hpp>
#include <boost/fusion/algorithm.hpp>
#include <boost/spirit/include/phoenix.hpp>
#include <boost/fusion/include/make_vector.hpp>
#include <boost/bind.hpp>
namespace phx = boost::phoenix;
namespace fusion = boost::fusion;
using namespace phx::arg_names;
struct mprint
{
template<typename T>
void operator()(const T& t) const
{
std::cout << t << std::endl;
}
};
struct get_val1
{
template <typename T>
std::string operator()(const T& t) const
{
return t.val1_;
}
};
struct TStruct
{
std::string val1_;
double val2_;
int val3_;
bool val4_;
TStruct( const std::string &val1, double val2, int val3, bool val4 ) :
val1_(val1), val2_(val2), val3_(val3), val4_(val4) { }
};
template <typename Sequence>
void viewVal1( const std::string &dummy, Sequence& args )
{
typedef fusion::transform_view<Sequence, get_val1> project;
fusion::for_each(project(args,get_val1()), mprint() );
}
template <typename Sequence>
void viewVal2( const std::string &dummy, Sequence& args )
{
typedef fusion::transform_view<Sequence,decltype(phx::bind(&TStruct::val2_,arg1))> project;
fusion::for_each( project(args,phx::bind(&TStruct::val2_, arg1)), mprint() );
}
int main( int argc, char* argv[] )
{
auto mdata = fusion::make_vector(
TStruct( "test1", 2.3, 1, true ),
TStruct( "test2", 3.3, 2, false ),
TStruct( "test3", 4.3, 3, true )
);
viewVal1( "dummy", mdata );
viewVal2( "dummy", mdata );
return 0;
}
Других решений пока нет …