99 lines
2.5 KiB
C++
99 lines
2.5 KiB
C++
// Boost.Assign library
|
|
//
|
|
// Copyright Thorsten Ottosen 2003-2004. 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)
|
|
//
|
|
// For more information, see http://www.boost.org/libs/assign/
|
|
//
|
|
|
|
|
|
#include <boost/detail/workaround.hpp>
|
|
|
|
#if BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x564))
|
|
# pragma warn -8091 // suppress warning in Boost.Test
|
|
# pragma warn -8057 // unused argument argc/argv in Boost.Test
|
|
#endif
|
|
|
|
#include <boost/assign/list_of.hpp>
|
|
#include <boost/array.hpp>
|
|
#include <boost/test/test_tools.hpp>
|
|
#include <algorithm>
|
|
#include <iostream>
|
|
|
|
template< class Range >
|
|
void print( const Range& r )
|
|
{
|
|
std::cout << "\n printing " << typeid(r).name() << " \n";
|
|
std::cout << "\n";
|
|
for( typename Range::iterator i = r.begin(), e = r.end();
|
|
i !=e; ++i )
|
|
std::cout << " " << *i;
|
|
}
|
|
|
|
template< class Range >
|
|
void sort( const Range& r )
|
|
{
|
|
std::cout << "\n sorting " << typeid(r).name() << " \n";
|
|
std::sort( r.begin(), r.end() );
|
|
print( r );
|
|
}
|
|
|
|
template< class Range, class Pred >
|
|
void sort( const Range& r, Pred pred )
|
|
{
|
|
std::cout << "\n sorting " << typeid(r).name() << " \n";
|
|
std::sort( r.begin(), r.end(), pred );
|
|
print( r );
|
|
}
|
|
|
|
template< class Range >
|
|
typename Range::const_iterator max_element( const Range& r )
|
|
{
|
|
return std::max_element( r.begin(), r.end() );
|
|
}
|
|
|
|
|
|
|
|
void check_static_list_of()
|
|
{
|
|
using namespace boost::assign;
|
|
|
|
BOOST_CHECK( cref_list_of<5>( 1 )( 2 )( 3 )( 4 ).size() == 4 );
|
|
|
|
int a=1,b=5,c=3,d=4,e=2,f=9,g=0,h=7;
|
|
|
|
int& max = *max_element( ref_list_of<8>(a)(b)(c)(d)(e)(f)(g)(h) );
|
|
BOOST_CHECK_EQUAL( max, f );
|
|
max = 8;
|
|
BOOST_CHECK_EQUAL( f, 8 );
|
|
const int& const_max = *max_element( cref_list_of<8>(a)(b)(c)(d)(e)(f)(g)(h) );
|
|
BOOST_CHECK_EQUAL( max, const_max );
|
|
|
|
print( ref_list_of<8>(a)(b)(c)(d)(e)(f)(g)(h) );
|
|
print( cref_list_of<8>(a)(b)(c)(d)(e)(f)(g)(h) );
|
|
|
|
boost::array<int,4> array = cref_list_of<4>(1)(2)(3)(4);
|
|
|
|
BOOST_CHECK_EQUAL( array[0], 1 );
|
|
BOOST_CHECK_EQUAL( array[3], 4 );
|
|
//
|
|
//print( cref_list_of<5>( "foo" )( "bar" )( "foobar" ) );
|
|
//
|
|
}
|
|
|
|
#include <boost/test/unit_test.hpp>
|
|
using boost::unit_test::test_suite;
|
|
|
|
test_suite* init_unit_test_suite( int argc, char* argv[] )
|
|
{
|
|
test_suite* test = BOOST_TEST_SUITE( "List Test Suite" );
|
|
|
|
test->add( BOOST_TEST_CASE( &check_static_list_of ) );
|
|
|
|
return test;
|
|
}
|
|
|
|
|