2011-08-26 18:26:44 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2012-03-22 18:48:57 +00:00
|
|
|
// (C) Copyright Ion Gaztanaga 2004-2012. Distributed under the Boost
|
2011-08-26 18:26:44 +00:00
|
|
|
// Software License, Version 1.0. (See accompanying file
|
|
|
|
// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
// See http://www.boost.org/libs/container for documentation.
|
|
|
|
//
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include <boost/container/detail/config_begin.hpp>
|
|
|
|
#include <algorithm>
|
|
|
|
#include <memory>
|
|
|
|
#include <vector>
|
|
|
|
#include <iostream>
|
|
|
|
#include <functional>
|
|
|
|
|
|
|
|
#include <boost/container/vector.hpp>
|
2011-12-22 20:15:57 +00:00
|
|
|
#include <boost/move/move.hpp>
|
2011-08-26 18:26:44 +00:00
|
|
|
#include "check_equal_containers.hpp"
|
|
|
|
#include "movable_int.hpp"
|
|
|
|
#include "expand_bwd_test_allocator.hpp"
|
|
|
|
#include "expand_bwd_test_template.hpp"
|
|
|
|
#include "dummy_test_allocator.hpp"
|
2011-12-22 20:15:57 +00:00
|
|
|
#include "propagate_allocator_test.hpp"
|
2011-08-26 18:26:44 +00:00
|
|
|
#include "vector_test.hpp"
|
|
|
|
|
|
|
|
using namespace boost::container;
|
|
|
|
|
2011-12-22 20:15:57 +00:00
|
|
|
namespace boost {
|
|
|
|
namespace container {
|
|
|
|
|
2011-08-26 18:26:44 +00:00
|
|
|
//Explicit instantiation to detect compilation errors
|
2011-12-22 20:15:57 +00:00
|
|
|
template class boost::container::vector<test::movable_and_copyable_int,
|
|
|
|
test::simple_allocator<test::movable_and_copyable_int> >;
|
|
|
|
|
2011-08-26 18:26:44 +00:00
|
|
|
template class boost::container::vector<test::movable_and_copyable_int,
|
|
|
|
test::dummy_test_allocator<test::movable_and_copyable_int> >;
|
|
|
|
|
2011-12-22 20:15:57 +00:00
|
|
|
template class boost::container::vector<test::movable_and_copyable_int,
|
|
|
|
std::allocator<test::movable_and_copyable_int> >;
|
|
|
|
|
|
|
|
}}
|
|
|
|
|
2011-08-26 18:26:44 +00:00
|
|
|
int test_expand_bwd()
|
|
|
|
{
|
|
|
|
//Now test all back insertion possibilities
|
|
|
|
|
|
|
|
//First raw ints
|
|
|
|
typedef test::expand_bwd_test_allocator<int>
|
|
|
|
int_allocator_type;
|
|
|
|
typedef vector<int, int_allocator_type>
|
|
|
|
int_vector;
|
|
|
|
|
|
|
|
if(!test::test_all_expand_bwd<int_vector>())
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
//Now user defined wrapped int
|
|
|
|
typedef test::expand_bwd_test_allocator<test::int_holder>
|
|
|
|
int_holder_allocator_type;
|
|
|
|
typedef vector<test::int_holder, int_holder_allocator_type>
|
|
|
|
int_holder_vector;
|
|
|
|
|
|
|
|
if(!test::test_all_expand_bwd<int_holder_vector>())
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
//Now user defined bigger wrapped int
|
|
|
|
typedef test::expand_bwd_test_allocator<test::triple_int_holder>
|
|
|
|
triple_int_holder_allocator_type;
|
|
|
|
|
|
|
|
typedef vector<test::triple_int_holder, triple_int_holder_allocator_type>
|
|
|
|
triple_int_holder_vector;
|
|
|
|
|
|
|
|
if(!test::test_all_expand_bwd<triple_int_holder_vector>())
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
class recursive_vector
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
int id_;
|
|
|
|
vector<recursive_vector> vector_;
|
|
|
|
};
|
|
|
|
|
|
|
|
void recursive_vector_test()//Test for recursive types
|
|
|
|
{
|
|
|
|
vector<recursive_vector> recursive_vector_vector;
|
|
|
|
}
|
|
|
|
|
|
|
|
enum Test
|
|
|
|
{
|
|
|
|
zero, one, two, three, four, five, six
|
|
|
|
};
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
2012-03-22 18:48:57 +00:00
|
|
|
const std::size_t positions_length = 10;
|
|
|
|
std::size_t positions[positions_length];
|
|
|
|
vector<int> vector_int;
|
|
|
|
vector<int> vector_int2(positions_length);
|
|
|
|
for(std::size_t i = 0; i != positions_length; ++i){
|
|
|
|
positions[i] = 0u;
|
|
|
|
}
|
|
|
|
for(std::size_t i = 0, max = vector_int2.size(); i != max; ++i){
|
|
|
|
vector_int2[i] = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
vector_int.insert(vector_int.begin(), 999);
|
|
|
|
|
2012-03-23 17:51:44 +00:00
|
|
|
//vector_int.insert_at_ordered_positions(positions, positions_length, vector_int2.end());
|
2012-03-22 18:48:57 +00:00
|
|
|
|
|
|
|
for(std::size_t i = 0, max = vector_int.size(); i != max; ++i){
|
|
|
|
std::cout << vector_int[i] << std::endl;
|
|
|
|
}
|
|
|
|
return 0;
|
2012-03-23 17:51:44 +00:00
|
|
|
|
2011-08-26 18:26:44 +00:00
|
|
|
recursive_vector_test();
|
|
|
|
{
|
|
|
|
//Now test move semantics
|
|
|
|
vector<recursive_vector> original;
|
|
|
|
vector<recursive_vector> move_ctor(boost::move(original));
|
|
|
|
vector<recursive_vector> move_assign;
|
|
|
|
move_assign = boost::move(move_ctor);
|
|
|
|
move_assign.swap(original);
|
|
|
|
}
|
|
|
|
typedef vector<int> MyVector;
|
|
|
|
typedef vector<test::movable_int> MyMoveVector;
|
|
|
|
typedef vector<test::movable_and_copyable_int> MyCopyMoveVector;
|
|
|
|
typedef vector<test::copyable_int> MyCopyVector;
|
|
|
|
typedef vector<Test> MyEnumVector;
|
|
|
|
|
|
|
|
if(test::vector_test<MyVector>())
|
|
|
|
return 1;
|
|
|
|
if(test::vector_test<MyMoveVector>())
|
|
|
|
return 1;
|
|
|
|
if(test::vector_test<MyCopyMoveVector>())
|
|
|
|
return 1;
|
|
|
|
if(test::vector_test<MyCopyVector>())
|
|
|
|
return 1;
|
|
|
|
if(test_expand_bwd())
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
MyEnumVector v;
|
|
|
|
Test t;
|
|
|
|
v.push_back(t);
|
|
|
|
v.push_back(::boost::move(t));
|
|
|
|
v.push_back(Test());
|
|
|
|
|
|
|
|
const test::EmplaceOptions Options = (test::EmplaceOptions)(test::EMPLACE_BACK | test::EMPLACE_BEFORE);
|
|
|
|
if(!boost::container::test::test_emplace
|
|
|
|
< vector<test::EmplaceInt>, Options>())
|
|
|
|
return 1;
|
|
|
|
|
2011-12-22 20:15:57 +00:00
|
|
|
if(!boost::container::test::test_propagate_allocator<vector>())
|
|
|
|
return 1;
|
2012-03-22 18:48:57 +00:00
|
|
|
|
2011-08-26 18:26:44 +00:00
|
|
|
return 0;
|
2012-03-23 17:51:44 +00:00
|
|
|
|
2011-08-26 18:26:44 +00:00
|
|
|
}
|
|
|
|
#include <boost/container/detail/config_end.hpp>
|