// Copyright 2005-2008 Daniel James. // 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) #if defined(BOOST_MSVC) #pragma warning(push) #pragma warning(disable:4100) // unreferenced formal parameter #endif #include #if defined(BOOST_MSVC) #pragma warning(pop) #endif #include #include #include #include #include #include #include "../helpers/check_return_type.hpp" typedef long double comparison_type; template void sink(T const&) {} template void container_test(X& r, T&) { typedef BOOST_DEDUCED_TYPENAME X::iterator iterator; typedef BOOST_DEDUCED_TYPENAME X::const_iterator const_iterator; typedef BOOST_DEDUCED_TYPENAME X::difference_type difference_type; typedef BOOST_DEDUCED_TYPENAME X::size_type size_type; typedef BOOST_DEDUCED_TYPENAME boost::iterator_value::type iterator_value_type; typedef BOOST_DEDUCED_TYPENAME boost::iterator_value::type const_iterator_value_type; typedef BOOST_DEDUCED_TYPENAME boost::iterator_difference::type iterator_difference_type; typedef BOOST_DEDUCED_TYPENAME boost::iterator_difference::type const_iterator_difference_type; typedef BOOST_DEDUCED_TYPENAME X::value_type value_type; typedef BOOST_DEDUCED_TYPENAME X::reference reference; typedef BOOST_DEDUCED_TYPENAME X::const_reference const_reference; // value_type BOOST_MPL_ASSERT((boost::is_same)); boost::function_requires >(); // reference_type / const_reference_type BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); // iterator boost::function_requires >(); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_convertible)); // const_iterator boost::function_requires >(); BOOST_MPL_ASSERT((boost::is_same)); // difference_type BOOST_MPL_ASSERT((boost::mpl::bool_< std::numeric_limits::is_signed>)); BOOST_MPL_ASSERT((boost::mpl::bool_< std::numeric_limits::is_integer>)); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); // size_type BOOST_MPL_ASSERT_NOT((boost::mpl::bool_< std::numeric_limits::is_signed>)); BOOST_MPL_ASSERT((boost::mpl::bool_< std::numeric_limits::is_integer>)); // size_type can represent any non-negative value type of difference_type // I'm not sure about either of these tests... size_type max_diff((std::numeric_limits::max)()); difference_type converted_diff(max_diff); BOOST_TEST((std::numeric_limits::max)() == converted_diff); BOOST_TEST( static_cast( (std::numeric_limits::max)()) > static_cast( (std::numeric_limits::max)())); // I don't test the runtime post-conditions here. X u; BOOST_TEST(u.size() == 0); BOOST_TEST(X().size() == 0); X a,b; sink(X(a)); X u2(a); X u3 = a; X* ptr = new X(); X& a1 = *ptr; (&a1)->~X(); X const a_const; test::check_return_type::equals(a.begin()); test::check_return_type::equals(a_const.begin()); test::check_return_type::equals(a.cbegin()); test::check_return_type::equals(a_const.cbegin()); test::check_return_type::equals(a.end()); test::check_return_type::equals(a_const.end()); test::check_return_type::equals(a.cend()); test::check_return_type::equals(a_const.cend()); // No tests for ==, != since they're not required for unordered containers. a.swap(b); test::check_return_type::equals_ref(r = a); test::check_return_type::equals(a.size()); test::check_return_type::equals(a.max_size()); test::check_return_type::convertible(a.empty()); } template void unordered_set_test(X&, Key const&) { typedef BOOST_DEDUCED_TYPENAME X::value_type value_type; typedef BOOST_DEDUCED_TYPENAME X::key_type key_type; BOOST_MPL_ASSERT((boost::is_same)); } template void unordered_map_test(X&, Key const&, T const&) { typedef BOOST_DEDUCED_TYPENAME X::value_type value_type; typedef BOOST_DEDUCED_TYPENAME X::key_type key_type; BOOST_MPL_ASSERT((boost::is_same >)); } template void unordered_unique_test(X& r, T const& t) { typedef BOOST_DEDUCED_TYPENAME X::iterator iterator; test::check_return_type >::equals(r.insert(t)); } template void unordered_equivalent_test(X& r, T const& t) { typedef BOOST_DEDUCED_TYPENAME X::iterator iterator; test::check_return_type::equals(r.insert(t)); } template void unordered_map_functions(X&, Key const& k, T const&) { typedef BOOST_DEDUCED_TYPENAME X::mapped_type mapped_type; X a; test::check_return_type::equals_ref(a[k]); test::check_return_type::equals_ref(a.at(k)); X const b = a; test::check_return_type::equals_ref(b.at(k)); } template void unordered_test(X&, Key& k, T& t, Hash& hf, Pred& eq) { typedef BOOST_DEDUCED_TYPENAME X::key_type key_type; typedef BOOST_DEDUCED_TYPENAME X::hasher hasher; typedef BOOST_DEDUCED_TYPENAME X::key_equal key_equal; typedef BOOST_DEDUCED_TYPENAME X::size_type size_type; typedef BOOST_DEDUCED_TYPENAME X::iterator iterator; typedef BOOST_DEDUCED_TYPENAME X::const_iterator const_iterator; typedef BOOST_DEDUCED_TYPENAME X::local_iterator local_iterator; typedef BOOST_DEDUCED_TYPENAME X::const_local_iterator const_local_iterator; typedef BOOST_DEDUCED_TYPENAME boost::BOOST_ITERATOR_CATEGORY::type iterator_category; typedef BOOST_DEDUCED_TYPENAME boost::iterator_difference::type iterator_difference; typedef BOOST_DEDUCED_TYPENAME boost::iterator_pointer::type iterator_pointer; typedef BOOST_DEDUCED_TYPENAME boost::iterator_reference::type iterator_reference; typedef BOOST_DEDUCED_TYPENAME boost::BOOST_ITERATOR_CATEGORY::type local_iterator_category; typedef BOOST_DEDUCED_TYPENAME boost::iterator_difference::type local_iterator_difference; typedef BOOST_DEDUCED_TYPENAME boost::iterator_pointer::type local_iterator_pointer; typedef BOOST_DEDUCED_TYPENAME boost::iterator_reference::type local_iterator_reference; typedef BOOST_DEDUCED_TYPENAME boost::BOOST_ITERATOR_CATEGORY::type const_iterator_category; typedef BOOST_DEDUCED_TYPENAME boost::iterator_difference::type const_iterator_difference; typedef BOOST_DEDUCED_TYPENAME boost::iterator_pointer::type const_iterator_pointer; typedef BOOST_DEDUCED_TYPENAME boost::iterator_reference::type const_iterator_reference; typedef BOOST_DEDUCED_TYPENAME boost::BOOST_ITERATOR_CATEGORY::type const_local_iterator_category; typedef BOOST_DEDUCED_TYPENAME boost::iterator_difference::type const_local_iterator_difference; typedef BOOST_DEDUCED_TYPENAME boost::iterator_pointer::type const_local_iterator_pointer; typedef BOOST_DEDUCED_TYPENAME boost::iterator_reference::type const_local_iterator_reference; BOOST_MPL_ASSERT((boost::is_same)); boost::function_requires >(); boost::function_requires >(); BOOST_MPL_ASSERT((boost::is_same)); test::check_return_type::equals(hf(k)); BOOST_MPL_ASSERT((boost::is_same)); test::check_return_type::convertible(eq(k, k)); boost::function_requires >(); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); boost::function_requires >(); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); BOOST_MPL_ASSERT((boost::is_same)); X(10, hf, eq); X a(10, hf, eq); X(10, hf); X a2(10, hf); X(10); X a3(10); X(); X a4; BOOST_DEDUCED_TYPENAME X::value_type* i = 0; BOOST_DEDUCED_TYPENAME X::value_type* j = 0; X(i, j, 10, hf, eq); X a5(i, j, 10, hf, eq); X(i, j, 10, hf); X a6(i, j, 10, hf); X(i, j, 10); X a7(i, j, 10); X(i, j); X a8(i, j); X const b; sink(X(b)); X a9(b); a = b; test::check_return_type::equals(b.hash_function()); test::check_return_type::equals(b.key_eq()); const_iterator q = a.cbegin(); test::check_return_type::equals(a.insert(q, t)); a.insert(i, j); test::check_return_type::equals(a.erase(k)); BOOST_TEST(a.empty()); if(a.empty()) { a.insert(t); q = a.cbegin(); test::check_return_type::equals(a.erase(q)); } const_iterator q1 = a.cbegin(), q2 = a.cend(); test::check_return_type::equals(a.erase(q1, q2)); a.clear(); test::check_return_type::equals(a.find(k)); test::check_return_type::equals(b.find(k)); test::check_return_type::equals(b.count(k)); test::check_return_type >::equals( a.equal_range(k)); test::check_return_type >::equals( b.equal_range(k)); test::check_return_type::equals(b.bucket_count()); test::check_return_type::equals(b.max_bucket_count()); test::check_return_type::equals(b.bucket(k)); test::check_return_type::equals(b.bucket_size(0)); test::check_return_type::equals(a.begin(0)); test::check_return_type::equals(b.begin(0)); test::check_return_type::equals(a.end(0)); test::check_return_type::equals(b.end(0)); test::check_return_type::equals(a.cbegin(0)); test::check_return_type::equals(b.cbegin(0)); test::check_return_type::equals(a.cend(0)); test::check_return_type::equals(b.cend(0)); test::check_return_type::equals(b.load_factor()); test::check_return_type::equals(b.max_load_factor()); a.max_load_factor((float) 2.0); a.rehash(100); }