189 lines
4.9 KiB
C++
189 lines
4.9 KiB
C++
// Boost.Range library
|
|
//
|
|
// Copyright Neil Groves 2010. 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/range/
|
|
//
|
|
#include <boost/range/algorithm_ext/erase.hpp>
|
|
|
|
#include <boost/test/test_tools.hpp>
|
|
#include <boost/test/unit_test.hpp>
|
|
|
|
#include <boost/range/iterator.hpp>
|
|
#include <algorithm>
|
|
#include <list>
|
|
#include <vector>
|
|
|
|
namespace
|
|
{
|
|
template< class Container >
|
|
void test_erase_impl()
|
|
{
|
|
Container source;
|
|
for (int i = 0; i < 10; ++i)
|
|
source.push_back(i);
|
|
|
|
Container reference(source);
|
|
Container test(source);
|
|
|
|
typedef BOOST_DEDUCED_TYPENAME Container::iterator iterator_t;
|
|
|
|
iterator_t first_ref = reference.begin();
|
|
iterator_t last_ref = reference.end();
|
|
|
|
boost::iterator_range< iterator_t > test_range(test.begin(), test.end());
|
|
|
|
reference.erase(first_ref, last_ref);
|
|
boost::erase(test, test_range);
|
|
|
|
BOOST_CHECK_EQUAL_COLLECTIONS( reference.begin(), reference.end(),
|
|
test.begin(), test.end() );
|
|
}
|
|
|
|
void test_erase()
|
|
{
|
|
test_erase_impl<std::vector<int> >();
|
|
test_erase_impl<std::list<int> >();
|
|
}
|
|
|
|
template< class Container >
|
|
void test_remove_erase_impl()
|
|
{
|
|
Container source;
|
|
for (int i = 0; i < 10; ++i)
|
|
source.push_back(i);
|
|
|
|
Container reference(source);
|
|
Container test(source);
|
|
|
|
boost::remove_erase(test, 5);
|
|
|
|
reference.erase( std::find(reference.begin(), reference.end(), 5) );
|
|
|
|
BOOST_CHECK_EQUAL_COLLECTIONS( reference.begin(), reference.end(),
|
|
test.begin(), test.end() );
|
|
}
|
|
|
|
void test_remove_erase()
|
|
{
|
|
test_remove_erase_impl<std::vector<int> >();
|
|
test_remove_erase_impl<std::list<int> >();
|
|
}
|
|
|
|
struct is_even
|
|
{
|
|
typedef bool result_type;
|
|
typedef int argument_type;
|
|
bool operator()(int x) const { return x % 2 == 0; }
|
|
};
|
|
|
|
template< class Container >
|
|
void test_remove_erase_if_impl()
|
|
{
|
|
Container source;
|
|
for (int i = 0; i < 10; ++i)
|
|
source.push_back(i);
|
|
|
|
Container reference;
|
|
typedef BOOST_DEDUCED_TYPENAME Container::const_iterator iterator_t;
|
|
iterator_t last_source = source.end();
|
|
is_even pred;
|
|
for (iterator_t it_source = source.begin(); it_source != last_source; ++it_source)
|
|
{
|
|
if (!pred(*it_source))
|
|
reference.push_back(*it_source);
|
|
}
|
|
|
|
Container test(source);
|
|
boost::remove_erase_if(test, is_even());
|
|
|
|
BOOST_CHECK_EQUAL_COLLECTIONS( reference.begin(), reference.end(),
|
|
test.begin(), test.end() );
|
|
|
|
}
|
|
|
|
void test_remove_erase_if()
|
|
{
|
|
test_remove_erase_if_impl<std::vector<int> >();
|
|
test_remove_erase_if_impl<std::list<int> >();
|
|
}
|
|
|
|
template< class Container >
|
|
void test_unique_erase_impl()
|
|
{
|
|
Container source;
|
|
source.push_back(1);
|
|
source.push_back(1);
|
|
source.push_back(1);
|
|
source.push_back(2);
|
|
source.push_back(3);
|
|
source.push_back(3);
|
|
|
|
Container reference;
|
|
reference.push_back(1);
|
|
reference.push_back(2);
|
|
reference.push_back(3);
|
|
|
|
boost::unique_erase(source);
|
|
|
|
BOOST_CHECK_EQUAL_COLLECTIONS( reference.begin(), reference.end(),
|
|
source.begin(), source.end() );
|
|
}
|
|
|
|
void test_unique_erase()
|
|
{
|
|
test_unique_erase_impl<std::vector<int> >();
|
|
test_unique_erase_impl<std::list<int> >();
|
|
}
|
|
|
|
struct distance_smaller_2
|
|
{
|
|
typedef bool result_type;
|
|
typedef int argument_type;
|
|
bool operator()(int x, int y) const { return std::abs(x - y) < 2; }
|
|
};
|
|
|
|
template< class Container >
|
|
void test_unique_erase_pred_impl()
|
|
{
|
|
Container source;
|
|
for (int i = 0; i < 10; ++i)
|
|
source.push_back(i);
|
|
|
|
Container reference;
|
|
for (int i = 0; i < 10; i += 2)
|
|
reference.push_back(i);
|
|
|
|
|
|
boost::unique_erase(source, distance_smaller_2());
|
|
|
|
BOOST_CHECK_EQUAL_COLLECTIONS( reference.begin(), reference.end(),
|
|
source.begin(), source.end() );
|
|
}
|
|
|
|
void test_unique_erase_pred()
|
|
{
|
|
test_unique_erase_pred_impl<std::vector<int> >();
|
|
test_unique_erase_pred_impl<std::list<int> >();
|
|
}
|
|
}
|
|
|
|
boost::unit_test::test_suite*
|
|
init_unit_test_suite(int argc, char* argv[])
|
|
{
|
|
boost::unit_test::test_suite* test
|
|
= BOOST_TEST_SUITE( "RangeTestSuite.algorithm_ext.erase" );
|
|
|
|
test->add( BOOST_TEST_CASE( &test_erase ) );
|
|
test->add( BOOST_TEST_CASE( &test_remove_erase ) );
|
|
test->add( BOOST_TEST_CASE( &test_remove_erase_if ) );
|
|
test->add( BOOST_TEST_CASE( &test_unique_erase ) );
|
|
test->add( BOOST_TEST_CASE( &test_unique_erase_pred ) );
|
|
|
|
return test;
|
|
}
|