Update of /cvsroot/boost/boost/libs/fusion/test/algorithm/ext_
In directory 
sc8-pr-cvs3.sourceforge.net:/tmp/cvs-serv8316/libs/fusion/test/algorithm/ext_

Added Files:
        find_if_s.cpp for_each_s.cpp 
Log Message:
experimental segmented Fusion support

--- NEW FILE: find_if_s.cpp ---
/*=============================================================================
    Copyright (c) 2001-2006 Joel de Guzman

    Use, modification and distribution is subject to the Boost Software
    License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
    http://www.boost.org/LICENSE_1_0.txt)
==============================================================================*/
#include <boost/detail/lightweight_test.hpp>
#include <boost/fusion/sequence/container/vector/vector.hpp>
#include <boost/fusion/sequence/adapted/mpl.hpp>
#include <boost/fusion/sequence/io/out.hpp>
#include <boost/fusion/algorithm/query/ext_/find_if_s.hpp>
#include <boost/fusion/sequence/container/ext_/tree.hpp>
#include <boost/fusion/sequence/generation/make_vector.hpp>
#include <boost/mpl/vector.hpp>
#include <boost/mpl/vector_c.hpp>
#include <boost/mpl/less.hpp>
#include <boost/type_traits/is_same.hpp>

struct X
{
    operator int() const
    {
        return 12345;
    }
};

template<typename Tree>
void 
process_tree(Tree const &tree)
{
    using namespace boost;
    using mpl::_;

    typedef typename fusion::result_of::find_if_s<Tree const, is_same<_,short> 
>::type short_iter;
    typedef typename fusion::result_of::find_if_s<Tree const, is_same<_,float> 
>::type float_iter;

    // find_if_s of a segmented data structure returns generic
    // segmented iterators
    short_iter si = fusion::find_if_s<is_same<_,short> >(tree);
    float_iter fi = fusion::find_if_s<is_same<_,float> >(tree);

    // they behave like ordinary Fusion iterators ...
    BOOST_TEST((*si == short('d')));
    BOOST_TEST((*fi == float(1)));
}

int
main()
{
    using namespace boost::fusion;

    {
        using boost::is_same;
        using boost::mpl::_;

        typedef vector<int, char, int, double> vector_type;
        vector_type v(12345, 'x', 678910, 3.36);

        std::cout << *find_if_s<is_same<_, char> >(v) << std::endl;
        BOOST_TEST((*find_if_s<is_same<_, char> >(v) == 'x'));

        std::cout << *find_if_s<is_same<_, int> >(v) << std::endl;
        BOOST_TEST((*find_if_s<is_same<_, int> >(v) == 12345));

        std::cout << *find_if_s<is_same<_, double> >(v) << std::endl;
        BOOST_TEST((*find_if_s<is_same<_, double> >(v) == 3.36));
    }

    {
        using boost::mpl::vector;
        using boost::is_same;
        using boost::mpl::_;

        typedef vector<int, char, X, double> mpl_vec;
        BOOST_TEST((*find_if_s<is_same<_, X> >(mpl_vec()) == 12345));
    }

    {
        using boost::mpl::vector_c;
        using boost::mpl::less;
        using boost::mpl::int_;
        using boost::is_same;
        using boost::mpl::_;

        typedef vector_c<int, 1, 2, 3, 4> mpl_vec;
        BOOST_TEST((*find_if_s<less<_, int_<3> > >(mpl_vec()) == 1));
    }

    {
        process_tree(
            make_tree(
                make_vector(double(0),'B')
              , make_tree(
                    make_vector(1,2,long(3))
                  , make_tree(make_vector('a','b','c'))
                  , make_tree(make_vector(short('d'),'e','f'))
                )
              , make_tree(
                    make_vector(4,5,6)
                  , make_tree(make_vector(float(1),'h','i'))
                  , make_tree(make_vector('j','k','l'))
                )
            )
        );
    }

    return boost::report_errors();
}


--- NEW FILE: for_each_s.cpp ---
/*=============================================================================
    Copyright (c) 2001-2006 Joel de Guzman, Eric Niebler

    Use, modification and distribution is subject to the Boost Software
    License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
    http://www.boost.org/LICENSE_1_0.txt)
==============================================================================*/
#include <boost/detail/lightweight_test.hpp>
#include <boost/fusion/sequence/container/vector/vector.hpp>
#include <boost/fusion/sequence/adapted/mpl.hpp>
#include <boost/fusion/sequence/io/out.hpp>
#include <boost/fusion/algorithm/iteration/ext_/for_each_s.hpp>
#include <boost/mpl/vector_c.hpp>
#include <boost/fusion/sequence/generation/make_vector.hpp>
#include <boost/fusion/sequence/container/ext_/tree.hpp>

struct print
{
    template <typename T>
    void operator()(T const& v) const
    {
        std::cout << "[ " << v << " ] ";
    }
};

struct increment
{
    template <typename T>
    void operator()(T& v) const
    {
        ++v;
    }
};

int
main()
{
    using namespace boost::fusion;
    using boost::mpl::vector_c;
    namespace fusion = boost::fusion;

    {
        typedef vector<int, char, double, char const*> vector_type;
        vector_type v(1, 'x', 3.3, "Ruby");
        for_each_s(v, print());
        std::cout << std::endl;
    }

    {
        typedef vector<int, char, double, char const*> vector_type;
        vector_type v(1, 'x', 3.3, "Ruby");
        for_each_s(v, increment());
        std::cout << v << std::endl;
    }

    {
        typedef vector_c<int, 2, 3, 4, 5, 6> mpl_vec;
        fusion::for_each_s(mpl_vec(), print());
        std::cout << std::endl;
    }

    {
        fusion::for_each_s(
            make_tree(
                make_vector(double(0),'B')
              , make_tree(
                    make_vector(1,2,long(3))
                  , make_tree(make_vector('a','b','c'))
                  , make_tree(make_vector(short('d'),'e','f'))
                )
              , make_tree(
                    make_vector(4,5,6)
                  , make_tree(make_vector(float(1),'h','i'))
                  , make_tree(make_vector('j','k','l'))
                )
            )
          , print()
        );
    }

    return boost::report_errors();
}



-------------------------------------------------------------------------
Take Surveys. Earn Cash. Influence the Future of IT
Join SourceForge.net's Techsay panel and you'll get the chance to share your
opinions on IT & business topics through brief surveys -- and earn cash
http://www.techsay.com/default.php?page=join.php&p=sourceforge&CID=DEVDEV
_______________________________________________
Boost-cvs mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/boost-cvs

Reply via email to