mirror of
				https://github.com/boostorg/unordered.git
				synced 2025-11-04 01:31:41 +01:00 
			
		
		
		
	New version of Boost.Unordered
Merged revisions 55470,55877-55878,55901-55902,55921-55922,55990-55992,56009-56010,56329,56346-56349,56362-56363,56374 via svnmerge from https://svn.boost.org/svn/boost/trunk ........ r55470 | danieljames | 2009-08-08 19:50:00 +0100 (Sat, 08 Aug 2009) | 1 line Remove empty svn:mergeinfo properties. This should reduce the amount of differences between trunk and release. ........ r55877 | danieljames | 2009-08-30 17:33:42 +0100 (Sun, 30 Aug 2009) | 1 line Remove allocator_constructor since it's never used. ........ r55878 | danieljames | 2009-08-30 17:42:28 +0100 (Sun, 30 Aug 2009) | 6 lines Initial checkin of new version of Boost.Unordered. - More template use, less preprocessor use. - Removed some of the Visual C++ 6 workarounds. - Reduced memory use of the main object. - Split into smaller headers. ........ r55901 | danieljames | 2009-08-31 11:39:25 +0100 (Mon, 31 Aug 2009) | 1 line Detab. ........ r55902 | danieljames | 2009-08-31 11:39:40 +0100 (Mon, 31 Aug 2009) | 1 line Remove unnecessary BOOST_DEDUCED_TYPENAMEs ........ r55921 | danieljames | 2009-08-31 16:33:28 +0100 (Mon, 31 Aug 2009) | 1 line Remove a few unused parameters. ........ r55922 | danieljames | 2009-08-31 16:33:49 +0100 (Mon, 31 Aug 2009) | 1 line Remove 'static' from next_node and node_count. Will hopefully make vacpp happy. ........ r55990 | danieljames | 2009-09-03 08:36:21 +0100 (Thu, 03 Sep 2009) | 1 line Combine hash_structure and hash_table_manager. ........ r55991 | danieljames | 2009-09-03 08:37:14 +0100 (Thu, 03 Sep 2009) | 1 line Remove some old Visual C++ workarounds. ........ r55992 | danieljames | 2009-09-03 08:37:30 +0100 (Thu, 03 Sep 2009) | 1 line Add a small test to see if the tested compilers support out of line template methods. ........ r56009 | danieljames | 2009-09-04 08:02:28 +0100 (Fri, 04 Sep 2009) | 1 line Fix link to n2691. ........ r56010 | danieljames | 2009-09-04 08:03:04 +0100 (Fri, 04 Sep 2009) | 1 line Move size_ and cached_begin_bucket_ into table, rename hash_table_manager hash_buckets. ........ r56329 | danieljames | 2009-09-20 22:55:15 +0100 (Sun, 20 Sep 2009) | 2 lines Since all the compilers support out of line template members use them and lots of other things. ........ r56346 | danieljames | 2009-09-21 22:17:19 +0100 (Mon, 21 Sep 2009) | 1 line Slightly more consistent variable names. In detail 'n' is now always a node pointer. ........ r56347 | danieljames | 2009-09-21 22:17:40 +0100 (Mon, 21 Sep 2009) | 1 line Fix bug where container was reducing the number of buckets. ........ r56348 | danieljames | 2009-09-21 22:18:01 +0100 (Mon, 21 Sep 2009) | 1 line Fix a bug that was causing unnecessary rehahes. ........ r56349 | danieljames | 2009-09-21 22:18:21 +0100 (Mon, 21 Sep 2009) | 1 line Use std::max. ........ r56362 | danieljames | 2009-09-22 23:39:00 +0100 (Tue, 22 Sep 2009) | 1 line Another std::max. ........ r56363 | danieljames | 2009-09-22 23:39:17 +0100 (Tue, 22 Sep 2009) | 1 line Remove the emplace_hint implementation for unique containers as it isn't really used and seems to be causing sun 5.7 problems. ........ r56374 | danieljames | 2009-09-24 21:42:19 +0100 (Thu, 24 Sep 2009) | 1 line Remove temporary test. ........ [SVN r56375]
This commit is contained in:
		@@ -3,5 +3,7 @@
 | 
			
		||||
# 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)
 | 
			
		||||
 | 
			
		||||
import testing ;
 | 
			
		||||
 | 
			
		||||
build-project unordered ;
 | 
			
		||||
build-project exception ;
 | 
			
		||||
 
 | 
			
		||||
@@ -21,14 +21,17 @@ namespace test
 | 
			
		||||
 | 
			
		||||
    namespace test_detail
 | 
			
		||||
    {
 | 
			
		||||
        template <typename T> struct list_node;
 | 
			
		||||
        template <typename T> class list_node;
 | 
			
		||||
        template <typename T> class list_data;
 | 
			
		||||
        template <typename T> class list_iterator;
 | 
			
		||||
        template <typename T> class list_const_iterator;
 | 
			
		||||
 | 
			
		||||
        template <typename T>
 | 
			
		||||
        struct list_node
 | 
			
		||||
        class list_node
 | 
			
		||||
        {
 | 
			
		||||
	    list_node(list_node const&);
 | 
			
		||||
	    list_node& operator=(list_node const&);
 | 
			
		||||
        public:
 | 
			
		||||
            T value_;
 | 
			
		||||
            list_node* next_;
 | 
			
		||||
                    
 | 
			
		||||
@@ -243,8 +246,8 @@ namespace test
 | 
			
		||||
        node** merge_adjacent_ranges(node** first, node** second,
 | 
			
		||||
                node** third, Less less)
 | 
			
		||||
        {
 | 
			
		||||
            while(true) {
 | 
			
		||||
                while(true) {
 | 
			
		||||
            for(;;) {
 | 
			
		||||
                for(;;) {
 | 
			
		||||
                    if(first == second) return third;
 | 
			
		||||
                    if(less((*second)->value_, (*first)->value_)) break;
 | 
			
		||||
                    first = &(*first)->next_;
 | 
			
		||||
@@ -256,7 +259,7 @@ namespace test
 | 
			
		||||
                // Since the two ranges we just swapped, the order is now:
 | 
			
		||||
                // first...third...second
 | 
			
		||||
                
 | 
			
		||||
                while(true) {
 | 
			
		||||
                for(;;) {
 | 
			
		||||
                    if(first == third) return second;
 | 
			
		||||
                    if(!less((*first)->value_, (*third)->value_)) break;
 | 
			
		||||
                    first = &(*first)->next_;
 | 
			
		||||
 
 | 
			
		||||
@@ -10,6 +10,7 @@ project unordered-test/unordered
 | 
			
		||||
        <toolset>intel-linux:"<cxxflags>-strict_ansi -cxxlib-icc"
 | 
			
		||||
        <toolset>gcc:<cxxflags>"-Wsign-promo -Wunused-parameter"
 | 
			
		||||
        #<toolset>msvc:<cxxflags>/W4
 | 
			
		||||
        <warnings>all
 | 
			
		||||
    ;
 | 
			
		||||
 | 
			
		||||
test-suite unordered
 | 
			
		||||
 
 | 
			
		||||
@@ -250,6 +250,19 @@ void constructor_tests2(T*, test::random_generator const& generator = test::defa
 | 
			
		||||
        test::check_equivalent_keys(x);
 | 
			
		||||
        test::check_equivalent_keys(y);
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    std::cerr<<"Construct 9\n";
 | 
			
		||||
    {
 | 
			
		||||
        test::random_values<T> v(100, generator);
 | 
			
		||||
        T x(50);
 | 
			
		||||
        BOOST_TEST(x.bucket_count() >= 50);
 | 
			
		||||
        x.max_load_factor(10);
 | 
			
		||||
        BOOST_TEST(x.bucket_count() >= 50);
 | 
			
		||||
        x.insert(v.begin(), v.end());
 | 
			
		||||
        BOOST_TEST(x.bucket_count() >= 50);
 | 
			
		||||
        test::check_container(x, v);
 | 
			
		||||
        test::check_equivalent_keys(x);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
template <class T>
 | 
			
		||||
 
 | 
			
		||||
@@ -41,7 +41,7 @@ void copy_construct_tests1(T*, test::random_generator const& generator = test::d
 | 
			
		||||
        T x(v.begin(), v.end());
 | 
			
		||||
        T y(x);
 | 
			
		||||
        test::unordered_equivalence_tester<T> equivalent(x);
 | 
			
		||||
        equivalent(y);
 | 
			
		||||
        BOOST_TEST(equivalent(y));
 | 
			
		||||
        test::check_equivalent_keys(y);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -55,7 +55,7 @@ void copy_construct_tests1(T*, test::random_generator const& generator = test::d
 | 
			
		||||
        x.max_load_factor(x.load_factor() / 4);
 | 
			
		||||
        T y(x);
 | 
			
		||||
        test::unordered_equivalence_tester<T> equivalent(x);
 | 
			
		||||
        equivalent(y);
 | 
			
		||||
        BOOST_TEST(equivalent(y));
 | 
			
		||||
        // This isn't guaranteed:
 | 
			
		||||
        BOOST_TEST(y.load_factor() < y.max_load_factor());
 | 
			
		||||
        test::check_equivalent_keys(y);
 | 
			
		||||
@@ -100,7 +100,7 @@ void copy_construct_tests2(T* ptr, test::random_generator const& generator = tes
 | 
			
		||||
        T x(v.begin(), v.end(), 0, hf, eq, al);
 | 
			
		||||
        T y(x);
 | 
			
		||||
        test::unordered_equivalence_tester<T> equivalent(x);
 | 
			
		||||
        equivalent(y);
 | 
			
		||||
        BOOST_TEST(equivalent(y));
 | 
			
		||||
        test::check_equivalent_keys(y);
 | 
			
		||||
        BOOST_TEST(test::equivalent(y.get_allocator(), al));
 | 
			
		||||
    }
 | 
			
		||||
@@ -111,7 +111,7 @@ void copy_construct_tests2(T* ptr, test::random_generator const& generator = tes
 | 
			
		||||
        T x(v.begin(), v.end(), 0, hf, eq, al);
 | 
			
		||||
        T y(x, al2);
 | 
			
		||||
        test::unordered_equivalence_tester<T> equivalent(x);
 | 
			
		||||
        equivalent(y);
 | 
			
		||||
        BOOST_TEST(equivalent(y));
 | 
			
		||||
        test::check_equivalent_keys(y);
 | 
			
		||||
        BOOST_TEST(test::equivalent(y.get_allocator(), al2));
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -116,7 +116,7 @@ bool compare(Range1 const& x, Range2 const& y)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
template <class Container>
 | 
			
		||||
bool general_erase_range_test(Container& x, int start, int end)
 | 
			
		||||
bool general_erase_range_test(Container& x, std::size_t start, std::size_t end)
 | 
			
		||||
{
 | 
			
		||||
    collide_list l(x.begin(), x.end());
 | 
			
		||||
    l.erase(boost::next(l.begin(), start), boost::next(l.begin(), end));
 | 
			
		||||
 
 | 
			
		||||
@@ -119,7 +119,7 @@ namespace move_tests
 | 
			
		||||
            BOOST_TEST(y.max_load_factor() == 2.0); // Not necessarily required.
 | 
			
		||||
            test::check_equivalent_keys(y);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
        {
 | 
			
		||||
            test::random_values<T> v(25, generator);
 | 
			
		||||
            T y(create(v, count, hf, eq, al, 1.0), al);
 | 
			
		||||
@@ -137,7 +137,7 @@ namespace move_tests
 | 
			
		||||
            BOOST_TEST(y.max_load_factor() == 1.0); // Not necessarily required.
 | 
			
		||||
            test::check_equivalent_keys(y);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
*/    }
 | 
			
		||||
 | 
			
		||||
    boost::unordered_set<test::object, test::hash, test::equal_to, test::allocator<test::object> >* test_set;
 | 
			
		||||
    boost::unordered_multiset<test::object, test::hash, test::equal_to, test::allocator<test::object> >* test_multiset;
 | 
			
		||||
 
 | 
			
		||||
@@ -60,6 +60,7 @@ void simple_test(X const& a)
 | 
			
		||||
        X u;
 | 
			
		||||
        X& r = u;
 | 
			
		||||
        BOOST_TEST(&(r = r) == &r);
 | 
			
		||||
 | 
			
		||||
        BOOST_TEST(r.empty());
 | 
			
		||||
        BOOST_TEST(&(r = a) == &r);
 | 
			
		||||
        BOOST_TEST(equivalent(r));
 | 
			
		||||
@@ -91,7 +92,7 @@ UNORDERED_AUTO_TEST(simple_tests)
 | 
			
		||||
    std::cout<<"Test unordered_set.\n";
 | 
			
		||||
    boost::unordered_set<int> set;
 | 
			
		||||
    simple_test(set);
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
    set.insert(1); set.insert(2); set.insert(1456);
 | 
			
		||||
    simple_test(set);
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user