| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-09 20:56:23 +00:00
										 |  |  | // Copyright 2006-2009 Daniel James.
 | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  | // 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_UNORDERED_EXCEPTION_TEST_HEADER)
 | 
					
						
							|  |  |  | #define BOOST_UNORDERED_EXCEPTION_TEST_HEADER
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "./test.hpp"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/preprocessor/seq/for_each_product.hpp>
 | 
					
						
							|  |  |  | #include <boost/preprocessor/seq/elem.hpp>
 | 
					
						
							|  |  |  | #include <boost/preprocessor/cat.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  | #   define UNORDERED_EXCEPTION_TEST_CASE(name, test_func, type)             \
 | 
					
						
							|  |  |  |         UNORDERED_AUTO_TEST(name)                                           \ | 
					
						
							|  |  |  |         {                                                                   \ | 
					
						
							|  |  |  |             test_func< type > fixture;                                      \ | 
					
						
							|  |  |  |             ::test::lightweight::exception_safety(                          \ | 
					
						
							|  |  |  |                 fixture, BOOST_STRINGIZE(test_func<type>));                 \ | 
					
						
							|  |  |  |         }                                                                   \ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-21 00:20:07 +00:00
										 |  |  | #   define UNORDERED_EXCEPTION_TEST_CASE_REPEAT(name, test_func, n, type)   \
 | 
					
						
							|  |  |  |         UNORDERED_AUTO_TEST(name)                                           \ | 
					
						
							|  |  |  |         {                                                                   \ | 
					
						
							|  |  |  |             for (unsigned i = 0; i < n; ++i) {                              \ | 
					
						
							|  |  |  |                 test_func< type > fixture;                                  \ | 
					
						
							|  |  |  |                 ::test::lightweight::exception_safety(                      \ | 
					
						
							|  |  |  |                     fixture, BOOST_STRINGIZE(test_func<type>));             \ | 
					
						
							|  |  |  |             }                                                               \ | 
					
						
							|  |  |  |         }                                                                   \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  | #    define UNORDERED_EPOINT_IMPL ::test::lightweight::epoint
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-24 17:03:15 +00:00
										 |  |  | #define UNORDERED_EXCEPTION_TEST_POSTFIX RUN_TESTS()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-21 00:20:07 +00:00
										 |  |  | #define EXCEPTION_TESTS(test_seq, param_seq)                                \
 | 
					
						
							|  |  |  |     BOOST_PP_SEQ_FOR_EACH_PRODUCT(EXCEPTION_TESTS_OP,                       \ | 
					
						
							|  |  |  |         (test_seq)((1))(param_seq)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define EXCEPTION_TESTS_REPEAT(n, test_seq, param_seq)                      \
 | 
					
						
							|  |  |  |     BOOST_PP_SEQ_FOR_EACH_PRODUCT(EXCEPTION_TESTS_OP,                       \ | 
					
						
							|  |  |  |         (test_seq)((n))(param_seq)) | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-21 00:20:07 +00:00
										 |  |  | #define EXCEPTION_TESTS_OP(r, product)                                      \
 | 
					
						
							|  |  |  |     UNORDERED_EXCEPTION_TEST_CASE_REPEAT(                                   \ | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |         BOOST_PP_CAT(BOOST_PP_SEQ_ELEM(0, product),                         \ | 
					
						
							| 
									
										
										
										
											2012-10-21 00:20:07 +00:00
										 |  |  |             BOOST_PP_CAT(_, BOOST_PP_SEQ_ELEM(2, product))                  \ | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |         ),                                                                  \ | 
					
						
							|  |  |  |         BOOST_PP_SEQ_ELEM(0, product),                                      \ | 
					
						
							| 
									
										
										
										
											2012-10-21 00:20:07 +00:00
										 |  |  |         BOOST_PP_SEQ_ELEM(1, product),                                      \ | 
					
						
							|  |  |  |         BOOST_PP_SEQ_ELEM(2, product)                                       \ | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |     )                                                                       \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UNORDERED_SCOPE(scope_name)                                         \
 | 
					
						
							|  |  |  |     for(::test::scope_guard unordered_test_guard(                           \ | 
					
						
							|  |  |  |             BOOST_STRINGIZE(scope_name));                                   \ | 
					
						
							|  |  |  |         !unordered_test_guard.dismissed();                                  \ | 
					
						
							|  |  |  |         unordered_test_guard.dismiss())                                     \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UNORDERED_EPOINT(name)                                              \
 | 
					
						
							|  |  |  |     if(::test::exceptions_enabled) {                                        \ | 
					
						
							|  |  |  |         UNORDERED_EPOINT_IMPL(name);                                        \ | 
					
						
							|  |  |  |     }                                                                       \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ENABLE_EXCEPTIONS                                                   \
 | 
					
						
							|  |  |  |     ::test::exceptions_enable BOOST_PP_CAT(                                 \ | 
					
						
							|  |  |  |         ENABLE_EXCEPTIONS_, __LINE__)(true)                                 \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DISABLE_EXCEPTIONS                                                  \
 | 
					
						
							|  |  |  |     ::test::exceptions_enable BOOST_PP_CAT(                                 \ | 
					
						
							|  |  |  |         ENABLE_EXCEPTIONS_, __LINE__)(false)                                \ | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace test { | 
					
						
							|  |  |  |     static char const* scope = ""; | 
					
						
							|  |  |  |     bool exceptions_enabled = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class scope_guard { | 
					
						
							|  |  |  |         scope_guard& operator=(scope_guard const&); | 
					
						
							|  |  |  |         scope_guard(scope_guard const&); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         char const* old_scope_; | 
					
						
							|  |  |  |         char const* scope_; | 
					
						
							|  |  |  |         bool dismissed_; | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         scope_guard(char const* name) | 
					
						
							|  |  |  |             : old_scope_(scope), | 
					
						
							|  |  |  |             scope_(name), | 
					
						
							|  |  |  |             dismissed_(false) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             scope = scope_; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ~scope_guard() { | 
					
						
							|  |  |  |             if(dismissed_) scope = old_scope_; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         void dismiss() { | 
					
						
							|  |  |  |             dismissed_ = true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         bool dismissed() const { | 
					
						
							|  |  |  |             return dismissed_; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class exceptions_enable | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         exceptions_enable& operator=(exceptions_enable const&); | 
					
						
							|  |  |  |         exceptions_enable(exceptions_enable const&); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         bool old_value_; | 
					
						
							|  |  |  |     public: | 
					
						
							|  |  |  |         exceptions_enable(bool enable) | 
					
						
							|  |  |  |             : old_value_(exceptions_enabled) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             exceptions_enabled = enable; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ~exceptions_enable() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             exceptions_enabled = old_value_; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct exception_base { | 
					
						
							|  |  |  |         struct data_type {}; | 
					
						
							|  |  |  |         struct strong_type { | 
					
						
							|  |  |  |             template <class T> void store(T const&) {} | 
					
						
							|  |  |  |             template <class T> void test(T const&) const {} | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         data_type init() const { return data_type(); } | 
					
						
							| 
									
										
										
										
											2009-11-21 19:40:28 +00:00
										 |  |  |         void check BOOST_PREVENT_MACRO_SUBSTITUTION() const {} | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <class T, class P1, class P2, class T2> | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |     inline void call_ignore_extra_parameters( | 
					
						
							|  |  |  |             void (T::*fn)() const, T2 const& obj, | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |             P1&, P2&) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         (obj.*fn)(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <class T, class P1, class P2, class T2> | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |     inline void call_ignore_extra_parameters( | 
					
						
							|  |  |  |             void (T::*fn)(P1&) const, T2 const& obj, | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |             P1& p1, P2&) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         (obj.*fn)(p1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <class T, class P1, class P2, class T2> | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |     inline void call_ignore_extra_parameters( | 
					
						
							|  |  |  |             void (T::*fn)(P1&, P2&) const, T2 const& obj, | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |             P1& p1, P2& p2) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         (obj.*fn)(p1, p2); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <class T> | 
					
						
							|  |  |  |     T const& constant(T const& x) { | 
					
						
							|  |  |  |         return x; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <class Test> | 
					
						
							|  |  |  |     class test_runner | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Test const& test_; | 
					
						
							| 
									
										
										
										
											2009-11-10 08:15:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         test_runner(test_runner const&); | 
					
						
							|  |  |  |         test_runner& operator=(test_runner const&); | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |     public: | 
					
						
							|  |  |  |         test_runner(Test const& t) : test_(t) {} | 
					
						
							|  |  |  |         void operator()() const { | 
					
						
							|  |  |  |             DISABLE_EXCEPTIONS; | 
					
						
							| 
									
										
											  
											
												Add the new allocator constructors, use composition instead of inheritance for the implementation and some small fixes.
Merged revisions 43922,43962,43966,43971,43981,43995-43996,44042,44046-44048,44057 via svnmerge from 
https://svn.boost.org/svn/boost/branches/unordered/trunk
........
  r43922 | danieljames | 2008-03-29 14:55:59 +0000 (Sat, 29 Mar 2008) | 1 line
  
  Fix some typos in the reference documentation.
........
  r43962 | danieljames | 2008-03-31 18:29:59 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Add a name variable to the release script, so that I can have different release names in different branches.
........
  r43966 | danieljames | 2008-03-31 18:43:16 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the image directory for standalone docs.
........
  r43971 | danieljames | 2008-03-31 19:17:25 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the unordered stylesheet.
........
  r43981 | danieljames | 2008-04-01 13:31:26 +0100 (Tue, 01 Apr 2008) | 2 lines
  
  Cast the pointer in the Visual C++ 6.5 _Charalloc method.
........
  r43995 | danieljames | 2008-04-02 12:50:27 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Try using the interprocess containers for testing. Compilation is a bit slower but hopefully I'll run into less cross-platform problems.
........
  r43996 | danieljames | 2008-04-02 13:25:49 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Revert my experiment with the interprocess containers. It didn't work out.
........
  r44042 | danieljames | 2008-04-04 20:38:09 +0100 (Fri, 04 Apr 2008) | 1 line
  
  Make hash table data a member of hash table, instead of a base.
........
  r44046 | danieljames | 2008-04-05 12:38:05 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Remove rvalue_ref from Jamfile.v2 - I didn't mean to check it in.
........
  r44047 | danieljames | 2008-04-05 12:39:38 +0100 (Sat, 05 Apr 2008) | 1 line
  
  New constructors with allocators.
........
  r44048 | danieljames | 2008-04-05 12:58:11 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Document the new constructors.
........
  r44057 | danieljames | 2008-04-05 17:08:23 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Fix some bugs in the exception testing code.
........
[SVN r44417]
											
										 
											2008-04-14 15:10:26 +00:00
										 |  |  |             test::scope = ""; | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |             BOOST_DEDUCED_TYPENAME Test::data_type x(test_.init()); | 
					
						
							|  |  |  |             BOOST_DEDUCED_TYPENAME Test::strong_type strong; | 
					
						
							|  |  |  |             strong.store(x); | 
					
						
							|  |  |  |             try { | 
					
						
							|  |  |  |                 ENABLE_EXCEPTIONS; | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |                 call_ignore_extra_parameters< | 
					
						
							|  |  |  |                     Test, | 
					
						
							|  |  |  |                     BOOST_DEDUCED_TYPENAME Test::data_type, | 
					
						
							|  |  |  |                     BOOST_DEDUCED_TYPENAME Test::strong_type | 
					
						
							|  |  |  |                 >(&Test::run, test_, x, strong); | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |             catch(...) { | 
					
						
							| 
									
										
										
										
											2010-01-04 22:49:39 +00:00
										 |  |  |                 call_ignore_extra_parameters< | 
					
						
							|  |  |  |                     Test, | 
					
						
							|  |  |  |                     BOOST_DEDUCED_TYPENAME Test::data_type const, | 
					
						
							|  |  |  |                     BOOST_DEDUCED_TYPENAME Test::strong_type const | 
					
						
							|  |  |  |                 >(&Test::check, test_, constant(x), constant(strong)); | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |                 throw; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Quick exception testing based on lightweight test
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     namespace lightweight { | 
					
						
							|  |  |  |         static int iteration; | 
					
						
							|  |  |  |         static int count; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         struct test_exception { | 
					
						
							|  |  |  |             char const* name; | 
					
						
							|  |  |  |             test_exception(char const* n) : name(n) {} | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         struct test_failure { | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         void epoint(char const* name) { | 
					
						
							|  |  |  |             ++count; | 
					
						
							|  |  |  |             if(count == iteration) { | 
					
						
							|  |  |  |                 throw test_exception(name); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         template <class Test> | 
					
						
							| 
									
										
											  
											
												Merge test improvements, pdf documentation improvements, some implementation
tweaks.
Merged revisions 45747-46030 via svnmerge from 
https://svn.boost.org/svn/boost/branches/unordered/trunk
................
  r45747 | danieljames | 2008-05-25 18:03:30 +0100 (Sun, 25 May 2008) | 1 line
  
  Remove /branches/unordered/dev from svnmerge tracking.
................
  r45874 | danieljames | 2008-05-28 18:54:53 +0100 (Wed, 28 May 2008) | 1 line
  
  Merge from trunk.
................
  r45881 | danieljames | 2008-05-29 00:10:37 +0100 (Thu, 29 May 2008) | 2 lines
  
  Make it possible to use a custom generator in more places.
................
  r45882 | danieljames | 2008-05-29 00:10:56 +0100 (Thu, 29 May 2008) | 2 lines
  
  Remove several unused parameters.
................
  r45883 | danieljames | 2008-05-29 00:11:06 +0100 (Thu, 29 May 2008) | 2 lines
  
  No need to run move_construct_tests1 from move_construct_tests2, already calling it directly.
................
  r45884 | danieljames | 2008-05-29 00:11:15 +0100 (Thu, 29 May 2008) | 2 lines
  
  Remove unused 'construct' as in trunk.
................
  r45885 | danieljames | 2008-05-29 00:11:25 +0100 (Thu, 29 May 2008) | 2 lines
  
  More consistent implementations of insert_impl.
................
  r45886 | danieljames | 2008-05-29 00:11:34 +0100 (Thu, 29 May 2008) | 2 lines
  
  No need to use the single argument version of methods when the variadic version is available. Frees up the non-variadic version for overloading to emulate variadic methods.
................
  r45887 | danieljames | 2008-05-29 00:11:44 +0100 (Thu, 29 May 2008) | 2 lines
  
  Add another test, mainly to avoid an unused parameter warning.
................
  r45888 | danieljames | 2008-05-29 00:11:54 +0100 (Thu, 29 May 2008) | 2 lines
  
  Adjust the pixels per inch of the buckets diagram so it'll fit on the page.
................
  r45889 | danieljames | 2008-05-29 00:15:49 +0100 (Thu, 29 May 2008) | 1 line
  
  Improve pdf output, thanks to John Maddock.
................
  r45890 | danieljames | 2008-05-29 00:17:45 +0100 (Thu, 29 May 2008) | 1 line
  
  Add an svg version of the bucket diagram.
................
  r45891 | danieljames | 2008-05-29 00:18:11 +0100 (Thu, 29 May 2008) | 1 line
  
  Remove the original dia buckets diagram, I'm not using it anymore.
................
  r46025 | danieljames | 2008-06-01 18:39:51 +0100 (Sun, 01 Jun 2008) | 1 line
  
  Initialise merging from doc.
................
  r46030 | danieljames | 2008-06-01 18:54:36 +0100 (Sun, 01 Jun 2008) | 29 lines
  
  Merge in documentation improvements from the doc branch.
  
  Merged revisions 45892-46020 via svnmerge from 
  https://svn.boost.org/svn/boost/branches/doc
  
  ........
    r45892 | danieljames | 2008-05-29 00:30:07 +0100 (Thu, 29 May 2008) | 1 line
    
    Merge latest changes from unordered.
  ........
    r46017 | danieljames | 2008-06-01 18:18:15 +0100 (Sun, 01 Jun 2008) | 2 lines
    
    Use both PNG and SVG versions of the buckets diagram.
  ........
    r46018 | danieljames | 2008-06-01 18:18:27 +0100 (Sun, 01 Jun 2008) | 2 lines
    
    Improved function summary tables in unordered documenations.
  ........
    r46019 | danieljames | 2008-06-01 18:18:39 +0100 (Sun, 01 Jun 2008) | 3 lines
    
    I'd hacked the bibliography to avoid showing the title twice, but this was
    causing problems when generating PDFs, so show the title twice.
  ........
    r46020 | danieljames | 2008-06-01 18:18:52 +0100 (Sun, 01 Jun 2008) | 3 lines
    
    Don't use the compact boostbook refernce style in the standalone documentation
    as it is too wide for printing out.
  ........
................
[SVN r46031]
											
										 
											2008-06-01 18:00:53 +00:00
										 |  |  |         void exception_safety(Test const& f, char const* /*name*/) { | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |             test_runner<Test> runner(f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             iteration = 0; | 
					
						
							|  |  |  |             bool success = false; | 
					
						
							|  |  |  |             do { | 
					
						
							|  |  |  |                 ++iteration; | 
					
						
							|  |  |  |                 count = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 try { | 
					
						
							|  |  |  |                     runner(); | 
					
						
							|  |  |  |                     success = true; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 catch(test_failure) { | 
					
						
							| 
									
										
											  
											
												Add the new allocator constructors, use composition instead of inheritance for the implementation and some small fixes.
Merged revisions 43922,43962,43966,43971,43981,43995-43996,44042,44046-44048,44057 via svnmerge from 
https://svn.boost.org/svn/boost/branches/unordered/trunk
........
  r43922 | danieljames | 2008-03-29 14:55:59 +0000 (Sat, 29 Mar 2008) | 1 line
  
  Fix some typos in the reference documentation.
........
  r43962 | danieljames | 2008-03-31 18:29:59 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Add a name variable to the release script, so that I can have different release names in different branches.
........
  r43966 | danieljames | 2008-03-31 18:43:16 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the image directory for standalone docs.
........
  r43971 | danieljames | 2008-03-31 19:17:25 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the unordered stylesheet.
........
  r43981 | danieljames | 2008-04-01 13:31:26 +0100 (Tue, 01 Apr 2008) | 2 lines
  
  Cast the pointer in the Visual C++ 6.5 _Charalloc method.
........
  r43995 | danieljames | 2008-04-02 12:50:27 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Try using the interprocess containers for testing. Compilation is a bit slower but hopefully I'll run into less cross-platform problems.
........
  r43996 | danieljames | 2008-04-02 13:25:49 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Revert my experiment with the interprocess containers. It didn't work out.
........
  r44042 | danieljames | 2008-04-04 20:38:09 +0100 (Fri, 04 Apr 2008) | 1 line
  
  Make hash table data a member of hash table, instead of a base.
........
  r44046 | danieljames | 2008-04-05 12:38:05 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Remove rvalue_ref from Jamfile.v2 - I didn't mean to check it in.
........
  r44047 | danieljames | 2008-04-05 12:39:38 +0100 (Sat, 05 Apr 2008) | 1 line
  
  New constructors with allocators.
........
  r44048 | danieljames | 2008-04-05 12:58:11 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Document the new constructors.
........
  r44057 | danieljames | 2008-04-05 17:08:23 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Fix some bugs in the exception testing code.
........
[SVN r44417]
											
										 
											2008-04-14 15:10:26 +00:00
										 |  |  |                     BOOST_ERROR("test_failure caught."); | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |                     break; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
											  
											
												Add the new allocator constructors, use composition instead of inheritance for the implementation and some small fixes.
Merged revisions 43922,43962,43966,43971,43981,43995-43996,44042,44046-44048,44057 via svnmerge from 
https://svn.boost.org/svn/boost/branches/unordered/trunk
........
  r43922 | danieljames | 2008-03-29 14:55:59 +0000 (Sat, 29 Mar 2008) | 1 line
  
  Fix some typos in the reference documentation.
........
  r43962 | danieljames | 2008-03-31 18:29:59 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Add a name variable to the release script, so that I can have different release names in different branches.
........
  r43966 | danieljames | 2008-03-31 18:43:16 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the image directory for standalone docs.
........
  r43971 | danieljames | 2008-03-31 19:17:25 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the unordered stylesheet.
........
  r43981 | danieljames | 2008-04-01 13:31:26 +0100 (Tue, 01 Apr 2008) | 2 lines
  
  Cast the pointer in the Visual C++ 6.5 _Charalloc method.
........
  r43995 | danieljames | 2008-04-02 12:50:27 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Try using the interprocess containers for testing. Compilation is a bit slower but hopefully I'll run into less cross-platform problems.
........
  r43996 | danieljames | 2008-04-02 13:25:49 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Revert my experiment with the interprocess containers. It didn't work out.
........
  r44042 | danieljames | 2008-04-04 20:38:09 +0100 (Fri, 04 Apr 2008) | 1 line
  
  Make hash table data a member of hash table, instead of a base.
........
  r44046 | danieljames | 2008-04-05 12:38:05 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Remove rvalue_ref from Jamfile.v2 - I didn't mean to check it in.
........
  r44047 | danieljames | 2008-04-05 12:39:38 +0100 (Sat, 05 Apr 2008) | 1 line
  
  New constructors with allocators.
........
  r44048 | danieljames | 2008-04-05 12:58:11 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Document the new constructors.
........
  r44057 | danieljames | 2008-04-05 17:08:23 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Fix some bugs in the exception testing code.
........
[SVN r44417]
											
										 
											2008-04-14 15:10:26 +00:00
										 |  |  |                 catch(test_exception) { | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |                 catch(...) { | 
					
						
							| 
									
										
											  
											
												Add the new allocator constructors, use composition instead of inheritance for the implementation and some small fixes.
Merged revisions 43922,43962,43966,43971,43981,43995-43996,44042,44046-44048,44057 via svnmerge from 
https://svn.boost.org/svn/boost/branches/unordered/trunk
........
  r43922 | danieljames | 2008-03-29 14:55:59 +0000 (Sat, 29 Mar 2008) | 1 line
  
  Fix some typos in the reference documentation.
........
  r43962 | danieljames | 2008-03-31 18:29:59 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Add a name variable to the release script, so that I can have different release names in different branches.
........
  r43966 | danieljames | 2008-03-31 18:43:16 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the image directory for standalone docs.
........
  r43971 | danieljames | 2008-03-31 19:17:25 +0100 (Mon, 31 Mar 2008) | 1 line
  
  Fix the unordered stylesheet.
........
  r43981 | danieljames | 2008-04-01 13:31:26 +0100 (Tue, 01 Apr 2008) | 2 lines
  
  Cast the pointer in the Visual C++ 6.5 _Charalloc method.
........
  r43995 | danieljames | 2008-04-02 12:50:27 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Try using the interprocess containers for testing. Compilation is a bit slower but hopefully I'll run into less cross-platform problems.
........
  r43996 | danieljames | 2008-04-02 13:25:49 +0100 (Wed, 02 Apr 2008) | 1 line
  
  Revert my experiment with the interprocess containers. It didn't work out.
........
  r44042 | danieljames | 2008-04-04 20:38:09 +0100 (Fri, 04 Apr 2008) | 1 line
  
  Make hash table data a member of hash table, instead of a base.
........
  r44046 | danieljames | 2008-04-05 12:38:05 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Remove rvalue_ref from Jamfile.v2 - I didn't mean to check it in.
........
  r44047 | danieljames | 2008-04-05 12:39:38 +0100 (Sat, 05 Apr 2008) | 1 line
  
  New constructors with allocators.
........
  r44048 | danieljames | 2008-04-05 12:58:11 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Document the new constructors.
........
  r44057 | danieljames | 2008-04-05 17:08:23 +0100 (Sat, 05 Apr 2008) | 1 line
  
  Fix some bugs in the exception testing code.
........
[SVN r44417]
											
										 
											2008-04-14 15:10:26 +00:00
										 |  |  |                     BOOST_ERROR("Unexpected exception."); | 
					
						
							|  |  |  |                     break; | 
					
						
							| 
									
										
										
										
											2008-01-13 16:19:26 +00:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } while(!success); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |