////////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2004-2013. Distributed under 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) // // See http://www.boost.org/libs/container for documentation. // ////////////////////////////////////////////////////////////////////////////// #include #include #include #include #include #include "dummy_test_allocator.hpp" #include #include "movable_int.hpp" #include "list_test.hpp" #include "propagate_allocator_test.hpp" #include "emplace_test.hpp" using namespace boost::container; namespace boost { namespace container { //Explicit instantiation to detect compilation errors template class boost::container::list < test::movable_and_copyable_int , test::simple_allocator >; template class boost::container::list < test::movable_and_copyable_int , test::dummy_test_allocator >; template class boost::container::list < test::movable_and_copyable_int , std::allocator >; template class boost::container::list < test::movable_and_copyable_int , allocator >; template class boost::container::list < test::movable_and_copyable_int , adaptive_pool >; template class boost::container::list < test::movable_and_copyable_int , node_allocator >; namespace container_detail { template class iterator_from_iiterator >::container_type::iterator, true >; template class iterator_from_iiterator >::container_type::iterator, false>; } }} class recursive_list { public: int id_; list list_; list::iterator it_; list::const_iterator cit_; list::reverse_iterator rit_; list::const_reverse_iterator crit_; recursive_list &operator=(const recursive_list &o) { list_ = o.list_; return *this; } }; void recursive_list_test()//Test for recursive types { list recursive, copy; //Test to test both move emulations if(!copy.size()){ copy = recursive; } } template struct GetAllocatorCont { template struct apply { typedef list< ValueType , typename allocator_traits ::template portable_rebind_alloc::type > type; }; }; template int test_cont_variants() { typedef typename GetAllocatorCont::template apply::type MyCont; typedef typename GetAllocatorCont::template apply::type MyMoveCont; typedef typename GetAllocatorCont::template apply::type MyCopyMoveCont; typedef typename GetAllocatorCont::template apply::type MyCopyCont; if(test::list_test()) return 1; if(test::list_test()) return 1; if(test::list_test()) return 1; if(test::list_test()) return 1; if(test::list_test()) return 1; return 0; } bool test_support_for_initializer_list() { #if !defined(BOOST_NO_CXX11_HDR_INITIALIZER_LIST) const std::initializer_list il = {1, 10}; const list expectedList(il.begin(), il.end()); const list testConstructor = il; if(testConstructor != expectedList) return false; list testAssignOperator = {10, 11}; testAssignOperator = il; if(testAssignOperator != expectedList) return false; list testAssignMethod = {99}; testAssignMethod = il; if(testAssignMethod != expectedList) return false; list testInsertMethod; testInsertMethod.insert(testInsertMethod.cbegin(), il); if(testInsertMethod != testInsertMethod) return false; return true; #endif return true; } int main () { recursive_list_test(); { //Now test move semantics list original; list move_ctor(boost::move(original)); list move_assign; move_assign = boost::move(move_ctor); move_assign.swap(original); } //////////////////////////////////// // Testing allocator implementations //////////////////////////////////// // std:allocator if(test_cont_variants< std::allocator >()){ std::cerr << "test_cont_variants< std::allocator > failed" << std::endl; return 1; } // boost::container::allocator if(test_cont_variants< allocator >()){ std::cerr << "test_cont_variants< allocator > failed" << std::endl; return 1; } // boost::container::node_allocator if(test_cont_variants< node_allocator >()){ std::cerr << "test_cont_variants< node_allocator > failed" << std::endl; return 1; } // boost::container::adaptive_pool if(test_cont_variants< adaptive_pool >()){ std::cerr << "test_cont_variants< adaptive_pool > failed" << std::endl; return 1; } //////////////////////////////////// // Emplace testing //////////////////////////////////// const test::EmplaceOptions Options = (test::EmplaceOptions)(test::EMPLACE_BACK | test::EMPLACE_FRONT | test::EMPLACE_BEFORE); if(!boost::container::test::test_emplace, Options>()) return 1; //////////////////////////////////// // Allocator propagation testing //////////////////////////////////// if(!boost::container::test::test_propagate_allocator()) return 1; if(!test_support_for_initializer_list()) return 1; return 0; } #include /* #include //#include int main() { return 0; } */