mirror of
				https://github.com/boostorg/utility.git
				synced 2025-10-25 06:21:53 +02:00 
			
		
		
		
	Compare commits
	
		
			24 Commits
		
	
	
		
			boost-1.40
			...
			svn-branch
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 6af8e5d5f9 | ||
|  | 561a94c8c6 | ||
|  | 9ddcf04abc | ||
|  | b08a86f069 | ||
|  | 3f72b10182 | ||
|  | 71cb8cb574 | ||
|  | c950825ef4 | ||
|  | 66ca84a45d | ||
|  | 06404f7d39 | ||
|  | 2d860e2574 | ||
|  | 66514f61ff | ||
|  | 63cde4d3fd | ||
|  | 1950f292df | ||
|  | 92a0602190 | ||
|  | c9a3ab1d04 | ||
|  | 0782034333 | ||
|  | 0808883f3c | ||
|  | 2f69501e55 | ||
|  | 5b83f641a8 | ||
|  | c730ab4ffb | ||
|  | e55610a0d0 | ||
|  | bf968794c9 | ||
|  | ce6e9c6698 | ||
|  | 7ac180ed54 | 
| @@ -85,7 +85,7 @@ | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
|  | ||||
|   <p>Revised  | ||||
|   | ||||
| @@ -1,37 +0,0 @@ | ||||
| # | ||||
| # Copyright Troy D. Straszheim | ||||
| # | ||||
| # Distributed under the Boost Software License, Version 1.0. | ||||
| # See http://www.boost.org/LICENSE_1_0.txt | ||||
| # | ||||
| #---------------------------------------------------------------------------- | ||||
| # This file was automatically generated from the original CMakeLists.txt file | ||||
| # Add a variable to hold the headers for the library | ||||
| set (lib_headers | ||||
|     assert.hpp | ||||
|     call_traits.hpp | ||||
|     checked_delete.hpp | ||||
|     compressed_pair.hpp | ||||
|     current_function.hpp | ||||
|     operators.hpp | ||||
|     throw_exception.hpp | ||||
|     utility.hpp | ||||
|     utility | ||||
| ) | ||||
|  | ||||
| # Add a library target to the build system | ||||
| boost_library_project( | ||||
|   utility | ||||
|   #  SRCDIRS  | ||||
|   TESTDIRS  test swap/test enable_if/test | ||||
|   HEADERS ${lib_headers} | ||||
|   #  DOCDIRS  | ||||
|   DESCRIPTION  "Various small utilities for C++ programming." | ||||
|   MODULARIZED  | ||||
|   AUTHORS  "David Abrahams <dave -at- boostpro.com>" | ||||
|            "Brad King" | ||||
|            "Douglas Gregor <doug.gregor -at- gmail.com>" | ||||
|   #  MAINTAINERS  | ||||
| ) | ||||
|  | ||||
|  | ||||
| @@ -509,7 +509,7 @@ Returns the largest size that this Collection can ever have. <A href="#8">[8]</A | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
|  | ||||
|   <p>Revised  | ||||
|   | ||||
| @@ -160,7 +160,7 @@ t.~T() | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
|  | ||||
|   <p>Revised  | ||||
|   | ||||
| @@ -185,7 +185,7 @@ | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
|  | ||||
|   <p>Revised  | ||||
|   | ||||
| @@ -70,7 +70,7 @@ | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
|  | ||||
|   <p>Revised  | ||||
|   | ||||
| @@ -145,20 +145,14 @@ objects are is implemented in <a href="../../boost/utility/compare_pointees.hpp" | ||||
| so direct usage of relational operators with the implied aliasing of shallow semantics | ||||
| -as with pointers- should not be used with generic code written for this concept.</p> | ||||
|  | ||||
| <h3>Acknowledgements</h3> | ||||
| <p>Based on the original concept developed by Augustus Saunders. | ||||
|  | ||||
| <br> | ||||
| </p> | ||||
| <HR> | ||||
| <TABLE> | ||||
| <TR valign=top> | ||||
| <TD nowrap>Copyright © 2003</TD><TD> | ||||
| <A HREF="mailto:fernando_cacciola@hotmail.com">Fernando Cacciola</A> | ||||
| <A HREF="mailto:fernando_cacciola@hotmail.com">Fernando Cacciola</A>, | ||||
| based on the original concept developed by Augustus Saunders. | ||||
| </TD></TR></TABLE> | ||||
|  | ||||
| <p>Distributed under the Boost Software License, Version 1.0. See | ||||
| <a href="http://www.boost.org/LICENSE_1_0.txt">www.boost.org/LICENSE_1_0.txt</a></p> | ||||
|  | ||||
| </BODY> | ||||
| </HTML> | ||||
| @@ -1,76 +0,0 @@ | ||||
| #include <boost/config.hpp> | ||||
|  | ||||
| #if defined(BOOST_MSVC) | ||||
| #pragma warning(disable: 4786)  // identifier truncated in debug info | ||||
| #pragma warning(disable: 4710)  // function not inlined | ||||
| #pragma warning(disable: 4711)  // function selected for automatic inline expansion | ||||
| #pragma warning(disable: 4514)  // unreferenced inline removed | ||||
| #endif | ||||
|  | ||||
| //  addressof_fn_test.cpp: addressof( f ) | ||||
| // | ||||
| //  Copyright (c) 2008, 2009 Peter Dimov | ||||
| // | ||||
| //  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 | ||||
|  | ||||
| #include <boost/utility/addressof.hpp> | ||||
| #include <boost/detail/lightweight_test.hpp> | ||||
|  | ||||
|  | ||||
| void f0() | ||||
| { | ||||
| } | ||||
|  | ||||
| void f1(int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f2(int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f3(int, int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f4(int, int, int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f5(int, int, int, int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f6(int, int, int, int, int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f7(int, int, int, int, int, int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f8(int, int, int, int, int, int, int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| void f9(int, int, int, int, int, int, int, int, int) | ||||
| { | ||||
| } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     BOOST_TEST( boost::addressof( f0 ) == &f0 ); | ||||
|     BOOST_TEST( boost::addressof( f1 ) == &f1 ); | ||||
|     BOOST_TEST( boost::addressof( f2 ) == &f2 ); | ||||
|     BOOST_TEST( boost::addressof( f3 ) == &f3 ); | ||||
|     BOOST_TEST( boost::addressof( f4 ) == &f4 ); | ||||
|     BOOST_TEST( boost::addressof( f5 ) == &f5 ); | ||||
|     BOOST_TEST( boost::addressof( f6 ) == &f6 ); | ||||
|     BOOST_TEST( boost::addressof( f7 ) == &f7 ); | ||||
|     BOOST_TEST( boost::addressof( f8 ) == &f8 ); | ||||
|     BOOST_TEST( boost::addressof( f9 ) == &f9 ); | ||||
|  | ||||
|     return boost::report_errors(); | ||||
| } | ||||
| @@ -1,95 +0,0 @@ | ||||
| // Copyright (C) 2002 Brad King (brad.king@kitware.com)  | ||||
| //                    Douglas Gregor (gregod@cs.rpi.edu) | ||||
| // | ||||
| // Copyright 2009 Peter Dimov | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // For more information, see http://www.boost.org | ||||
|  | ||||
|  | ||||
| #include <boost/utility/addressof.hpp> | ||||
|  | ||||
| #if defined(BOOST_MSVC) && (BOOST_MSVC < 1300) | ||||
| #pragma warning(push, 3) | ||||
| #endif | ||||
|  | ||||
| #include <iostream> | ||||
|  | ||||
| #if defined(BOOST_MSVC) && (BOOST_MSVC < 1300) | ||||
| #pragma warning(pop) | ||||
| #endif | ||||
|  | ||||
| #include <boost/detail/lightweight_test.hpp> | ||||
|  | ||||
| template<class T> void scalar_test( T * = 0 ) | ||||
| { | ||||
|     T* px = new T(); | ||||
|  | ||||
|     T& x = *px; | ||||
|     BOOST_TEST( boost::addressof(x) == px ); | ||||
|  | ||||
|     const T& cx = *px; | ||||
|     const T* pcx = boost::addressof(cx); | ||||
|     BOOST_TEST( pcx == px ); | ||||
|  | ||||
|     volatile T& vx = *px; | ||||
|     volatile T* pvx = boost::addressof(vx); | ||||
|     BOOST_TEST( pvx == px ); | ||||
|  | ||||
|     const volatile T& cvx = *px; | ||||
|     const volatile T* pcvx = boost::addressof(cvx); | ||||
|     BOOST_TEST( pcvx == px ); | ||||
|  | ||||
|     delete px; | ||||
| } | ||||
|  | ||||
| template<class T> void array_test( T * = 0 ) | ||||
| { | ||||
|     T nrg[3] = {1,2,3}; | ||||
|     T (*pnrg)[3] = &nrg; | ||||
|     BOOST_TEST( boost::addressof(nrg) == pnrg ); | ||||
|  | ||||
|     T const cnrg[3] = {1,2,3}; | ||||
|     T const (*pcnrg)[3] = &cnrg; | ||||
|     BOOST_TEST( boost::addressof(cnrg) == pcnrg ); | ||||
| } | ||||
|  | ||||
| class convertible { | ||||
| public: | ||||
|  | ||||
|     convertible( int = 0 ) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     template<class U> operator U () const | ||||
|     { | ||||
|         return U(); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| class convertible2 { | ||||
| public: | ||||
|  | ||||
|     convertible2( int = 0 ) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     operator convertible2* () const | ||||
|     { | ||||
|         return 0; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     scalar_test<convertible>(); | ||||
|     scalar_test<convertible2>(); | ||||
|  | ||||
|     array_test<convertible>(); | ||||
|     array_test<convertible2>(); | ||||
|  | ||||
|     return boost::report_errors(); | ||||
| } | ||||
							
								
								
									
										12
									
								
								assert.html
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								assert.html
									
									
									
									
									
								
							| @@ -47,15 +47,9 @@ void assertion_failed(char const * expr, char const * function, char const * fil | ||||
| 		<P>As is the case with <STRONG><cassert></STRONG>, <STRONG><boost/assert.hpp></STRONG> | ||||
| 			can be included multiple times in a single translation unit. <STRONG>BOOST_ASSERT</STRONG> | ||||
| 			will be redefined each time as specified above.</P> | ||||
| 		<p><STRONG><boost/assert.hpp></STRONG> also defines the macro <STRONG>BOOST_VERIFY</STRONG>.  | ||||
| 			It has exactly the same behavior as <STRONG>BOOST_ASSERT</STRONG>, except that  | ||||
| 			the expression that is passed to <STRONG>BOOST_VERIFY</STRONG> is always  | ||||
| 			evaluated. This is useful when the asserted expression has desirable side  | ||||
| 			effects; it can also help suppress warnings about unused variables when the  | ||||
| 			only use of the variable is inside an assertion.</p> | ||||
| 		<p><br> | ||||
| 			<small>Copyright <20> 2002, 2007 by Peter Dimov. Distributed under the Boost Software  | ||||
| 				License, Version 1.0. See accompanying file <A href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</A> | ||||
| 				or copy at <A href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</A>.</small></p> | ||||
| 			<small>Copyright <20> 2002 by Peter Dimov. Distributed under the Boost Software License, Version  | ||||
| 				1.0. See accompanying file <A href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</A> or  | ||||
| 				copy at <A href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</A>.</small></p> | ||||
| 	</body> | ||||
| </html> | ||||
|   | ||||
| @@ -334,7 +334,7 @@ with the exact pointer type used in <code>switcher</code>'s constructor.</p> | ||||
| <h3><a name="contributors">Contributors</a></h3> | ||||
|  | ||||
| <dl> | ||||
| 	<dt><a href="http://www.boost.org/people/ed_brey.htm">Ed Brey</a> | ||||
| 	<dt><a href="../../people/ed_brey.htm">Ed Brey</a> | ||||
| 	<dd>Suggested some interface changes. | ||||
|  | ||||
| 	<dt><a href="http://www.moocat.org">R. Samuel Klatchko</a> (<a | ||||
| @@ -343,7 +343,7 @@ with the exact pointer type used in <code>switcher</code>'s constructor.</p> | ||||
| 	<dd>Invented the idiom of how to use a class member for initializing | ||||
| 		a base class. | ||||
|  | ||||
| 	<dt><a href="http://www.boost.org/people/dietmar_kuehl.htm">Dietmar Kuehl</a> | ||||
| 	<dt><a href="../../people/dietmar_kuehl.htm">Dietmar Kuehl</a> | ||||
| 	<dd>Popularized the base-from-member idiom in his | ||||
| 		<a href="http://www.informatik.uni-konstanz.de/~kuehl/c++/iostream/">IOStream | ||||
| 		example classes</a>. | ||||
| @@ -353,7 +353,7 @@ with the exact pointer type used in <code>switcher</code>'s constructor.</p> | ||||
| 		can be controlled and automated with macros.  The implementation uses | ||||
| 		the <a href="../preprocessor/index.html">Preprocessor library</a>. | ||||
|  | ||||
| 	<dt><a href="http://www.boost.org/people/daryle_walker.html">Daryle Walker</a> | ||||
| 	<dt><a href="../../people/daryle_walker.html">Daryle Walker</a> | ||||
| 	<dd>Started the library.  Contributed the test file <cite><a | ||||
| 		href="base_from_member_test.cpp">base_from_member_test.cpp</a></cite>. | ||||
| </dl> | ||||
|   | ||||
							
								
								
									
										643
									
								
								binary_test.cpp
									
									
									
									
									
								
							
							
						
						
									
										643
									
								
								binary_test.cpp
									
									
									
									
									
								
							| @@ -1,643 +0,0 @@ | ||||
| /*============================================================================= | ||||
|     Copyright (c) 2006, 2007 Matthew Calabrese | ||||
|  | ||||
|     Use, modification and distribution is subject to 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) | ||||
| ==============================================================================*/ | ||||
|  | ||||
| #include <boost/test/minimal.hpp> | ||||
| #include <boost/utility/binary.hpp> | ||||
| #include <algorithm> | ||||
| #include <cstddef> | ||||
|  | ||||
| /* | ||||
| Note: This file tests every single valid bit-grouping on its own, and some | ||||
|       random combinations of bit-groupings. | ||||
| */ | ||||
|  | ||||
| std::size_t const num_random_test_values = 32; | ||||
|  | ||||
| // Note: These hex values should all correspond with the binary array below | ||||
| unsigned int const random_unsigned_ints_hex[num_random_test_values] | ||||
|   = { 0x0103u, 0x77ebu, 0x5f36u, 0x1f18u, 0xc530u, 0xa73au, 0xd6f8u, 0x0919u | ||||
|     , 0xfbb0u, 0x3e7cu, 0xd0e9u, 0x22c8u, 0x724eu, 0x14fau, 0xd98eu, 0x40b5 | ||||
|     , 0xeba0u, 0xfe50u, 0x688au, 0x1b05u, 0x5f9cu, 0xe4fcu, 0xa7b8u, 0xd3acu | ||||
|     , 0x1dddu, 0xbf04u, 0x8352u, 0xe89cu, 0x7506u, 0xe767u, 0xf489u, 0xe167 | ||||
|     }; | ||||
|  | ||||
| unsigned int const random_unsigned_ints_binary[num_random_test_values] | ||||
|   = { BOOST_BINARY( 0 00010000 0011 ), BOOST_BINARY( 0 11101 1111  101011 ) | ||||
|     , BOOST_BINARY( 010111 1100110 1 1 0 ), BOOST_BINARY( 000 1 11110 00 11000 ) | ||||
|     , BOOST_BINARY( 110 001010 0110 000 ), BOOST_BINARY( 1010 01110011 1010 ) | ||||
|     , BOOST_BINARY( 11 010 1 101111 1000 ), BOOST_BINARY( 0000 100100 0110 01 ) | ||||
|     , BOOST_BINARY( 1111 101110 11 0000 ), BOOST_BINARY( 00111110 01111100 ) | ||||
|     , BOOST_BINARY( 11  010 000111 01001 ), BOOST_BINARY( 00100 010110   01000 ) | ||||
|     , BOOST_BINARY( 01 11001001 001110 ), BOOST_BINARY( 0010 1001111 1010 ) | ||||
|     , BOOST_BINARY( 1101 1 00110 0 01110 ), BOOST_BINARY( 100 000 01011010 1 ) | ||||
|     , BOOST_BINARY( 11 1010 1110 1000 00 ), BOOST_BINARY( 11111 110010 10000 ) | ||||
|     , BOOST_BINARY( 01101 00010 001010 ), BOOST_BINARY( 000 11011 000001 01 ) | ||||
|     , BOOST_BINARY( 01 01111 1100111 00 ), BOOST_BINARY( 1 110010 0111111 00 ) | ||||
|     , BOOST_BINARY( 101 0011 11 01110 00 ), BOOST_BINARY( 110100 1 110101 100 ) | ||||
|     , BOOST_BINARY( 00 1110111 011 101 ), BOOST_BINARY( 1011 1111 00000 100 ) | ||||
|     , BOOST_BINARY( 1000 00110 101 0010 ), BOOST_BINARY( 1110  10001 001110 0 ) | ||||
|     , BOOST_BINARY( 011 1010100 000 110 ), BOOST_BINARY( 1110 0111 01100 111 ) | ||||
|     , BOOST_BINARY( 11110 10010 001001 ), BOOST_BINARY( 11 1000010 1100 111 ) | ||||
|     }; | ||||
|  | ||||
| unsigned int const unsigned_ints_1_bit[2] = | ||||
| { BOOST_BINARY( 0 ) | ||||
| , BOOST_BINARY( 1 ) | ||||
| }; | ||||
|  | ||||
| unsigned int const unsigned_ints_2_bits[4] = | ||||
| { BOOST_BINARY( 00 ) | ||||
| , BOOST_BINARY( 01 ) | ||||
| , BOOST_BINARY( 10 ) | ||||
| , BOOST_BINARY( 11 ) | ||||
| }; | ||||
|  | ||||
| unsigned int const unsigned_ints_3_bits[8] = | ||||
| { BOOST_BINARY( 000 ) | ||||
| , BOOST_BINARY( 001 ) | ||||
| , BOOST_BINARY( 010 ) | ||||
| , BOOST_BINARY( 011 ) | ||||
| , BOOST_BINARY( 100 ) | ||||
| , BOOST_BINARY( 101 ) | ||||
| , BOOST_BINARY( 110 ) | ||||
| , BOOST_BINARY( 111 ) | ||||
| }; | ||||
|  | ||||
| unsigned int const unsigned_ints_4_bits[16] = | ||||
| { BOOST_BINARY( 0000 ) | ||||
| , BOOST_BINARY( 0001 ) | ||||
| , BOOST_BINARY( 0010 ) | ||||
| , BOOST_BINARY( 0011 ) | ||||
| , BOOST_BINARY( 0100 ) | ||||
| , BOOST_BINARY( 0101 ) | ||||
| , BOOST_BINARY( 0110 ) | ||||
| , BOOST_BINARY( 0111 ) | ||||
| , BOOST_BINARY( 1000 ) | ||||
| , BOOST_BINARY( 1001 ) | ||||
| , BOOST_BINARY( 1010 ) | ||||
| , BOOST_BINARY( 1011 ) | ||||
| , BOOST_BINARY( 1100 ) | ||||
| , BOOST_BINARY( 1101 ) | ||||
| , BOOST_BINARY( 1110 ) | ||||
| , BOOST_BINARY( 1111 ) | ||||
| }; | ||||
|  | ||||
| unsigned int const unsigned_ints_5_bits[32] = | ||||
| { BOOST_BINARY( 00000 ) | ||||
| , BOOST_BINARY( 00001 ) | ||||
| , BOOST_BINARY( 00010 ) | ||||
| , BOOST_BINARY( 00011 ) | ||||
| , BOOST_BINARY( 00100 ) | ||||
| , BOOST_BINARY( 00101 ) | ||||
| , BOOST_BINARY( 00110 ) | ||||
| , BOOST_BINARY( 00111 ) | ||||
| , BOOST_BINARY( 01000 ) | ||||
| , BOOST_BINARY( 01001 ) | ||||
| , BOOST_BINARY( 01010 ) | ||||
| , BOOST_BINARY( 01011 ) | ||||
| , BOOST_BINARY( 01100 ) | ||||
| , BOOST_BINARY( 01101 ) | ||||
| , BOOST_BINARY( 01110 ) | ||||
| , BOOST_BINARY( 01111 ) | ||||
| , BOOST_BINARY( 10000 ) | ||||
| , BOOST_BINARY( 10001 ) | ||||
| , BOOST_BINARY( 10010 ) | ||||
| , BOOST_BINARY( 10011 ) | ||||
| , BOOST_BINARY( 10100 ) | ||||
| , BOOST_BINARY( 10101 ) | ||||
| , BOOST_BINARY( 10110 ) | ||||
| , BOOST_BINARY( 10111 ) | ||||
| , BOOST_BINARY( 11000 ) | ||||
| , BOOST_BINARY( 11001 ) | ||||
| , BOOST_BINARY( 11010 ) | ||||
| , BOOST_BINARY( 11011 ) | ||||
| , BOOST_BINARY( 11100 ) | ||||
| , BOOST_BINARY( 11101 ) | ||||
| , BOOST_BINARY( 11110 ) | ||||
| , BOOST_BINARY( 11111 ) | ||||
| }; | ||||
|  | ||||
| unsigned int const unsigned_ints_6_bits[64] = | ||||
| { BOOST_BINARY( 000000 ) | ||||
| , BOOST_BINARY( 000001 ) | ||||
| , BOOST_BINARY( 000010 ) | ||||
| , BOOST_BINARY( 000011 ) | ||||
| , BOOST_BINARY( 000100 ) | ||||
| , BOOST_BINARY( 000101 ) | ||||
| , BOOST_BINARY( 000110 ) | ||||
| , BOOST_BINARY( 000111 ) | ||||
| , BOOST_BINARY( 001000 ) | ||||
| , BOOST_BINARY( 001001 ) | ||||
| , BOOST_BINARY( 001010 ) | ||||
| , BOOST_BINARY( 001011 ) | ||||
| , BOOST_BINARY( 001100 ) | ||||
| , BOOST_BINARY( 001101 ) | ||||
| , BOOST_BINARY( 001110 ) | ||||
| , BOOST_BINARY( 001111 ) | ||||
| , BOOST_BINARY( 010000 ) | ||||
| , BOOST_BINARY( 010001 ) | ||||
| , BOOST_BINARY( 010010 ) | ||||
| , BOOST_BINARY( 010011 ) | ||||
| , BOOST_BINARY( 010100 ) | ||||
| , BOOST_BINARY( 010101 ) | ||||
| , BOOST_BINARY( 010110 ) | ||||
| , BOOST_BINARY( 010111 ) | ||||
| , BOOST_BINARY( 011000 ) | ||||
| , BOOST_BINARY( 011001 ) | ||||
| , BOOST_BINARY( 011010 ) | ||||
| , BOOST_BINARY( 011011 ) | ||||
| , BOOST_BINARY( 011100 ) | ||||
| , BOOST_BINARY( 011101 ) | ||||
| , BOOST_BINARY( 011110 ) | ||||
| , BOOST_BINARY( 011111 ) | ||||
| , BOOST_BINARY( 100000 ) | ||||
| , BOOST_BINARY( 100001 ) | ||||
| , BOOST_BINARY( 100010 ) | ||||
| , BOOST_BINARY( 100011 ) | ||||
| , BOOST_BINARY( 100100 ) | ||||
| , BOOST_BINARY( 100101 ) | ||||
| , BOOST_BINARY( 100110 ) | ||||
| , BOOST_BINARY( 100111 ) | ||||
| , BOOST_BINARY( 101000 ) | ||||
| , BOOST_BINARY( 101001 ) | ||||
| , BOOST_BINARY( 101010 ) | ||||
| , BOOST_BINARY( 101011 ) | ||||
| , BOOST_BINARY( 101100 ) | ||||
| , BOOST_BINARY( 101101 ) | ||||
| , BOOST_BINARY( 101110 ) | ||||
| , BOOST_BINARY( 101111 ) | ||||
| , BOOST_BINARY( 110000 ) | ||||
| , BOOST_BINARY( 110001 ) | ||||
| , BOOST_BINARY( 110010 ) | ||||
| , BOOST_BINARY( 110011 ) | ||||
| , BOOST_BINARY( 110100 ) | ||||
| , BOOST_BINARY( 110101 ) | ||||
| , BOOST_BINARY( 110110 ) | ||||
| , BOOST_BINARY( 110111 ) | ||||
| , BOOST_BINARY( 111000 ) | ||||
| , BOOST_BINARY( 111001 ) | ||||
| , BOOST_BINARY( 111010 ) | ||||
| , BOOST_BINARY( 111011 ) | ||||
| , BOOST_BINARY( 111100 ) | ||||
| , BOOST_BINARY( 111101 ) | ||||
| , BOOST_BINARY( 111110 ) | ||||
| , BOOST_BINARY( 111111 ) | ||||
| }; | ||||
|  | ||||
| unsigned int const unsigned_ints_7_bits[128] = | ||||
| { BOOST_BINARY( 0000000 ) | ||||
| , BOOST_BINARY( 0000001 ) | ||||
| , BOOST_BINARY( 0000010 ) | ||||
| , BOOST_BINARY( 0000011 ) | ||||
| , BOOST_BINARY( 0000100 ) | ||||
| , BOOST_BINARY( 0000101 ) | ||||
| , BOOST_BINARY( 0000110 ) | ||||
| , BOOST_BINARY( 0000111 ) | ||||
| , BOOST_BINARY( 0001000 ) | ||||
| , BOOST_BINARY( 0001001 ) | ||||
| , BOOST_BINARY( 0001010 ) | ||||
| , BOOST_BINARY( 0001011 ) | ||||
| , BOOST_BINARY( 0001100 ) | ||||
| , BOOST_BINARY( 0001101 ) | ||||
| , BOOST_BINARY( 0001110 ) | ||||
| , BOOST_BINARY( 0001111 ) | ||||
| , BOOST_BINARY( 0010000 ) | ||||
| , BOOST_BINARY( 0010001 ) | ||||
| , BOOST_BINARY( 0010010 ) | ||||
| , BOOST_BINARY( 0010011 ) | ||||
| , BOOST_BINARY( 0010100 ) | ||||
| , BOOST_BINARY( 0010101 ) | ||||
| , BOOST_BINARY( 0010110 ) | ||||
| , BOOST_BINARY( 0010111 ) | ||||
| , BOOST_BINARY( 0011000 ) | ||||
| , BOOST_BINARY( 0011001 ) | ||||
| , BOOST_BINARY( 0011010 ) | ||||
| , BOOST_BINARY( 0011011 ) | ||||
| , BOOST_BINARY( 0011100 ) | ||||
| , BOOST_BINARY( 0011101 ) | ||||
| , BOOST_BINARY( 0011110 ) | ||||
| , BOOST_BINARY( 0011111 ) | ||||
| , BOOST_BINARY( 0100000 ) | ||||
| , BOOST_BINARY( 0100001 ) | ||||
| , BOOST_BINARY( 0100010 ) | ||||
| , BOOST_BINARY( 0100011 ) | ||||
| , BOOST_BINARY( 0100100 ) | ||||
| , BOOST_BINARY( 0100101 ) | ||||
| , BOOST_BINARY( 0100110 ) | ||||
| , BOOST_BINARY( 0100111 ) | ||||
| , BOOST_BINARY( 0101000 ) | ||||
| , BOOST_BINARY( 0101001 ) | ||||
| , BOOST_BINARY( 0101010 ) | ||||
| , BOOST_BINARY( 0101011 ) | ||||
| , BOOST_BINARY( 0101100 ) | ||||
| , BOOST_BINARY( 0101101 ) | ||||
| , BOOST_BINARY( 0101110 ) | ||||
| , BOOST_BINARY( 0101111 ) | ||||
| , BOOST_BINARY( 0110000 ) | ||||
| , BOOST_BINARY( 0110001 ) | ||||
| , BOOST_BINARY( 0110010 ) | ||||
| , BOOST_BINARY( 0110011 ) | ||||
| , BOOST_BINARY( 0110100 ) | ||||
| , BOOST_BINARY( 0110101 ) | ||||
| , BOOST_BINARY( 0110110 ) | ||||
| , BOOST_BINARY( 0110111 ) | ||||
| , BOOST_BINARY( 0111000 ) | ||||
| , BOOST_BINARY( 0111001 ) | ||||
| , BOOST_BINARY( 0111010 ) | ||||
| , BOOST_BINARY( 0111011 ) | ||||
| , BOOST_BINARY( 0111100 ) | ||||
| , BOOST_BINARY( 0111101 ) | ||||
| , BOOST_BINARY( 0111110 ) | ||||
| , BOOST_BINARY( 0111111 ) | ||||
| , BOOST_BINARY( 1000000 ) | ||||
| , BOOST_BINARY( 1000001 ) | ||||
| , BOOST_BINARY( 1000010 ) | ||||
| , BOOST_BINARY( 1000011 ) | ||||
| , BOOST_BINARY( 1000100 ) | ||||
| , BOOST_BINARY( 1000101 ) | ||||
| , BOOST_BINARY( 1000110 ) | ||||
| , BOOST_BINARY( 1000111 ) | ||||
| , BOOST_BINARY( 1001000 ) | ||||
| , BOOST_BINARY( 1001001 ) | ||||
| , BOOST_BINARY( 1001010 ) | ||||
| , BOOST_BINARY( 1001011 ) | ||||
| , BOOST_BINARY( 1001100 ) | ||||
| , BOOST_BINARY( 1001101 ) | ||||
| , BOOST_BINARY( 1001110 ) | ||||
| , BOOST_BINARY( 1001111 ) | ||||
| , BOOST_BINARY( 1010000 ) | ||||
| , BOOST_BINARY( 1010001 ) | ||||
| , BOOST_BINARY( 1010010 ) | ||||
| , BOOST_BINARY( 1010011 ) | ||||
| , BOOST_BINARY( 1010100 ) | ||||
| , BOOST_BINARY( 1010101 ) | ||||
| , BOOST_BINARY( 1010110 ) | ||||
| , BOOST_BINARY( 1010111 ) | ||||
| , BOOST_BINARY( 1011000 ) | ||||
| , BOOST_BINARY( 1011001 ) | ||||
| , BOOST_BINARY( 1011010 ) | ||||
| , BOOST_BINARY( 1011011 ) | ||||
| , BOOST_BINARY( 1011100 ) | ||||
| , BOOST_BINARY( 1011101 ) | ||||
| , BOOST_BINARY( 1011110 ) | ||||
| , BOOST_BINARY( 1011111 ) | ||||
| , BOOST_BINARY( 1100000 ) | ||||
| , BOOST_BINARY( 1100001 ) | ||||
| , BOOST_BINARY( 1100010 ) | ||||
| , BOOST_BINARY( 1100011 ) | ||||
| , BOOST_BINARY( 1100100 ) | ||||
| , BOOST_BINARY( 1100101 ) | ||||
| , BOOST_BINARY( 1100110 ) | ||||
| , BOOST_BINARY( 1100111 ) | ||||
| , BOOST_BINARY( 1101000 ) | ||||
| , BOOST_BINARY( 1101001 ) | ||||
| , BOOST_BINARY( 1101010 ) | ||||
| , BOOST_BINARY( 1101011 ) | ||||
| , BOOST_BINARY( 1101100 ) | ||||
| , BOOST_BINARY( 1101101 ) | ||||
| , BOOST_BINARY( 1101110 ) | ||||
| , BOOST_BINARY( 1101111 ) | ||||
| , BOOST_BINARY( 1110000 ) | ||||
| , BOOST_BINARY( 1110001 ) | ||||
| , BOOST_BINARY( 1110010 ) | ||||
| , BOOST_BINARY( 1110011 ) | ||||
| , BOOST_BINARY( 1110100 ) | ||||
| , BOOST_BINARY( 1110101 ) | ||||
| , BOOST_BINARY( 1110110 ) | ||||
| , BOOST_BINARY( 1110111 ) | ||||
| , BOOST_BINARY( 1111000 ) | ||||
| , BOOST_BINARY( 1111001 ) | ||||
| , BOOST_BINARY( 1111010 ) | ||||
| , BOOST_BINARY( 1111011 ) | ||||
| , BOOST_BINARY( 1111100 ) | ||||
| , BOOST_BINARY( 1111101 ) | ||||
| , BOOST_BINARY( 1111110 ) | ||||
| , BOOST_BINARY( 1111111 ) | ||||
| }; | ||||
| unsigned int const unsigned_ints_8_bits[256] = | ||||
| { BOOST_BINARY( 00000000 ) | ||||
| , BOOST_BINARY( 00000001 ) | ||||
| , BOOST_BINARY( 00000010 ) | ||||
| , BOOST_BINARY( 00000011 ) | ||||
| , BOOST_BINARY( 00000100 ) | ||||
| , BOOST_BINARY( 00000101 ) | ||||
| , BOOST_BINARY( 00000110 ) | ||||
| , BOOST_BINARY( 00000111 ) | ||||
| , BOOST_BINARY( 00001000 ) | ||||
| , BOOST_BINARY( 00001001 ) | ||||
| , BOOST_BINARY( 00001010 ) | ||||
| , BOOST_BINARY( 00001011 ) | ||||
| , BOOST_BINARY( 00001100 ) | ||||
| , BOOST_BINARY( 00001101 ) | ||||
| , BOOST_BINARY( 00001110 ) | ||||
| , BOOST_BINARY( 00001111 ) | ||||
| , BOOST_BINARY( 00010000 ) | ||||
| , BOOST_BINARY( 00010001 ) | ||||
| , BOOST_BINARY( 00010010 ) | ||||
| , BOOST_BINARY( 00010011 ) | ||||
| , BOOST_BINARY( 00010100 ) | ||||
| , BOOST_BINARY( 00010101 ) | ||||
| , BOOST_BINARY( 00010110 ) | ||||
| , BOOST_BINARY( 00010111 ) | ||||
| , BOOST_BINARY( 00011000 ) | ||||
| , BOOST_BINARY( 00011001 ) | ||||
| , BOOST_BINARY( 00011010 ) | ||||
| , BOOST_BINARY( 00011011 ) | ||||
| , BOOST_BINARY( 00011100 ) | ||||
| , BOOST_BINARY( 00011101 ) | ||||
| , BOOST_BINARY( 00011110 ) | ||||
| , BOOST_BINARY( 00011111 ) | ||||
| , BOOST_BINARY( 00100000 ) | ||||
| , BOOST_BINARY( 00100001 ) | ||||
| , BOOST_BINARY( 00100010 ) | ||||
| , BOOST_BINARY( 00100011 ) | ||||
| , BOOST_BINARY( 00100100 ) | ||||
| , BOOST_BINARY( 00100101 ) | ||||
| , BOOST_BINARY( 00100110 ) | ||||
| , BOOST_BINARY( 00100111 ) | ||||
| , BOOST_BINARY( 00101000 ) | ||||
| , BOOST_BINARY( 00101001 ) | ||||
| , BOOST_BINARY( 00101010 ) | ||||
| , BOOST_BINARY( 00101011 ) | ||||
| , BOOST_BINARY( 00101100 ) | ||||
| , BOOST_BINARY( 00101101 ) | ||||
| , BOOST_BINARY( 00101110 ) | ||||
| , BOOST_BINARY( 00101111 ) | ||||
| , BOOST_BINARY( 00110000 ) | ||||
| , BOOST_BINARY( 00110001 ) | ||||
| , BOOST_BINARY( 00110010 ) | ||||
| , BOOST_BINARY( 00110011 ) | ||||
| , BOOST_BINARY( 00110100 ) | ||||
| , BOOST_BINARY( 00110101 ) | ||||
| , BOOST_BINARY( 00110110 ) | ||||
| , BOOST_BINARY( 00110111 ) | ||||
| , BOOST_BINARY( 00111000 ) | ||||
| , BOOST_BINARY( 00111001 ) | ||||
| , BOOST_BINARY( 00111010 ) | ||||
| , BOOST_BINARY( 00111011 ) | ||||
| , BOOST_BINARY( 00111100 ) | ||||
| , BOOST_BINARY( 00111101 ) | ||||
| , BOOST_BINARY( 00111110 ) | ||||
| , BOOST_BINARY( 00111111 ) | ||||
| , BOOST_BINARY( 01000000 ) | ||||
| , BOOST_BINARY( 01000001 ) | ||||
| , BOOST_BINARY( 01000010 ) | ||||
| , BOOST_BINARY( 01000011 ) | ||||
| , BOOST_BINARY( 01000100 ) | ||||
| , BOOST_BINARY( 01000101 ) | ||||
| , BOOST_BINARY( 01000110 ) | ||||
| , BOOST_BINARY( 01000111 ) | ||||
| , BOOST_BINARY( 01001000 ) | ||||
| , BOOST_BINARY( 01001001 ) | ||||
| , BOOST_BINARY( 01001010 ) | ||||
| , BOOST_BINARY( 01001011 ) | ||||
| , BOOST_BINARY( 01001100 ) | ||||
| , BOOST_BINARY( 01001101 ) | ||||
| , BOOST_BINARY( 01001110 ) | ||||
| , BOOST_BINARY( 01001111 ) | ||||
| , BOOST_BINARY( 01010000 ) | ||||
| , BOOST_BINARY( 01010001 ) | ||||
| , BOOST_BINARY( 01010010 ) | ||||
| , BOOST_BINARY( 01010011 ) | ||||
| , BOOST_BINARY( 01010100 ) | ||||
| , BOOST_BINARY( 01010101 ) | ||||
| , BOOST_BINARY( 01010110 ) | ||||
| , BOOST_BINARY( 01010111 ) | ||||
| , BOOST_BINARY( 01011000 ) | ||||
| , BOOST_BINARY( 01011001 ) | ||||
| , BOOST_BINARY( 01011010 ) | ||||
| , BOOST_BINARY( 01011011 ) | ||||
| , BOOST_BINARY( 01011100 ) | ||||
| , BOOST_BINARY( 01011101 ) | ||||
| , BOOST_BINARY( 01011110 ) | ||||
| , BOOST_BINARY( 01011111 ) | ||||
| , BOOST_BINARY( 01100000 ) | ||||
| , BOOST_BINARY( 01100001 ) | ||||
| , BOOST_BINARY( 01100010 ) | ||||
| , BOOST_BINARY( 01100011 ) | ||||
| , BOOST_BINARY( 01100100 ) | ||||
| , BOOST_BINARY( 01100101 ) | ||||
| , BOOST_BINARY( 01100110 ) | ||||
| , BOOST_BINARY( 01100111 ) | ||||
| , BOOST_BINARY( 01101000 ) | ||||
| , BOOST_BINARY( 01101001 ) | ||||
| , BOOST_BINARY( 01101010 ) | ||||
| , BOOST_BINARY( 01101011 ) | ||||
| , BOOST_BINARY( 01101100 ) | ||||
| , BOOST_BINARY( 01101101 ) | ||||
| , BOOST_BINARY( 01101110 ) | ||||
| , BOOST_BINARY( 01101111 ) | ||||
| , BOOST_BINARY( 01110000 ) | ||||
| , BOOST_BINARY( 01110001 ) | ||||
| , BOOST_BINARY( 01110010 ) | ||||
| , BOOST_BINARY( 01110011 ) | ||||
| , BOOST_BINARY( 01110100 ) | ||||
| , BOOST_BINARY( 01110101 ) | ||||
| , BOOST_BINARY( 01110110 ) | ||||
| , BOOST_BINARY( 01110111 ) | ||||
| , BOOST_BINARY( 01111000 ) | ||||
| , BOOST_BINARY( 01111001 ) | ||||
| , BOOST_BINARY( 01111010 ) | ||||
| , BOOST_BINARY( 01111011 ) | ||||
| , BOOST_BINARY( 01111100 ) | ||||
| , BOOST_BINARY( 01111101 ) | ||||
| , BOOST_BINARY( 01111110 ) | ||||
| , BOOST_BINARY( 01111111 ) | ||||
| , BOOST_BINARY( 10000000 ) | ||||
| , BOOST_BINARY( 10000001 ) | ||||
| , BOOST_BINARY( 10000010 ) | ||||
| , BOOST_BINARY( 10000011 ) | ||||
| , BOOST_BINARY( 10000100 ) | ||||
| , BOOST_BINARY( 10000101 ) | ||||
| , BOOST_BINARY( 10000110 ) | ||||
| , BOOST_BINARY( 10000111 ) | ||||
| , BOOST_BINARY( 10001000 ) | ||||
| , BOOST_BINARY( 10001001 ) | ||||
| , BOOST_BINARY( 10001010 ) | ||||
| , BOOST_BINARY( 10001011 ) | ||||
| , BOOST_BINARY( 10001100 ) | ||||
| , BOOST_BINARY( 10001101 ) | ||||
| , BOOST_BINARY( 10001110 ) | ||||
| , BOOST_BINARY( 10001111 ) | ||||
| , BOOST_BINARY( 10010000 ) | ||||
| , BOOST_BINARY( 10010001 ) | ||||
| , BOOST_BINARY( 10010010 ) | ||||
| , BOOST_BINARY( 10010011 ) | ||||
| , BOOST_BINARY( 10010100 ) | ||||
| , BOOST_BINARY( 10010101 ) | ||||
| , BOOST_BINARY( 10010110 ) | ||||
| , BOOST_BINARY( 10010111 ) | ||||
| , BOOST_BINARY( 10011000 ) | ||||
| , BOOST_BINARY( 10011001 ) | ||||
| , BOOST_BINARY( 10011010 ) | ||||
| , BOOST_BINARY( 10011011 ) | ||||
| , BOOST_BINARY( 10011100 ) | ||||
| , BOOST_BINARY( 10011101 ) | ||||
| , BOOST_BINARY( 10011110 ) | ||||
| , BOOST_BINARY( 10011111 ) | ||||
| , BOOST_BINARY( 10100000 ) | ||||
| , BOOST_BINARY( 10100001 ) | ||||
| , BOOST_BINARY( 10100010 ) | ||||
| , BOOST_BINARY( 10100011 ) | ||||
| , BOOST_BINARY( 10100100 ) | ||||
| , BOOST_BINARY( 10100101 ) | ||||
| , BOOST_BINARY( 10100110 ) | ||||
| , BOOST_BINARY( 10100111 ) | ||||
| , BOOST_BINARY( 10101000 ) | ||||
| , BOOST_BINARY( 10101001 ) | ||||
| , BOOST_BINARY( 10101010 ) | ||||
| , BOOST_BINARY( 10101011 ) | ||||
| , BOOST_BINARY( 10101100 ) | ||||
| , BOOST_BINARY( 10101101 ) | ||||
| , BOOST_BINARY( 10101110 ) | ||||
| , BOOST_BINARY( 10101111 ) | ||||
| , BOOST_BINARY( 10110000 ) | ||||
| , BOOST_BINARY( 10110001 ) | ||||
| , BOOST_BINARY( 10110010 ) | ||||
| , BOOST_BINARY( 10110011 ) | ||||
| , BOOST_BINARY( 10110100 ) | ||||
| , BOOST_BINARY( 10110101 ) | ||||
| , BOOST_BINARY( 10110110 ) | ||||
| , BOOST_BINARY( 10110111 ) | ||||
| , BOOST_BINARY( 10111000 ) | ||||
| , BOOST_BINARY( 10111001 ) | ||||
| , BOOST_BINARY( 10111010 ) | ||||
| , BOOST_BINARY( 10111011 ) | ||||
| , BOOST_BINARY( 10111100 ) | ||||
| , BOOST_BINARY( 10111101 ) | ||||
| , BOOST_BINARY( 10111110 ) | ||||
| , BOOST_BINARY( 10111111 ) | ||||
| , BOOST_BINARY( 11000000 ) | ||||
| , BOOST_BINARY( 11000001 ) | ||||
| , BOOST_BINARY( 11000010 ) | ||||
| , BOOST_BINARY( 11000011 ) | ||||
| , BOOST_BINARY( 11000100 ) | ||||
| , BOOST_BINARY( 11000101 ) | ||||
| , BOOST_BINARY( 11000110 ) | ||||
| , BOOST_BINARY( 11000111 ) | ||||
| , BOOST_BINARY( 11001000 ) | ||||
| , BOOST_BINARY( 11001001 ) | ||||
| , BOOST_BINARY( 11001010 ) | ||||
| , BOOST_BINARY( 11001011 ) | ||||
| , BOOST_BINARY( 11001100 ) | ||||
| , BOOST_BINARY( 11001101 ) | ||||
| , BOOST_BINARY( 11001110 ) | ||||
| , BOOST_BINARY( 11001111 ) | ||||
| , BOOST_BINARY( 11010000 ) | ||||
| , BOOST_BINARY( 11010001 ) | ||||
| , BOOST_BINARY( 11010010 ) | ||||
| , BOOST_BINARY( 11010011 ) | ||||
| , BOOST_BINARY( 11010100 ) | ||||
| , BOOST_BINARY( 11010101 ) | ||||
| , BOOST_BINARY( 11010110 ) | ||||
| , BOOST_BINARY( 11010111 ) | ||||
| , BOOST_BINARY( 11011000 ) | ||||
| , BOOST_BINARY( 11011001 ) | ||||
| , BOOST_BINARY( 11011010 ) | ||||
| , BOOST_BINARY( 11011011 ) | ||||
| , BOOST_BINARY( 11011100 ) | ||||
| , BOOST_BINARY( 11011101 ) | ||||
| , BOOST_BINARY( 11011110 ) | ||||
| , BOOST_BINARY( 11011111 ) | ||||
| , BOOST_BINARY( 11100000 ) | ||||
| , BOOST_BINARY( 11100001 ) | ||||
| , BOOST_BINARY( 11100010 ) | ||||
| , BOOST_BINARY( 11100011 ) | ||||
| , BOOST_BINARY( 11100100 ) | ||||
| , BOOST_BINARY( 11100101 ) | ||||
| , BOOST_BINARY( 11100110 ) | ||||
| , BOOST_BINARY( 11100111 ) | ||||
| , BOOST_BINARY( 11101000 ) | ||||
| , BOOST_BINARY( 11101001 ) | ||||
| , BOOST_BINARY( 11101010 ) | ||||
| , BOOST_BINARY( 11101011 ) | ||||
| , BOOST_BINARY( 11101100 ) | ||||
| , BOOST_BINARY( 11101101 ) | ||||
| , BOOST_BINARY( 11101110 ) | ||||
| , BOOST_BINARY( 11101111 ) | ||||
| , BOOST_BINARY( 11110000 ) | ||||
| , BOOST_BINARY( 11110001 ) | ||||
| , BOOST_BINARY( 11110010 ) | ||||
| , BOOST_BINARY( 11110011 ) | ||||
| , BOOST_BINARY( 11110100 ) | ||||
| , BOOST_BINARY( 11110101 ) | ||||
| , BOOST_BINARY( 11110110 ) | ||||
| , BOOST_BINARY( 11110111 ) | ||||
| , BOOST_BINARY( 11111000 ) | ||||
| , BOOST_BINARY( 11111001 ) | ||||
| , BOOST_BINARY( 11111010 ) | ||||
| , BOOST_BINARY( 11111011 ) | ||||
| , BOOST_BINARY( 11111100 ) | ||||
| , BOOST_BINARY( 11111101 ) | ||||
| , BOOST_BINARY( 11111110 ) | ||||
| , BOOST_BINARY( 11111111 ) | ||||
| }; | ||||
|  | ||||
| struct left_is_not_one_less_than_right | ||||
| { | ||||
|   bool operator ()( unsigned int left, unsigned int right ) const | ||||
|   { | ||||
|     return right != left + 1; | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template< std::size_t Size > | ||||
| bool is_ascending_from_0_array( unsigned int const (&array)[Size] ) | ||||
| { | ||||
|   unsigned int const* const curr = array, | ||||
|                     * const end  = array + Size; | ||||
|  | ||||
|   return    ( *curr == 0 ) | ||||
|          && (    std::adjacent_find( curr, end | ||||
|                                    , left_is_not_one_less_than_right() | ||||
|                                    ) | ||||
|               == end | ||||
|             ); | ||||
| } | ||||
|  | ||||
| std::size_t const unsigned_int_id = 1, | ||||
|                   unsigned_long_int_id = 2; | ||||
|  | ||||
| typedef char (&unsigned_int_id_type)[unsigned_int_id]; | ||||
| typedef char (&unsigned_long_int_id_type)[unsigned_long_int_id]; | ||||
|  | ||||
| // Note: Functions only used for type checking | ||||
| unsigned_int_id_type      binary_type_checker( unsigned int ); | ||||
| unsigned_long_int_id_type binary_type_checker( unsigned long int ); | ||||
|  | ||||
| int test_main( int, char *[] ) | ||||
| { | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_1_bit ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_2_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_3_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_4_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_5_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_6_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_7_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_8_bits ) ); | ||||
|  | ||||
|   BOOST_CHECK( std::equal( &random_unsigned_ints_hex[0] | ||||
|                          , random_unsigned_ints_hex + num_random_test_values | ||||
|                          , &random_unsigned_ints_binary[0] | ||||
|                          ) | ||||
|              ); | ||||
|  | ||||
|   BOOST_CHECK(    sizeof( binary_type_checker( BOOST_BINARY_U( 110100 1010 ) ) ) | ||||
|                == unsigned_int_id | ||||
|              ); | ||||
|  | ||||
|   BOOST_CHECK(    sizeof( binary_type_checker( BOOST_BINARY_UL( 11110 ) ) ) | ||||
|                == unsigned_long_int_id | ||||
|              ); | ||||
|  | ||||
|   BOOST_CHECK(    sizeof( binary_type_checker( BOOST_BINARY_LU( 10 0001 ) ) ) | ||||
|                == unsigned_long_int_id | ||||
|              ); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -740,16 +740,26 @@ specialisation).</p> | ||||
|  | ||||
| <p>Revised 01 September 2000</p> | ||||
|  | ||||
|    <p> | ||||
|       Copyright 2000 Steve Cleary, Beman Dawes, Howard | ||||
|       Hinnant and John Maddock. <br/> | ||||
|       Use, modification and distribution are subject to the | ||||
|       Boost Software License, Version 1.0. | ||||
|       (See accompanying file LICENSE_1_0.txt | ||||
|       or copy at <a href="http://www.boost.org/LICENSE_1_0.txt"> | ||||
|          http://www.boost.org/LICENSE_1_0.txt | ||||
|       </a>). | ||||
|    </p> | ||||
| <p><EFBFBD> Copyright boost.org 2000. Permission to copy, use, modify, | ||||
| sell and distribute this document is granted provided this | ||||
| copyright notice appears in all copies. This document is provided | ||||
| "as is" without express or implied warranty, and with | ||||
| no claim as to its suitability for any purpose.</p> | ||||
|  | ||||
| <p>Based on contributions by Steve Cleary, Beman Dawes, Howard | ||||
| Hinnant and John Maddock.</p> | ||||
|  | ||||
| <p>Maintained by <a href="mailto:john@johnmaddock.co.uk">John | ||||
| Maddock</a>, the latest version of this file can be found at <a | ||||
| href="http://www.boost.org/">www.boost.org</a>, and the boost | ||||
| discussion list at <a | ||||
| href="http://www.yahoogroups.com/list/boost">www.yahoogroups.com/list/boost</a>.</p> | ||||
|  | ||||
| <p>.</p> | ||||
|  | ||||
| <p> </p> | ||||
|  | ||||
| <p> </p> | ||||
| </body> | ||||
| </html> | ||||
|  | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
|       <title>Header </title> | ||||
|       <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> | ||||
|       <meta name="Template" content="C:\PROGRAM FILES\MICROSOFT OFFICE\OFFICE\html.dot"> | ||||
|       <meta name="GENERATOR" content="Microsoft FrontPage 5.0"> | ||||
|       <meta name="GENERATOR" content="Microsoft FrontPage Express 2.0"> | ||||
|       <boostcompressed_pair.hpp> | ||||
|    </head> | ||||
|    <body bgcolor="#ffffff" text="#000000" link="#0000ff" vlink="#800080"> | ||||
| @@ -59,18 +59,17 @@ public: | ||||
|          empty type, then assigning to that member will produce memory corruption,  | ||||
|          unless the empty type has a "do nothing" assignment operator defined. This is  | ||||
|          due to a bug in the way VC6 generates implicit assignment operators.</p> | ||||
|       <h3>Acknowledgements</h3> | ||||
|       <hr> | ||||
|       <p>Revised 08 May 2001</p> | ||||
|       <p><EFBFBD> Copyright boost.org 2000. Permission to copy, use, modify, sell and  | ||||
|          distribute this document is granted provided this copyright notice appears in  | ||||
|          all copies. This document is provided "as is" without express or implied  | ||||
|          warranty, and with no claim as to its suitability for any purpose.</p> | ||||
|       <p>Based on contributions by Steve Cleary, Beman Dawes, Howard Hinnant and John  | ||||
|          Maddock.</p> | ||||
|       <p>Maintained by <a href="mailto:john@johnmaddock.co.uk">John Maddock</a>, the  | ||||
|          latest version of this file can be found at <a href="http://www.boost.org">www.boost.org</a>,  | ||||
|          and the boost discussion list at <a href="http://www.yahoogroups.com/list/boost">www.yahoogroups.com/list/boost</a>.</p> | ||||
|       <hr> | ||||
|       <p>Revised | ||||
|       <!--webbot bot="Timestamp" S-Type="EDITED" S-Format="%d %B %Y" startspan -->07 November 2007<!--webbot bot="Timestamp" endspan i-checksum="40338" --></p> | ||||
|       <p><EFBFBD> Copyright Beman Dawes, 2000.</p> | ||||
| <p>Distributed under the Boost Software License, Version 1.0. See | ||||
| <a href="http://www.boost.org/LICENSE_1_0.txt">www.boost.org/LICENSE_1_0.txt</a></p> | ||||
|  | ||||
|       <p> </p> | ||||
|    </body> | ||||
| </html> | ||||
| </html> | ||||
|   | ||||
| @@ -366,18 +366,17 @@ David Vandevoorde and Nicolai M. Josuttis. | ||||
| <EM>C++ Templates: The Complete Guide</EM>. | ||||
| Addison-Wesley, 2002.</DL> | ||||
|  | ||||
| <hr/> | ||||
|    <p>Copyright Jaakko Järvi, Jeremiah Willcock and Andrew Lumsdaine<BR> | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| <hr></hr> | ||||
|  | ||||
| <B>Contributed by:</B> <BR> | ||||
| Jaakko Järvi, Jeremiah Willcock and Andrew Lumsdaine<BR> | ||||
| <EM>{jajarvi|jewillco|lums}@osl.iu.edu</EM><BR> | ||||
| Indiana University<BR> | ||||
| Open Systems Lab<br/> | ||||
| Use, modification and distribution are subject to the | ||||
| Boost Software License, Version 1.0. | ||||
| (See accompanying file LICENSE_1_0.txt | ||||
| or copy at <a href="http://www.boost.org/LICENSE_1_0.txt"> | ||||
|    http://www.boost.org/LICENSE_1_0.txt | ||||
| </a>). | ||||
| </p> | ||||
| Open Systems Lab | ||||
| <!--HTMLFOOT--> | ||||
| <!--ENDHTML--> | ||||
| <!--FOOTER--> | ||||
|   | ||||
| @@ -1,20 +0,0 @@ | ||||
| # | ||||
| # Copyright Troy D. Straszheim | ||||
| # | ||||
| # Distributed under the Boost Software License, Version 1.0. | ||||
| # See http://www.boost.org/LICENSE_1_0.txt | ||||
| # | ||||
| foreach(T | ||||
|     constructors | ||||
|     dummy_arg_disambiguation | ||||
|     lazy | ||||
|     lazy_test | ||||
|     member_templates | ||||
|     namespace_disambiguation | ||||
|     no_disambiguation | ||||
|     partial_specializations | ||||
|     ) | ||||
|   boost_test_run(${T} DEPENDS boost_test_exec_monitor) | ||||
| endforeach() | ||||
|  | ||||
|  | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -146,14 +146,14 @@ int main() | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
|  | ||||
|   <p>Revised  | ||||
|   <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %B, %Y" startspan -->05 December, 2006<!--webbot bot="Timestamp" endspan i-checksum="38516" --></p> | ||||
|  | ||||
|   <p><i>Copyright © 2001 <a href= | ||||
|   "http://www.boost.org/people/jens_maurer.htm">Jens Maurer</a></i></p> | ||||
|   "../../people/jens_maurer.htm">Jens Maurer</a></i></p> | ||||
|  | ||||
|   <p><i>Distributed under the Boost Software License, Version 1.0. (See | ||||
|   accompanying file <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or | ||||
|   | ||||
| @@ -99,7 +99,7 @@ directly to the container:</p> | ||||
| <H2><A NAME="framework"></A>Framework</H2> | ||||
| <p> | ||||
| This library proposes a framework to allow some containers to directly contruct contained objects in-place without requiring | ||||
| the entire set of constructor overloads from the contained type. It also allows the container to remove the CopyConstuctible | ||||
| the entire set of constructor overloads ftom the contained type. It also allows the container to remove the CopyConstuctible | ||||
| requirement from the contained type since objects can be directly constructed in-place without need of a copy.<br> | ||||
| The only requirement on the container is that it must provide proper storage (that is, correctly aligned and sized). | ||||
| Naturally, the container will typically support uninitialized storage to avoid the in-place construction to override | ||||
| @@ -117,7 +117,7 @@ The following simplified example shows the basic idea. A complete example follow | ||||
| <pre>struct C | ||||
| { | ||||
|    template<class InPlaceFactory> | ||||
|    C ( InPlaceFactory const& aFactory ) | ||||
|    C ( InPlaceFactory const& aFactoty ) | ||||
|     : | ||||
|     contained_ ( uninitialized_storage() ) | ||||
|    { | ||||
| @@ -293,4 +293,4 @@ the latest version of this file can be found at <A | ||||
| HREF="http://www.boost.org">www.boost.org</A>, and the boost | ||||
| <A HREF="http://www.boost.org/more/mailing_lists.htm#main">discussion lists</A></P> | ||||
| </BODY> | ||||
| </HTML> | ||||
| </HTML> | ||||
| @@ -2,7 +2,6 @@ | ||||
| //  boost/assert.hpp - BOOST_ASSERT(expr) | ||||
| // | ||||
| //  Copyright (c) 2001, 2002 Peter Dimov and Multi Media Ltd. | ||||
| //  Copyright (c) 2007 Peter Dimov | ||||
| // | ||||
| // Distributed under the Boost Software License, Version 1.0. (See | ||||
| // accompanying file LICENSE_1_0.txt or copy at | ||||
| @@ -36,15 +35,3 @@ void assertion_failed(char const * expr, char const * function, char const * fil | ||||
| # include <assert.h> // .h to support old libraries w/o <cassert> - effect is the same | ||||
| # define BOOST_ASSERT(expr) assert(expr) | ||||
| #endif | ||||
|  | ||||
| #undef BOOST_VERIFY | ||||
|  | ||||
| #if defined(BOOST_DISABLE_ASSERTS) || ( !defined(BOOST_ENABLE_ASSERT_HANDLER) && defined(NDEBUG) ) | ||||
|  | ||||
| # define BOOST_VERIFY(expr) ((void)(expr)) | ||||
|  | ||||
| #else | ||||
|  | ||||
| # define BOOST_VERIFY(expr) BOOST_ASSERT(expr) | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -92,7 +92,7 @@ struct call_traits<T&> | ||||
|    typedef T& param_type;  // hh removed const | ||||
| }; | ||||
|  | ||||
| #if BOOST_WORKAROUND( __BORLANDC__,  < 0x5A0 ) | ||||
| #if BOOST_WORKAROUND( __BORLANDC__,  BOOST_TESTED_AT( 0x581 ) ) | ||||
| // these are illegal specialisations; cv-qualifies applied to | ||||
| // references have no effect according to [8.3.2p1], | ||||
| // C++ Builder requires them though as it treats cv-qualified | ||||
|   | ||||
| @@ -1,13 +0,0 @@ | ||||
| //Copyright (c) 2006-2008 Emil Dotchevski and Reverge Studios, Inc. | ||||
|  | ||||
| //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) | ||||
|  | ||||
| #ifndef UUID_1D94A7C6054E11DB9804B622A1EF5492 | ||||
| #define UUID_1D94A7C6054E11DB9804B622A1EF5492 | ||||
|  | ||||
| //The header <boost/exception.hpp> has been deprecated. | ||||
| //Please #include <boost/exception/all.hpp> instead. | ||||
| #include <boost/exception/all.hpp> | ||||
|  | ||||
| #endif | ||||
| @@ -8,9 +8,6 @@ | ||||
| //  See http://www.boost.org/libs/utility/operators.htm for documentation. | ||||
|  | ||||
| //  Revision History | ||||
| //  07 Aug 08 Added "euclidean" spelling. (Daniel Frey) | ||||
| //  03 Apr 08 Make sure "convertible to bool" is sufficient | ||||
| //            for T::operator<, etc. (Daniel Frey) | ||||
| //  24 May 07 Changed empty_base to depend on T, see | ||||
| //            http://svn.boost.org/trac/boost/ticket/979 | ||||
| //  21 Oct 02 Modified implementation of operators to allow compilers with a | ||||
| @@ -127,34 +124,34 @@ namespace boost | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct less_than_comparable2 : B | ||||
| { | ||||
|      friend bool operator<=(const T& x, const U& y) { return !static_cast<bool>(x > y); } | ||||
|      friend bool operator>=(const T& x, const U& y) { return !static_cast<bool>(x < y); } | ||||
|      friend bool operator<=(const T& x, const U& y) { return !(x > y); } | ||||
|      friend bool operator>=(const T& x, const U& y) { return !(x < y); } | ||||
|      friend bool operator>(const U& x, const T& y)  { return y < x; } | ||||
|      friend bool operator<(const U& x, const T& y)  { return y > x; } | ||||
|      friend bool operator<=(const U& x, const T& y) { return !static_cast<bool>(y < x); } | ||||
|      friend bool operator>=(const U& x, const T& y) { return !static_cast<bool>(y > x); } | ||||
|      friend bool operator<=(const U& x, const T& y) { return !(y < x); } | ||||
|      friend bool operator>=(const U& x, const T& y) { return !(y > x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct less_than_comparable1 : B | ||||
| { | ||||
|      friend bool operator>(const T& x, const T& y)  { return y < x; } | ||||
|      friend bool operator<=(const T& x, const T& y) { return !static_cast<bool>(y < x); } | ||||
|      friend bool operator>=(const T& x, const T& y) { return !static_cast<bool>(x < y); } | ||||
|      friend bool operator<=(const T& x, const T& y) { return !(y < x); } | ||||
|      friend bool operator>=(const T& x, const T& y) { return !(x < y); } | ||||
| }; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct equality_comparable2 : B | ||||
| { | ||||
|      friend bool operator==(const U& y, const T& x) { return x == y; } | ||||
|      friend bool operator!=(const U& y, const T& x) { return !static_cast<bool>(x == y); } | ||||
|      friend bool operator!=(const T& y, const U& x) { return !static_cast<bool>(y == x); } | ||||
|      friend bool operator!=(const U& y, const T& x) { return !(x == y); } | ||||
|      friend bool operator!=(const T& y, const U& x) { return !(y == x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct equality_comparable1 : B | ||||
| { | ||||
|      friend bool operator!=(const T& x, const T& y) { return !static_cast<bool>(x == y); } | ||||
|      friend bool operator!=(const T& x, const T& y) { return !(x == y); } | ||||
| }; | ||||
|  | ||||
| // A macro which produces "name_2left" from "name". | ||||
| @@ -359,7 +356,7 @@ struct equivalent2 : B | ||||
| { | ||||
|   friend bool operator==(const T& x, const U& y) | ||||
|   { | ||||
|     return !static_cast<bool>(x < y) && !static_cast<bool>(x > y); | ||||
|     return !(x < y) && !(x > y); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| @@ -368,7 +365,7 @@ struct equivalent1 : B | ||||
| { | ||||
|   friend bool operator==(const T&x, const T&y) | ||||
|   { | ||||
|     return !static_cast<bool>(x < y) && !static_cast<bool>(y < x); | ||||
|     return !(x < y) && !(y < x); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| @@ -376,17 +373,17 @@ template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct partially_ordered2 : B | ||||
| { | ||||
|   friend bool operator<=(const T& x, const U& y) | ||||
|     { return static_cast<bool>(x < y) || static_cast<bool>(x == y); } | ||||
|     { return (x < y) || (x == y); } | ||||
|   friend bool operator>=(const T& x, const U& y) | ||||
|     { return static_cast<bool>(x > y) || static_cast<bool>(x == y); } | ||||
|     { return (x > y) || (x == y); } | ||||
|   friend bool operator>(const U& x, const T& y) | ||||
|     { return y < x; } | ||||
|   friend bool operator<(const U& x, const T& y) | ||||
|     { return y > x; } | ||||
|   friend bool operator<=(const U& x, const T& y) | ||||
|     { return static_cast<bool>(y > x) || static_cast<bool>(y == x); } | ||||
|     { return (y > x) || (y == x); } | ||||
|   friend bool operator>=(const U& x, const T& y) | ||||
|     { return static_cast<bool>(y < x) || static_cast<bool>(y == x); } | ||||
|     { return (y < x) || (y == x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| @@ -395,9 +392,9 @@ struct partially_ordered1 : B | ||||
|   friend bool operator>(const T& x, const T& y) | ||||
|     { return y < x; } | ||||
|   friend bool operator<=(const T& x, const T& y) | ||||
|     { return static_cast<bool>(x < y) || static_cast<bool>(x == y); } | ||||
|     { return (x < y) || (x == y); } | ||||
|   friend bool operator>=(const T& x, const T& y) | ||||
|     { return static_cast<bool>(y < x) || static_cast<bool>(x == y); } | ||||
|     { return (y < x) || (x == y); } | ||||
| }; | ||||
|  | ||||
| //  Combined operator classes (contributed by Daryle Walker) ----------------// | ||||
| @@ -583,35 +580,7 @@ struct ordered_euclidian_ring_operators1 | ||||
|     : totally_ordered1<T | ||||
|     , euclidian_ring_operators1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct euclidean_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
|     , dividable2_left<T, U | ||||
|     , modable2<T, U | ||||
|     , modable2_left<T, U, B | ||||
|       > > > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct euclidean_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T | ||||
|     , modable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_euclidean_ring_operators2 | ||||
|     : totally_ordered2<T, U | ||||
|     , euclidean_ring_operators2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_euclidean_ring_operators1 | ||||
|     : totally_ordered1<T | ||||
|     , euclidean_ring_operators1<T, B | ||||
|       > > {}; | ||||
|  | ||||
|        | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| struct input_iteratable | ||||
|     : equality_comparable1<T | ||||
| @@ -868,8 +837,6 @@ BOOST_OPERATOR_TEMPLATE(field_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(ordered_field_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(euclidian_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(ordered_euclidian_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(euclidean_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(ordered_euclidean_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE2(input_iteratable) | ||||
| BOOST_OPERATOR_TEMPLATE1(output_iteratable) | ||||
| BOOST_OPERATOR_TEMPLATE2(forward_iteratable) | ||||
|   | ||||
| @@ -15,7 +15,7 @@ | ||||
| // | ||||
| //  ref.hpp - ref/cref, useful helper functions | ||||
| // | ||||
| //  Copyright (C) 1999, 2000 Jaakko Jarvi (jaakko.jarvi@cs.utu.fi) | ||||
| //  Copyright (C) 1999, 2000 Jaakko J<EFBFBD>rvi (jaakko.jarvi@cs.utu.fi) | ||||
| //  Copyright (C) 2001, 2002 Peter Dimov | ||||
| //  Copyright (C) 2002 David Abrahams | ||||
| // | ||||
| @@ -173,17 +173,6 @@ class unwrap_reference | ||||
|  | ||||
| # endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||
|  | ||||
| template <class T> inline typename unwrap_reference<T>::type& | ||||
| unwrap_ref(T& t) | ||||
| { | ||||
|     return t; | ||||
| } | ||||
|  | ||||
| template<class T> inline T* get_pointer( reference_wrapper<T> const & r ) | ||||
| { | ||||
|     return r.get_pointer(); | ||||
| } | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| #endif // #ifndef BOOST_REF_HPP_INCLUDED | ||||
|   | ||||
| @@ -1,12 +0,0 @@ | ||||
| // Copyright (C) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| #ifndef BOOST_SWAP_HPP | ||||
| #define BOOST_SWAP_HPP | ||||
|  | ||||
| #include "boost/utility/swap.hpp" | ||||
|  | ||||
| #endif | ||||
| @@ -10,8 +10,7 @@ | ||||
| #define BOOST_UTILITY_HPP | ||||
|  | ||||
| #include <boost/utility/addressof.hpp> | ||||
| #include <boost/utility/base_from_member.hpp> | ||||
| #include <boost/utility/binary.hpp> | ||||
| #include <boost/utility/base_from_member.hpp>   | ||||
| #include <boost/utility/enable_if.hpp> | ||||
| #include <boost/checked_delete.hpp> | ||||
| #include <boost/next_prior.hpp> | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| // Copyright (C) 2002 Brad King (brad.king@kitware.com)  | ||||
| //                    Douglas Gregor (gregod@cs.rpi.edu) | ||||
| // | ||||
| // Copyright (C) 2002, 2008 Peter Dimov | ||||
| //                    Peter Dimov | ||||
| // | ||||
| // Distributed under the Boost Software License, Version 1.0. (See | ||||
| // accompanying file LICENSE_1_0.txt or copy at | ||||
| @@ -15,75 +14,32 @@ | ||||
| # include <boost/config.hpp> | ||||
| # include <boost/detail/workaround.hpp> | ||||
|  | ||||
| namespace boost | ||||
| { | ||||
| namespace boost { | ||||
|  | ||||
| namespace detail | ||||
| { | ||||
| // Do not make addressof() inline. Breaks MSVC 7. (Peter Dimov) | ||||
|  | ||||
| template<class T> struct addr_impl_ref | ||||
| { | ||||
|     T & v_; | ||||
| // VC7 strips const from nested classes unless we add indirection here | ||||
| # if BOOST_WORKAROUND(BOOST_MSVC, == 1300) | ||||
|  | ||||
|     inline addr_impl_ref( T & v ): v_( v ) {} | ||||
|     inline operator T& () const { return v_; } | ||||
|  | ||||
| private: | ||||
|     addr_impl_ref & operator=(const addr_impl_ref &); | ||||
| }; | ||||
|  | ||||
| template<class T> struct addressof_impl | ||||
| { | ||||
|     static inline T * f( T & v, long ) | ||||
|     { | ||||
|         return reinterpret_cast<T*>( | ||||
|             &const_cast<char&>(reinterpret_cast<const volatile char &>(v))); | ||||
|     } | ||||
|  | ||||
|     static inline T * f( T * v, int ) | ||||
|     { | ||||
|         return v; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| } // namespace detail | ||||
|  | ||||
| template<class T> T * addressof( T & v ) | ||||
| { | ||||
| #if defined( __BORLANDC__ ) && BOOST_WORKAROUND( __BORLANDC__, BOOST_TESTED_AT( 0x610 ) ) | ||||
|  | ||||
|     return boost::detail::addressof_impl<T>::f( v, 0 ); | ||||
|  | ||||
| #else | ||||
|  | ||||
|     return boost::detail::addressof_impl<T>::f( boost::detail::addr_impl_ref<T>( v ), 0 ); | ||||
|  | ||||
| #endif | ||||
| } | ||||
|  | ||||
| #if defined( __SUNPRO_CC ) && BOOST_WORKAROUND( __SUNPRO_CC, BOOST_TESTED_AT( 0x590 ) ) | ||||
|  | ||||
| namespace detail | ||||
| { | ||||
|  | ||||
| template<class T> struct addressof_addp | ||||
| template<class T> struct _addp | ||||
| { | ||||
|     typedef T * type; | ||||
| }; | ||||
|      | ||||
| template <typename T> typename _addp<T>::type | ||||
|  | ||||
| } // namespace detail | ||||
|  | ||||
| template< class T, std::size_t N > | ||||
| typename detail::addressof_addp< T[N] >::type addressof( T (&t)[N] ) | ||||
| # else | ||||
| template <typename T> T* | ||||
| # endif | ||||
| addressof(T& v) | ||||
| { | ||||
|     return &t; | ||||
|   return reinterpret_cast<T*>( | ||||
|        &const_cast<char&>(reinterpret_cast<const volatile char &>(v))); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| // Borland doesn't like casting an array reference to a char reference | ||||
| // but these overloads work around the problem. | ||||
| #if defined( __BORLANDC__ ) && BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) | ||||
| # if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) | ||||
| template<typename T,std::size_t N> | ||||
| T (*addressof(T (&t)[N]))[N] | ||||
| { | ||||
| @@ -95,8 +51,8 @@ const T (*addressof(const T (&t)[N]))[N] | ||||
| { | ||||
|    return reinterpret_cast<const T(*)[N]>(&t); | ||||
| } | ||||
| #endif | ||||
| # endif | ||||
|  | ||||
| } // namespace boost | ||||
| } | ||||
|  | ||||
| #endif // BOOST_UTILITY_ADDRESSOF_HPP | ||||
|   | ||||
| @@ -1,708 +0,0 @@ | ||||
| /*============================================================================= | ||||
|     Copyright (c) 2005 Matthew Calabrese | ||||
|  | ||||
|     Use, modification and distribution is subject to 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) | ||||
| ==============================================================================*/ | ||||
|  | ||||
| #ifndef BOOST_UTILITY_BINARY_HPP | ||||
| #define BOOST_UTILITY_BINARY_HPP | ||||
|  | ||||
| /*============================================================================= | ||||
|  | ||||
|     Binary Literal Utility | ||||
|     ______________________ | ||||
|  | ||||
|  | ||||
|     The following code works by converting the input bit pattern into a | ||||
|     Boost.Preprocessor sequence, then converting groupings of 3 bits each into | ||||
|     the corresponding octal digit, and finally concatenating all of the digits | ||||
|     together along with a leading zero. This yields a standard octal literal | ||||
|     with the desired value as specified in bits. | ||||
|  | ||||
| ==============================================================================*/ | ||||
|  | ||||
| #include <boost/preprocessor/control/deduce_d.hpp> | ||||
| #include <boost/preprocessor/facilities/identity.hpp> | ||||
| #include <boost/preprocessor/cat.hpp> | ||||
| #include <boost/preprocessor/seq/cat.hpp> | ||||
| #include <boost/preprocessor/seq/transform.hpp> | ||||
| #include <boost/preprocessor/arithmetic/mod.hpp> | ||||
| #include <boost/preprocessor/seq/size.hpp> | ||||
| #include <boost/preprocessor/facilities/empty.hpp> | ||||
| #include <boost/preprocessor/control/while.hpp> | ||||
|  | ||||
| #define BOOST_BINARY( bit_groupings )                                          \ | ||||
|   BOOST_BINARY_LITERAL_D( BOOST_PP_DEDUCE_D(), bit_groupings )  | ||||
|  | ||||
| #define BOOST_BINARY_U( bit_groupings )                                        \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, U )  | ||||
|  | ||||
| #define BOOST_BINARY_L( bit_groupings )                                        \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, L )  | ||||
|  | ||||
| #define BOOST_BINARY_UL( bit_groupings )                                       \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, UL )  | ||||
|  | ||||
| #define BOOST_BINARY_LU( bit_groupings )                                       \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, LU )  | ||||
|  | ||||
| #define BOOST_BINARY_LL( bit_groupings )                                       \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, LL )  | ||||
|  | ||||
| #define BOOST_BINARY_ULL( bit_groupings )                                      \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, ULL )  | ||||
|  | ||||
| #define BOOST_BINARY_LLU( bit_groupings )                                      \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, LLU )  | ||||
|  | ||||
| #define BOOST_SUFFIXED_BINARY_LITERAL( bit_groupings, suffix )                 \ | ||||
|   BOOST_SUFFIXED_BINARY_LITERAL_D( BOOST_PP_DEDUCE_D(), bit_groupings, suffix )  | ||||
|  | ||||
| #define BOOST_SUFFIXED_BINARY_LITERAL_D( d, bit_groupings, suffix )            \ | ||||
|   BOOST_PP_CAT( BOOST_BINARY_LITERAL_D( d, bit_groupings ), suffix )  | ||||
|  | ||||
| #define BOOST_BINARY_LITERAL_D( d, bit_groupings )                             \ | ||||
|   BOOST_PP_SEQ_CAT                                                             \ | ||||
|   ( (0) BOOST_DETAIL_CREATE_BINARY_LITERAL_OCTAL_SEQUENCE( d, bit_groupings )  \ | ||||
|   )  | ||||
|  | ||||
| #define BOOST_DETAIL_CREATE_BINARY_LITERAL_OCTAL_SEQUENCE( d, bit_groupings )  \ | ||||
|   BOOST_PP_SEQ_TRANSFORM                                                       \ | ||||
|   ( BOOST_DETAIL_TRIPLE_TO_OCTAL_OPERATION                                     \ | ||||
|   , BOOST_PP_NIL                                                               \ | ||||
|   , BOOST_PP_IDENTITY( BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_TRIPLE_SEQUENCE )()\ | ||||
|     ( BOOST_DETAIL_COMPLETE_TRIPLE_SEQUENCE                                    \ | ||||
|       (                                                                        \ | ||||
|         d                                                                      \ | ||||
|       , BOOST_DETAIL_CREATE_BINARY_LITERAL_BIT_SEQUENCE( d, bit_groupings )    \ | ||||
|       )                                                                        \ | ||||
|     )                                                                          \ | ||||
|   )  | ||||
|  | ||||
| #define BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_TRIPLE_SEQUENCE( bit_sequence )   \ | ||||
|   BOOST_PP_CAT                                                                 \ | ||||
|   ( BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_1 bit_sequence      \ | ||||
|   , END_BIT                                                                    \ | ||||
|   )  | ||||
|  | ||||
| #define BOOST_DETAIL_BITS_PER_OCTIT 3 | ||||
|  | ||||
| #define BOOST_DETAIL_COMPLETE_TRIPLE_SEQUENCE( d, incomplete_nibble_sequence ) \ | ||||
|   BOOST_PP_CAT                                                                 \ | ||||
|   ( BOOST_DETAIL_CREATE_TRIPLE_COMPLETION_SEQUENCE_                            \ | ||||
|   , BOOST_PP_MOD_D( d                                                          \ | ||||
|                   , BOOST_PP_SEQ_SIZE( incomplete_nibble_sequence )            \ | ||||
|                   , BOOST_DETAIL_BITS_PER_OCTIT                                \ | ||||
|                   )                                                            \ | ||||
|   )                                                                            \ | ||||
|   incomplete_nibble_sequence  | ||||
|  | ||||
| #define BOOST_DETAIL_FIXED_COMPL( bit )                                        \ | ||||
|   BOOST_PP_CAT( BOOST_DETAIL_FIXED_COMPL_, bit ) | ||||
|  | ||||
| #define BOOST_DETAIL_FIXED_COMPL_0 1  | ||||
|  | ||||
| #define BOOST_DETAIL_FIXED_COMPL_1 0  | ||||
|  | ||||
| #define BOOST_DETAIL_CREATE_BINARY_LITERAL_BIT_SEQUENCE( d, bit_groupings )    \ | ||||
|   BOOST_PP_EMPTY                                                               \ | ||||
|   BOOST_PP_CAT( BOOST_PP_WHILE_, d )                                           \ | ||||
|   ( BOOST_DETAIL_BINARY_LITERAL_PREDICATE                                      \ | ||||
|   , BOOST_DETAIL_BINARY_LITERAL_OPERATION                                      \ | ||||
|   , bit_groupings ()                                                           \ | ||||
|   )  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_PREDICATE( d, state )                      \ | ||||
|   BOOST_DETAIL_FIXED_COMPL( BOOST_DETAIL_IS_NULLARY_ARGS( state ) )  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_OPERATION( d, state )                      \ | ||||
|   BOOST_DETAIL_SPLIT_AND_SWAP                                                  \ | ||||
|   ( BOOST_PP_CAT( BOOST_DETAIL_BINARY_LITERAL_ELEMENT_, state ) )  | ||||
|  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_OPERATION( s, dummy_param, tuple )        \ | ||||
|   BOOST_DETAIL_TERNARY_TRIPLE_TO_OCTAL tuple  | ||||
|  | ||||
| #define BOOST_DETAIL_TERNARY_TRIPLE_TO_OCTAL( bit2, bit1, bit0 )               \ | ||||
|   BOOST_DETAIL_TRIPLE_TO_OCTAL_ ## bit2 ## bit1 ## bit0  | ||||
|  | ||||
| #define BOOST_DETAIL_CREATE_TRIPLE_COMPLETION_SEQUENCE_1 (0)(0) | ||||
| #define BOOST_DETAIL_CREATE_TRIPLE_COMPLETION_SEQUENCE_2 (0) | ||||
| #define BOOST_DETAIL_CREATE_TRIPLE_COMPLETION_SEQUENCE_0   | ||||
|  | ||||
| #define BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_1END_BIT   | ||||
|  | ||||
| #define BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_1( bit )        \ | ||||
|   ( ( bit, BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_2  | ||||
|  | ||||
| #define BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_2( bit )        \ | ||||
|   bit, BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_3  | ||||
|  | ||||
| #define BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_3( bit )        \ | ||||
|   bit ) ) BOOST_DETAIL_CONVERT_BIT_SEQUENCE_TO_PARENTHETIC_TUPLE_1  | ||||
|  | ||||
| #define BOOST_DETAIL_SPLIT_AND_SWAP( params )                                  \ | ||||
|   BOOST_PP_IDENTITY( BOOST_DETAIL_SPLIT_AND_SWAP_PARAMS )()( params ) | ||||
|  | ||||
| #define BOOST_DETAIL_SPLIT_AND_SWAP_PARAMS( first_param, second_param )        \ | ||||
|   second_param first_param  | ||||
|  | ||||
| #define BOOST_DETAIL_LEFT_OF_COMMA( params )                                   \ | ||||
|   BOOST_PP_IDENTITY( BOOST_DETAIL_FIRST_MACRO_PARAM )()( params )  | ||||
|  | ||||
| #define BOOST_DETAIL_FIRST_MACRO_PARAM( first_param, second_param )            \ | ||||
|   first_param  | ||||
|  | ||||
| /* Begin derived concepts from Chaos by Paul Mensonides */ | ||||
|  | ||||
| #define BOOST_DETAIL_IS_NULLARY_ARGS( param )                                  \ | ||||
|   BOOST_DETAIL_LEFT_OF_COMMA                                                   \ | ||||
|   ( BOOST_PP_CAT( BOOST_DETAIL_IS_NULLARY_ARGS_R_                              \ | ||||
|                 , BOOST_DETAIL_IS_NULLARY_ARGS_C param                         \ | ||||
|                 )                                                              \ | ||||
|   )  | ||||
|  | ||||
| #define BOOST_DETAIL_IS_NULLARY_ARGS_C()                                       \ | ||||
|   1  | ||||
|  | ||||
| #define BOOST_DETAIL_IS_NULLARY_ARGS_R_1                                       \ | ||||
|   1, BOOST_PP_NIL  | ||||
|  | ||||
| #define BOOST_DETAIL_IS_NULLARY_ARGS_R_BOOST_DETAIL_IS_NULLARY_ARGS_C          \ | ||||
|   0, BOOST_PP_NIL  | ||||
|  | ||||
| /* End derived concepts from Chaos by Paul Mensonides */ | ||||
|  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_000 0  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_001 1  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_010 2  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_011 3  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_100 4  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_101 5  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_110 6  | ||||
| #define BOOST_DETAIL_TRIPLE_TO_OCTAL_111 7  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0 (0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1 (1),  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00 (0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01 (0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10 (1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11 (1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00 (0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01 (0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10 (1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11 (1)(1),  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000 (0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001 (0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010 (0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011 (0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100 (1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101 (1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110 (1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111 (1)(1)(1),  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000 (0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001 (0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010 (0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011 (0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100 (0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101 (0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110 (0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111 (0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000 (1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001 (1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010 (1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011 (1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100 (1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101 (1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110 (1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111 (1)(1)(1)(1),  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000 (0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001 (0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010 (0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011 (0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100 (0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101 (0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110 (0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111 (0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000 (0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001 (0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010 (0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011 (0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100 (0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101 (0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110 (0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111 (0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000 (1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001 (1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010 (1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011 (1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100 (1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101 (1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110 (1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111 (1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000 (1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001 (1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010 (1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011 (1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100 (1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101 (1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110 (1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111 (1)(1)(1)(1)(1),  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000000 (0)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000001 (0)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000010 (0)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000011 (0)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000100 (0)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000101 (0)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000110 (0)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_000111 (0)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001000 (0)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001001 (0)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001010 (0)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001011 (0)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001100 (0)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001101 (0)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001110 (0)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_001111 (0)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010000 (0)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010001 (0)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010010 (0)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010011 (0)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010100 (0)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010101 (0)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010110 (0)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_010111 (0)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011000 (0)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011001 (0)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011010 (0)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011011 (0)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011100 (0)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011101 (0)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011110 (0)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_011111 (0)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100000 (1)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100001 (1)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100010 (1)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100011 (1)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100100 (1)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100101 (1)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100110 (1)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_100111 (1)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101000 (1)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101001 (1)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101010 (1)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101011 (1)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101100 (1)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101101 (1)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101110 (1)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_101111 (1)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110000 (1)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110001 (1)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110010 (1)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110011 (1)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110100 (1)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110101 (1)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110110 (1)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_110111 (1)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111000 (1)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111001 (1)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111010 (1)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111011 (1)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111100 (1)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111101 (1)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111110 (1)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_111111 (1)(1)(1)(1)(1)(1),  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000000 (0)(0)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000001 (0)(0)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000010 (0)(0)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000011 (0)(0)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000100 (0)(0)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000101 (0)(0)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000110 (0)(0)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0000111 (0)(0)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001000 (0)(0)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001001 (0)(0)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001010 (0)(0)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001011 (0)(0)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001100 (0)(0)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001101 (0)(0)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001110 (0)(0)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0001111 (0)(0)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010000 (0)(0)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010001 (0)(0)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010010 (0)(0)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010011 (0)(0)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010100 (0)(0)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010101 (0)(0)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010110 (0)(0)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0010111 (0)(0)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011000 (0)(0)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011001 (0)(0)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011010 (0)(0)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011011 (0)(0)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011100 (0)(0)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011101 (0)(0)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011110 (0)(0)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0011111 (0)(0)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100000 (0)(1)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100001 (0)(1)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100010 (0)(1)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100011 (0)(1)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100100 (0)(1)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100101 (0)(1)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100110 (0)(1)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0100111 (0)(1)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101000 (0)(1)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101001 (0)(1)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101010 (0)(1)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101011 (0)(1)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101100 (0)(1)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101101 (0)(1)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101110 (0)(1)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0101111 (0)(1)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110000 (0)(1)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110001 (0)(1)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110010 (0)(1)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110011 (0)(1)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110100 (0)(1)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110101 (0)(1)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110110 (0)(1)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0110111 (0)(1)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111000 (0)(1)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111001 (0)(1)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111010 (0)(1)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111011 (0)(1)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111100 (0)(1)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111101 (0)(1)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111110 (0)(1)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_0111111 (0)(1)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000000 (1)(0)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000001 (1)(0)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000010 (1)(0)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000011 (1)(0)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000100 (1)(0)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000101 (1)(0)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000110 (1)(0)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1000111 (1)(0)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001000 (1)(0)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001001 (1)(0)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001010 (1)(0)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001011 (1)(0)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001100 (1)(0)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001101 (1)(0)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001110 (1)(0)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1001111 (1)(0)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010000 (1)(0)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010001 (1)(0)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010010 (1)(0)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010011 (1)(0)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010100 (1)(0)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010101 (1)(0)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010110 (1)(0)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1010111 (1)(0)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011000 (1)(0)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011001 (1)(0)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011010 (1)(0)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011011 (1)(0)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011100 (1)(0)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011101 (1)(0)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011110 (1)(0)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1011111 (1)(0)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100000 (1)(1)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100001 (1)(1)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100010 (1)(1)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100011 (1)(1)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100100 (1)(1)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100101 (1)(1)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100110 (1)(1)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1100111 (1)(1)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101000 (1)(1)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101001 (1)(1)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101010 (1)(1)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101011 (1)(1)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101100 (1)(1)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101101 (1)(1)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101110 (1)(1)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1101111 (1)(1)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110000 (1)(1)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110001 (1)(1)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110010 (1)(1)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110011 (1)(1)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110100 (1)(1)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110101 (1)(1)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110110 (1)(1)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1110111 (1)(1)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111000 (1)(1)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111001 (1)(1)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111010 (1)(1)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111011 (1)(1)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111100 (1)(1)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111101 (1)(1)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111110 (1)(1)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_1111111 (1)(1)(1)(1)(1)(1)(1),  | ||||
|  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000000 (0)(0)(0)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000001 (0)(0)(0)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000010 (0)(0)(0)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000011 (0)(0)(0)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000100 (0)(0)(0)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000101 (0)(0)(0)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000110 (0)(0)(0)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00000111 (0)(0)(0)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001000 (0)(0)(0)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001001 (0)(0)(0)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001010 (0)(0)(0)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001011 (0)(0)(0)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001100 (0)(0)(0)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001101 (0)(0)(0)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001110 (0)(0)(0)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00001111 (0)(0)(0)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010000 (0)(0)(0)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010001 (0)(0)(0)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010010 (0)(0)(0)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010011 (0)(0)(0)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010100 (0)(0)(0)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010101 (0)(0)(0)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010110 (0)(0)(0)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00010111 (0)(0)(0)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011000 (0)(0)(0)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011001 (0)(0)(0)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011010 (0)(0)(0)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011011 (0)(0)(0)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011100 (0)(0)(0)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011101 (0)(0)(0)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011110 (0)(0)(0)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00011111 (0)(0)(0)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100000 (0)(0)(1)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100001 (0)(0)(1)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100010 (0)(0)(1)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100011 (0)(0)(1)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100100 (0)(0)(1)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100101 (0)(0)(1)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100110 (0)(0)(1)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00100111 (0)(0)(1)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101000 (0)(0)(1)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101001 (0)(0)(1)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101010 (0)(0)(1)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101011 (0)(0)(1)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101100 (0)(0)(1)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101101 (0)(0)(1)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101110 (0)(0)(1)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00101111 (0)(0)(1)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110000 (0)(0)(1)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110001 (0)(0)(1)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110010 (0)(0)(1)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110011 (0)(0)(1)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110100 (0)(0)(1)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110101 (0)(0)(1)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110110 (0)(0)(1)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00110111 (0)(0)(1)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111000 (0)(0)(1)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111001 (0)(0)(1)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111010 (0)(0)(1)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111011 (0)(0)(1)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111100 (0)(0)(1)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111101 (0)(0)(1)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111110 (0)(0)(1)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_00111111 (0)(0)(1)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000000 (0)(1)(0)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000001 (0)(1)(0)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000010 (0)(1)(0)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000011 (0)(1)(0)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000100 (0)(1)(0)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000101 (0)(1)(0)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000110 (0)(1)(0)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01000111 (0)(1)(0)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001000 (0)(1)(0)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001001 (0)(1)(0)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001010 (0)(1)(0)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001011 (0)(1)(0)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001100 (0)(1)(0)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001101 (0)(1)(0)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001110 (0)(1)(0)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01001111 (0)(1)(0)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010000 (0)(1)(0)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010001 (0)(1)(0)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010010 (0)(1)(0)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010011 (0)(1)(0)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010100 (0)(1)(0)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010101 (0)(1)(0)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010110 (0)(1)(0)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01010111 (0)(1)(0)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011000 (0)(1)(0)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011001 (0)(1)(0)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011010 (0)(1)(0)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011011 (0)(1)(0)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011100 (0)(1)(0)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011101 (0)(1)(0)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011110 (0)(1)(0)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01011111 (0)(1)(0)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100000 (0)(1)(1)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100001 (0)(1)(1)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100010 (0)(1)(1)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100011 (0)(1)(1)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100100 (0)(1)(1)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100101 (0)(1)(1)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100110 (0)(1)(1)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01100111 (0)(1)(1)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101000 (0)(1)(1)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101001 (0)(1)(1)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101010 (0)(1)(1)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101011 (0)(1)(1)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101100 (0)(1)(1)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101101 (0)(1)(1)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101110 (0)(1)(1)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01101111 (0)(1)(1)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110000 (0)(1)(1)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110001 (0)(1)(1)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110010 (0)(1)(1)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110011 (0)(1)(1)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110100 (0)(1)(1)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110101 (0)(1)(1)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110110 (0)(1)(1)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01110111 (0)(1)(1)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111000 (0)(1)(1)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111001 (0)(1)(1)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111010 (0)(1)(1)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111011 (0)(1)(1)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111100 (0)(1)(1)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111101 (0)(1)(1)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111110 (0)(1)(1)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_01111111 (0)(1)(1)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000000 (1)(0)(0)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000001 (1)(0)(0)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000010 (1)(0)(0)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000011 (1)(0)(0)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000100 (1)(0)(0)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000101 (1)(0)(0)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000110 (1)(0)(0)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10000111 (1)(0)(0)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001000 (1)(0)(0)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001001 (1)(0)(0)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001010 (1)(0)(0)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001011 (1)(0)(0)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001100 (1)(0)(0)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001101 (1)(0)(0)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001110 (1)(0)(0)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10001111 (1)(0)(0)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010000 (1)(0)(0)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010001 (1)(0)(0)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010010 (1)(0)(0)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010011 (1)(0)(0)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010100 (1)(0)(0)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010101 (1)(0)(0)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010110 (1)(0)(0)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10010111 (1)(0)(0)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011000 (1)(0)(0)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011001 (1)(0)(0)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011010 (1)(0)(0)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011011 (1)(0)(0)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011100 (1)(0)(0)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011101 (1)(0)(0)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011110 (1)(0)(0)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10011111 (1)(0)(0)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100000 (1)(0)(1)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100001 (1)(0)(1)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100010 (1)(0)(1)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100011 (1)(0)(1)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100100 (1)(0)(1)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100101 (1)(0)(1)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100110 (1)(0)(1)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10100111 (1)(0)(1)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101000 (1)(0)(1)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101001 (1)(0)(1)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101010 (1)(0)(1)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101011 (1)(0)(1)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101100 (1)(0)(1)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101101 (1)(0)(1)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101110 (1)(0)(1)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10101111 (1)(0)(1)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110000 (1)(0)(1)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110001 (1)(0)(1)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110010 (1)(0)(1)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110011 (1)(0)(1)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110100 (1)(0)(1)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110101 (1)(0)(1)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110110 (1)(0)(1)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10110111 (1)(0)(1)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111000 (1)(0)(1)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111001 (1)(0)(1)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111010 (1)(0)(1)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111011 (1)(0)(1)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111100 (1)(0)(1)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111101 (1)(0)(1)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111110 (1)(0)(1)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_10111111 (1)(0)(1)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000000 (1)(1)(0)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000001 (1)(1)(0)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000010 (1)(1)(0)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000011 (1)(1)(0)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000100 (1)(1)(0)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000101 (1)(1)(0)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000110 (1)(1)(0)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11000111 (1)(1)(0)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001000 (1)(1)(0)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001001 (1)(1)(0)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001010 (1)(1)(0)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001011 (1)(1)(0)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001100 (1)(1)(0)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001101 (1)(1)(0)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001110 (1)(1)(0)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11001111 (1)(1)(0)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010000 (1)(1)(0)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010001 (1)(1)(0)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010010 (1)(1)(0)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010011 (1)(1)(0)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010100 (1)(1)(0)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010101 (1)(1)(0)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010110 (1)(1)(0)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11010111 (1)(1)(0)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011000 (1)(1)(0)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011001 (1)(1)(0)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011010 (1)(1)(0)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011011 (1)(1)(0)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011100 (1)(1)(0)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011101 (1)(1)(0)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011110 (1)(1)(0)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11011111 (1)(1)(0)(1)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100000 (1)(1)(1)(0)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100001 (1)(1)(1)(0)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100010 (1)(1)(1)(0)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100011 (1)(1)(1)(0)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100100 (1)(1)(1)(0)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100101 (1)(1)(1)(0)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100110 (1)(1)(1)(0)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11100111 (1)(1)(1)(0)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101000 (1)(1)(1)(0)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101001 (1)(1)(1)(0)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101010 (1)(1)(1)(0)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101011 (1)(1)(1)(0)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101100 (1)(1)(1)(0)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101101 (1)(1)(1)(0)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101110 (1)(1)(1)(0)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11101111 (1)(1)(1)(0)(1)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110000 (1)(1)(1)(1)(0)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110001 (1)(1)(1)(1)(0)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110010 (1)(1)(1)(1)(0)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110011 (1)(1)(1)(1)(0)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110100 (1)(1)(1)(1)(0)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110101 (1)(1)(1)(1)(0)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110110 (1)(1)(1)(1)(0)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11110111 (1)(1)(1)(1)(0)(1)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111000 (1)(1)(1)(1)(1)(0)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111001 (1)(1)(1)(1)(1)(0)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111010 (1)(1)(1)(1)(1)(0)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111011 (1)(1)(1)(1)(1)(0)(1)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111100 (1)(1)(1)(1)(1)(1)(0)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111101 (1)(1)(1)(1)(1)(1)(0)(1),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111110 (1)(1)(1)(1)(1)(1)(1)(0),  | ||||
| #define BOOST_DETAIL_BINARY_LITERAL_ELEMENT_11111111 (1)(1)(1)(1)(1)(1)(1)(1),  | ||||
|  | ||||
| #endif | ||||
| @@ -1,12 +1,12 @@ | ||||
| // Boost enable_if library | ||||
|  | ||||
| // Copyright 2003 (c) The Trustees of Indiana University. | ||||
| // Copyright 2003 <EFBFBD> The Trustees of Indiana University. | ||||
|  | ||||
| // Use, modification, and distribution is subject to 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) | ||||
|  | ||||
| //    Authors: Jaakko Jarvi (jajarvi at osl.iu.edu) | ||||
| //    Authors: Jaakko J<EFBFBD>rvi (jajarvi at osl.iu.edu) | ||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) | ||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) | ||||
|  | ||||
|   | ||||
| @@ -70,8 +70,8 @@ struct result_of_nested_result : F::template result<FArgs> | ||||
| template<typename F, typename FArgs> | ||||
| struct result_of_impl<F, FArgs, false> | ||||
|   : mpl::if_<is_function_with_no_args<FArgs>, | ||||
|              result_of_void_impl<F>, | ||||
|              result_of_nested_result<F, FArgs> >::type | ||||
| 	     result_of_void_impl<F>, | ||||
| 	     result_of_nested_result<F, FArgs> >::type | ||||
| {}; | ||||
|  | ||||
| } // end namespace detail | ||||
|   | ||||
| @@ -1,55 +0,0 @@ | ||||
| // Copyright (C) 2007, 2008 Steven Watanabe, Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
| // For more information, see http://www.boost.org | ||||
|  | ||||
|  | ||||
| #ifndef BOOST_UTILITY_SWAP_HPP | ||||
| #define BOOST_UTILITY_SWAP_HPP | ||||
|  | ||||
| // Note: the implementation of this utility contains various workarounds: | ||||
| // - swap_impl is put outside the boost namespace, to avoid infinite | ||||
| // recursion (causing stack overflow) when swapping objects of a primitive | ||||
| // type. | ||||
| // - swap_impl has a using-directive, rather than a using-declaration, | ||||
| // because some compilers (including MSVC 7.1, Borland 5.9.3, and | ||||
| // Intel 8.1) don't do argument-dependent lookup when it has a | ||||
| // using-declaration instead. | ||||
| // - boost::swap has two template arguments, instead of one, to | ||||
| // avoid ambiguity when swapping objects of a Boost type that does | ||||
| // not have its own boost::swap overload. | ||||
|  | ||||
| #include <algorithm> //for std::swap | ||||
| #include <cstddef> //for std::size_t | ||||
|  | ||||
| namespace boost_swap_impl | ||||
| { | ||||
|   template<class T> | ||||
|   void swap_impl(T& left, T& right) | ||||
|   { | ||||
|     using namespace std;//use std::swap if argument dependent lookup fails | ||||
|     swap(left,right); | ||||
|   } | ||||
|  | ||||
|   template<class T, std::size_t N> | ||||
|   void swap_impl(T (& left)[N], T (& right)[N]) | ||||
|   { | ||||
|     for (std::size_t i = 0; i < N; ++i) | ||||
|     { | ||||
|       ::boost_swap_impl::swap_impl(left[i], right[i]); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| namespace boost | ||||
| { | ||||
|   template<class T1, class T2> | ||||
|   void swap(T1& left, T2& right) | ||||
|   { | ||||
|     ::boost_swap_impl::swap_impl(left, right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| #endif | ||||
| @@ -1,110 +1,166 @@ | ||||
| // (C) Copyright 2002-2008, Fernando Luis Cacciola Carballal. | ||||
| // (C) Copyright 2002-2007, Fernando Luis Cacciola Carballal. | ||||
| // | ||||
| // 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) | ||||
| // | ||||
| // 21 Ago 2002 (Created) Fernando Cacciola | ||||
| // 24 Dec 2007 (Refactored and worked around various compiler bugs) Fernando Cacciola, Niels Dekker | ||||
| // 23 May 2008 (Fixed operator= const issue, added initialized_value) Niels Dekker, Fernando Cacciola | ||||
| // 21 Ago 2008 (Added swap) Niels Dekker, Fernando Cacciola | ||||
| // 07 Set 2007 (Worked around MSVC++ bug) Fernando Cacciola, Niels Dekker | ||||
| // | ||||
| #ifndef BOOST_UTILITY_VALUE_INIT_21AGO2002_HPP | ||||
| #define BOOST_UTILITY_VALUE_INIT_21AGO2002_HPP | ||||
|  | ||||
| // Note: The implementation of boost::value_initialized had to deal with the | ||||
| // fact that various compilers haven't fully implemented value-initialization. | ||||
| // The constructor of boost::value_initialized<T> works around these compiler | ||||
| // issues, by clearing the bytes of T, before constructing the T object it | ||||
| // contains. More details on these issues are at libs/utility/value_init.htm | ||||
|  | ||||
| #include <boost/aligned_storage.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
| #include <boost/static_assert.hpp> | ||||
| #include <boost/detail/select_type.hpp> | ||||
| #include <boost/type_traits/cv_traits.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
|  | ||||
| #if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1500) ) | ||||
| // Microsoft Visual C++ does not correctly support value initialization, as reported by | ||||
| // Pavel Kuznetsov (MetaCommunications Engineering), 7/28/2005, Feedback ID 100744, | ||||
| // Feedback Title: Value-initialization in new-expression | ||||
| // https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=100744 | ||||
| // The report was closed at 11/14/2006, and its status was set to "Closed (Won't Fix)". | ||||
| // Luckily, even in the presence of this compiler bug, boost::value_initialized will still | ||||
| // do its job correctly, when using the following workaround: | ||||
| #define BOOST_UTILITY_VALUE_INIT_WORKAROUND | ||||
| #endif | ||||
|  | ||||
| #ifdef BOOST_UTILITY_VALUE_INIT_WORKAROUND | ||||
| #include <boost/aligned_storage.hpp> | ||||
| #include <boost/type_traits/alignment_of.hpp> | ||||
| #include <boost/swap.hpp> | ||||
| #include <cstring> | ||||
| #include <new> | ||||
|  | ||||
| namespace boost { | ||||
|  | ||||
| template<class T> | ||||
| class value_initialized | ||||
| { | ||||
|   private : | ||||
|     struct wrapper | ||||
|     { | ||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x592)) | ||||
|       typename | ||||
| #endif  | ||||
|       remove_const<T>::type data; | ||||
|     }; | ||||
|  | ||||
|     mutable | ||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x592)) | ||||
|       typename | ||||
| #endif  | ||||
|       aligned_storage<sizeof(wrapper), alignment_of<wrapper>::value>::type x; | ||||
|  | ||||
|     wrapper * wrapper_address() const | ||||
|     { | ||||
|       return static_cast<wrapper *>( static_cast<void*>(&x)); | ||||
|     } | ||||
|  | ||||
|   public : | ||||
|  | ||||
|     value_initialized() | ||||
|     { | ||||
|       std::memset(&x, 0, sizeof(x)); | ||||
| #ifdef BOOST_MSVC | ||||
| #pragma warning(push) | ||||
| #if _MSC_VER >= 1310 | ||||
| // When using MSVC 7.1 or higher, the following placement new expression may trigger warning C4345: | ||||
| // When using MSVC 7.1 or higher, placement new, "new (&x) T()", may trigger warning C4345: | ||||
| // "behavior change: an object of POD type constructed with an initializer of the form () | ||||
| // will be default-initialized".  It is safe to ignore this warning when using value_initialized. | ||||
| // will be default-initialized".  There is no need to worry about this, though. | ||||
| #pragma warning(disable: 4345) | ||||
| #endif | ||||
| #endif | ||||
|       new (wrapper_address()) wrapper(); | ||||
| #ifdef BOOST_MSVC | ||||
| #pragma warning(pop) | ||||
| #endif | ||||
|     } | ||||
|  | ||||
|     value_initialized(value_initialized const & arg) | ||||
| namespace boost { | ||||
|  | ||||
| namespace vinit_detail { | ||||
|  | ||||
| template<class T> | ||||
| class const_T_base | ||||
| { | ||||
|   protected : | ||||
|  | ||||
|     const_T_base() | ||||
|     { | ||||
|       new (wrapper_address()) wrapper( static_cast<wrapper const &>(*(arg.wrapper_address()))); | ||||
|       std::memset(&x, 0, sizeof(x)); | ||||
|       new (&x) T(); | ||||
|     } | ||||
|  | ||||
|     value_initialized & operator=(value_initialized const & arg) | ||||
|     ~const_T_base() | ||||
|     { | ||||
|       // Assignment is only allowed when T is non-const. | ||||
|       BOOST_STATIC_ASSERT( ! is_const<T>::value ); | ||||
|       *wrapper_address() = static_cast<wrapper const &>(*(arg.wrapper_address())); | ||||
|       return *this; | ||||
|       void const * ptr = &x; | ||||
|       static_cast<T*>(ptr)->T::~T(); | ||||
|     } | ||||
|  | ||||
|     ~value_initialized() | ||||
|     T & get() const | ||||
|     { | ||||
|       wrapper_address()->wrapper::~wrapper(); | ||||
|       void const * ptr = &x; | ||||
|       return *static_cast<T*>(ptr); | ||||
|     } | ||||
|  | ||||
|     T& data() const | ||||
|     { | ||||
|       return wrapper_address()->data; | ||||
|     } | ||||
|  | ||||
|     void swap(value_initialized & arg) | ||||
|     { | ||||
|       ::boost::swap( this->data(), arg.data() ); | ||||
|     } | ||||
|  | ||||
|     operator T&() const { return this->data(); } | ||||
|  | ||||
|   private : | ||||
|     typename ::boost::aligned_storage<sizeof(T), ::boost::alignment_of<T>::value>::type x; | ||||
| } ; | ||||
|  | ||||
| template<class T> | ||||
| class non_const_T_base | ||||
| { | ||||
|   protected : | ||||
|  | ||||
|     non_const_T_base() | ||||
|     { | ||||
|       std::memset(&x, 0, sizeof(x)); | ||||
|       new (&x) T(); | ||||
|     } | ||||
|  | ||||
|     ~non_const_T_base() | ||||
|     { | ||||
|       void * ptr = &x; | ||||
|       static_cast<T*>(ptr)->T::~T(); | ||||
|     } | ||||
|  | ||||
|     T & get() const | ||||
|     {  | ||||
|       void * ptr = &x; | ||||
|       return *static_cast<T*>(ptr); | ||||
|     } | ||||
|  | ||||
|   private : | ||||
|     mutable typename ::boost::aligned_storage<sizeof(T), ::boost::alignment_of<T>::value>::type x; | ||||
| } ; | ||||
|  | ||||
| #ifdef BOOST_MSVC | ||||
| // Restores the state of warning C4345. | ||||
| #pragma warning(pop) | ||||
| #endif | ||||
|  | ||||
| #else | ||||
|  | ||||
| namespace boost { | ||||
|  | ||||
| namespace vinit_detail { | ||||
|  | ||||
| template<class T> | ||||
| class const_T_base | ||||
| { | ||||
|   protected : | ||||
|  | ||||
|    const_T_base() : x() {} | ||||
|    T & get() const { return x; } | ||||
|  | ||||
|   private : | ||||
|    T x ; | ||||
| } ; | ||||
|  | ||||
| template<class T> | ||||
| class non_const_T_base | ||||
| { | ||||
|   protected : | ||||
|  | ||||
|    non_const_T_base() : x() {} | ||||
|    T & get() const { return x; } | ||||
|  | ||||
|   private : | ||||
|    mutable T x ; | ||||
| } ; | ||||
|  | ||||
| #endif | ||||
|  | ||||
| template<class T> | ||||
| struct select_base | ||||
| { | ||||
|   typedef | ||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) | ||||
|   typename | ||||
| #endif  | ||||
|     ::boost::detail::if_true< ::boost::is_const<T>::value > | ||||
|       ::template then< const_T_base<T>, non_const_T_base<T> >::type type ; | ||||
| } ; | ||||
|  | ||||
| } // namespace vinit_detail | ||||
|  | ||||
| template<class T> | ||||
| class value_initialized : private vinit_detail::select_base<T>::type | ||||
| { | ||||
|   public : | ||||
|  | ||||
|     value_initialized() {} | ||||
|  | ||||
|     operator T&() const { return this->get(); } | ||||
|  | ||||
|     T& data() const { return this->get(); } | ||||
|  | ||||
| } ; | ||||
|  | ||||
| template<class T> | ||||
| T const& get ( value_initialized<T> const& x ) | ||||
| @@ -117,27 +173,8 @@ T& get ( value_initialized<T>& x ) | ||||
|   return x.data() ; | ||||
| } | ||||
|  | ||||
| template<class T> | ||||
| void swap ( value_initialized<T> & lhs, value_initialized<T> & rhs ) | ||||
| { | ||||
|   lhs.swap(rhs) ; | ||||
| } | ||||
|  | ||||
|  | ||||
| class initialized_value_t | ||||
| { | ||||
|   public : | ||||
|      | ||||
|     template <class T> operator T() const | ||||
|     { | ||||
|       return get( value_initialized<T>() ); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| initialized_value_t const initialized_value = {} ; | ||||
|  | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
|  | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -21,15 +21,14 @@ | ||||
| 				<a href="compressed_pair.htm">compressed_pair</a><br> | ||||
| 				<a href="current_function.html">current_function</a><br> | ||||
| 				<a href="enable_if.html">enable_if</a><br> | ||||
|             <a href="iterator_adaptors.htm">iterator_adaptors</a><br> | ||||
|             <a href="generator_iterator.htm">generator iterator adaptors</a><br> | ||||
|                 <a href="iterator_adaptors.htm">iterator_adaptors</a><br> | ||||
| 				<a href="operators.htm">operators</a><br> | ||||
| 				<a href="throw_exception.html">throw_exception</a><br> | ||||
| 				<a href="utility.htm">utility</a><br> | ||||
|                 <a href="value_init.htm">value_init</a></p> | ||||
| 		</blockquote> | ||||
| 		<hr> | ||||
| 		<p>© Copyright Beman Dawes, 2001</p> | ||||
| 		<p><EFBFBD> Copyright Beman Dawes, 2001</p> | ||||
|         <p>Distributed under the Boost Software License, Version 1.0. (See  | ||||
|         accompanying file <a href="../../LICENSE_1_0.txt"> | ||||
|         LICENSE_1_0.txt</a> or copy at | ||||
|   | ||||
| @@ -1 +0,0 @@ | ||||
| boost_module(utility DEPENDS iterator exception detail ) | ||||
							
								
								
									
										103
									
								
								operators.htm
									
									
									
									
									
								
							
							
						
						
									
										103
									
								
								operators.htm
									
									
									
									
									
								
							| @@ -132,18 +132,18 @@ | ||||
| class MyInt | ||||
|     : boost::operators<MyInt> | ||||
| { | ||||
|     bool operator<(const MyInt& x) const; | ||||
|     bool operator<(const MyInt& x) const;  | ||||
|     bool operator==(const MyInt& x) const; | ||||
|     MyInt& operator+=(const MyInt& x); | ||||
|     MyInt& operator-=(const MyInt& x); | ||||
|     MyInt& operator*=(const MyInt& x); | ||||
|     MyInt& operator/=(const MyInt& x); | ||||
|     MyInt& operator%=(const MyInt& x); | ||||
|     MyInt& operator|=(const MyInt& x); | ||||
|     MyInt& operator&=(const MyInt& x); | ||||
|     MyInt& operator^=(const MyInt& x); | ||||
|     MyInt& operator++(); | ||||
|     MyInt& operator--(); | ||||
|     MyInt& operator+=(const MyInt& x);     | ||||
|     MyInt& operator-=(const MyInt& x);     | ||||
|     MyInt& operator*=(const MyInt& x);     | ||||
|     MyInt& operator/=(const MyInt& x);     | ||||
|     MyInt& operator%=(const MyInt& x);     | ||||
|     MyInt& operator|=(const MyInt& x);     | ||||
|     MyInt& operator&=(const MyInt& x);     | ||||
|     MyInt& operator^=(const MyInt& x);     | ||||
|     MyInt& operator++();     | ||||
|     MyInt& operator--();     | ||||
| }; | ||||
| </pre> | ||||
|     </blockquote> | ||||
| @@ -345,7 +345,7 @@ class MyInt | ||||
|     </ul> | ||||
|  | ||||
|     <p>As Daniel Krügler pointed out, this technique violates 14.6.5/2 | ||||
|     and is thus non-portable. The reasoning is, that the operators injected | ||||
|     and is thus non-portable. The reasoning is, that the operators injected  | ||||
|     by the instantiation of e.g. | ||||
|     <code>less_than_comparable<myclass></code> can not be found | ||||
|     by ADL according to the rules given by 3.4.2/2, since myclass is | ||||
| @@ -445,9 +445,6 @@ const point<float> pi_over_4_normalized = pi_over_4 / length(pi_over_4); | ||||
|     optional template parameter <code>B</code>, which is not shown, for the | ||||
|     <a href="#chaining">base class chaining</a> technique.</p> | ||||
|  | ||||
|     <p>The primary operand type <code>T</code> needs to be of class type, | ||||
|     built-in types are not supported.</p> | ||||
|  | ||||
|     <table cellpadding="5" border="1" align="center"> | ||||
|       <caption> | ||||
|         Simple Arithmetic Operator Template Classes | ||||
| @@ -920,7 +917,7 @@ T operator+( const T& lhs, const T& rhs ) | ||||
|     created, <code>operator+=</code> is called on it and it is copied to the | ||||
|     function return value (which is another unnamed object of type | ||||
|     <code>T</code>). The standard doesn't generally allow the intermediate | ||||
|     object to be optimized away: | ||||
|     object to be optimized away:  | ||||
|  | ||||
|     <blockquote> | ||||
|       3.7.2/2: Automatic storage duration<br> | ||||
| @@ -931,7 +928,7 @@ T operator+( const T& lhs, const T& rhs ) | ||||
|       unused, except that a class object or its copy may be eliminated as | ||||
|       specified in 12.8. | ||||
|     </blockquote> | ||||
|     The reference to 12.8 is important for us: | ||||
|     The reference to 12.8 is important for us:  | ||||
|  | ||||
|     <blockquote> | ||||
|       12.8/15: Copying class objects<br> | ||||
| @@ -945,7 +942,7 @@ T operator+( const T& lhs, const T& rhs ) | ||||
|     </blockquote> | ||||
|     This optimization is known as the named return value optimization (NRVO), | ||||
|     which leads us to the following implementation for | ||||
|     <code>operator+</code>: | ||||
|     <code>operator+</code>:  | ||||
| <pre> | ||||
| T operator+( const T& lhs, const T& rhs ) | ||||
| { | ||||
| @@ -959,7 +956,7 @@ T operator+( const T& lhs, const T& rhs ) | ||||
|     even implement it in an incorrect way which makes it useless here. | ||||
|     Without the NRVO, the NRVO-friendly code is no worse than the original | ||||
|     code showed above, but there is another possible implementation, which | ||||
|     has some very special properties: | ||||
|     has some very special properties:  | ||||
| <pre> | ||||
| T operator+( T lhs, const T& rhs ) | ||||
| { | ||||
| @@ -985,7 +982,7 @@ T operator+( T lhs, const T& rhs ) | ||||
|     will force the NRVO-friendly implementation to be used even for compilers | ||||
|     that don't implement the NRVO. <br> | ||||
|      <br> | ||||
|  | ||||
|       | ||||
|     <h3><a name="grpd_oprs">Grouped Arithmetic Operators</a></h3> | ||||
|  | ||||
|     <p>The following templates provide common groups of related operations. | ||||
| @@ -1423,9 +1420,9 @@ T operator+( T lhs, const T& rhs ) | ||||
|  | ||||
|       <tr> | ||||
|         <td><code><a name= | ||||
|         "euclidean_ring_operators1">euclidean_ring_operators<T></a></code><br> | ||||
|         "euclidian_ring_operators1">euclidian_ring_operators<T></a></code><br> | ||||
|  | ||||
|          <code>euclidean_ring_operators1<T></code></td> | ||||
|          <code>euclidian_ring_operators1<T></code></td> | ||||
|  | ||||
|         <td> | ||||
|           <ul> | ||||
| @@ -1442,9 +1439,9 @@ T operator+( T lhs, const T& rhs ) | ||||
|  | ||||
|       <tr> | ||||
|         <td><code><a name= | ||||
|         "euclidean_ring_operators2">euclidean_ring_operators<T, | ||||
|         "euclidian_ring_operators2">euclidian_ring_operators<T, | ||||
|         U></a></code><br> | ||||
|          <code>euclidean_ring_operators2<T, U></code></td> | ||||
|          <code>euclidian_ring_operators2<T, U></code></td> | ||||
|  | ||||
|         <td> | ||||
|           <ul> | ||||
| @@ -1467,14 +1464,14 @@ T operator+( T lhs, const T& rhs ) | ||||
|  | ||||
|       <tr> | ||||
|         <td><code><a name= | ||||
|         "ordered_euclidean_ring_operators1">ordered_euclidean_ring_operators<T></a></code><br> | ||||
|         "ordered_euclidian_ring_operators1">ordered_euclidian_ring_operators<T></a></code><br> | ||||
|  | ||||
|          <code>ordered_euclidean_ring_operators1<T></code></td> | ||||
|          <code>ordered_euclidian_ring_operators1<T></code></td> | ||||
|  | ||||
|         <td> | ||||
|           <ul> | ||||
|             <li><code><a href= | ||||
|             "#euclidean_ring_operators1">euclidean_ring_operators<T></a></code></li> | ||||
|             "#euclidian_ring_operators1">euclidian_ring_operators<T></a></code></li> | ||||
|  | ||||
|             <li><code><a href= | ||||
|             "#totally_ordered1">totally_ordered<T></a></code></li> | ||||
| @@ -1484,14 +1481,14 @@ T operator+( T lhs, const T& rhs ) | ||||
|  | ||||
|       <tr> | ||||
|         <td><code><a name= | ||||
|         "ordered_euclidean_ring_operators2">ordered_euclidean_ring_operators<T, | ||||
|         "ordered_euclidian_ring_operators2">ordered_euclidian_ring_operators<T, | ||||
|         U></a></code><br> | ||||
|          <code>ordered_euclidean_ring_operators2<T, U></code></td> | ||||
|          <code>ordered_euclidian_ring_operators2<T, U></code></td> | ||||
|  | ||||
|         <td> | ||||
|           <ul> | ||||
|             <li><code><a href= | ||||
|             "#euclidean_ring_operators2">euclidean_ring_operators<T, | ||||
|             "#euclidian_ring_operators2">euclidian_ring_operators<T, | ||||
|             U></a></code></li> | ||||
|  | ||||
|             <li><code><a href="#totally_ordered2">totally_ordered<T, | ||||
| @@ -1501,15 +1498,6 @@ T operator+( T lhs, const T& rhs ) | ||||
|       </tr> | ||||
|     </table> | ||||
|  | ||||
|     <h4>Spelling: euclidean vs. euclidian</h4> | ||||
|  | ||||
|     <p>Older versions of the Boost.Operators library used | ||||
|     "<code>euclidian</code>", but it was pointed out that | ||||
|     "<code>euclidean</code>" is the more common spelling. | ||||
|     To be compatible with older version, the library now supports | ||||
|     both spellings. | ||||
|     </p> | ||||
|  | ||||
|     <h3><a name="ex_oprs">Example</a> Templates</h3> | ||||
|  | ||||
|     <p>The arithmetic operator class templates <code><a href= | ||||
| @@ -1588,8 +1576,9 @@ T operator+( T lhs, const T& rhs ) | ||||
|  | ||||
|     <p>The <cite><a href="operators_test.cpp">operators_test.cpp</a></cite> | ||||
|     program demonstrates the use of the arithmetic operator templates, and | ||||
|     can also be used to verify correct operation. Check the compiler status | ||||
|     report for the test results with selected platforms.</p> | ||||
|     can also be used to verify correct operation. Check the <a href= | ||||
|     "../../status/compiler_status.html">compiler status report</a> for the | ||||
|     test results with selected platforms.</p> | ||||
|  | ||||
|     <h2><a name="deref">Dereference</a> Operators and Iterator Helpers</h2> | ||||
|  | ||||
| @@ -1867,7 +1856,7 @@ T operator+( T lhs, const T& rhs ) | ||||
|         V, D, P, R></a></code></td> | ||||
|  | ||||
|         <td> | ||||
|           Supports the operations and has the requirements of | ||||
|           Supports the operations and has the requirements of  | ||||
|  | ||||
|           <ul> | ||||
|             <li><code><a href="#input_iteratable">input_iteratable<T, | ||||
| @@ -1881,7 +1870,7 @@ T operator+( T lhs, const T& rhs ) | ||||
|         "output_iterator_helper">output_iterator_helper<T></a></code></td> | ||||
|  | ||||
|         <td> | ||||
|           Supports the operations and has the requirements of | ||||
|           Supports the operations and has the requirements of  | ||||
|  | ||||
|           <ul> | ||||
|             <li><code><a href= | ||||
| @@ -1897,7 +1886,7 @@ T operator+( T lhs, const T& rhs ) | ||||
|         R></a></code></td> | ||||
|  | ||||
|         <td> | ||||
|           Supports the operations and has the requirements of | ||||
|           Supports the operations and has the requirements of  | ||||
|  | ||||
|           <ul> | ||||
|             <li><code><a href="#forward_iteratable">forward_iteratable<T, | ||||
| @@ -1912,7 +1901,7 @@ T operator+( T lhs, const T& rhs ) | ||||
|         V, D, P, R></a></code></td> | ||||
|  | ||||
|         <td> | ||||
|           Supports the operations and has the requirements of | ||||
|           Supports the operations and has the requirements of  | ||||
|  | ||||
|           <ul> | ||||
|             <li><code><a href= | ||||
| @@ -1928,7 +1917,7 @@ T operator+( T lhs, const T& rhs ) | ||||
|         V, D, P, R></a></code></td> | ||||
|  | ||||
|         <td> | ||||
|           Supports the operations and has the requirements of | ||||
|           Supports the operations and has the requirements of  | ||||
|  | ||||
|           <ul> | ||||
|             <li><code><a href= | ||||
| @@ -1979,8 +1968,8 @@ struct function_output_iterator | ||||
|     template<typename T> | ||||
|     function_output_iterator& operator=(T const& value) | ||||
|     { | ||||
|         this->func(value); | ||||
|         return *this; | ||||
|         this->func(value);  | ||||
|         return *this;  | ||||
|     } | ||||
|  | ||||
|  private: | ||||
| @@ -2033,20 +2022,20 @@ public: | ||||
| </pre> | ||||
|     </blockquote> | ||||
|  | ||||
|     <p>Check the <a href="http://www.boost.org/development/testing.html">compiler status | ||||
|     <p>Check the <a href="../../status/compiler_status.html">compiler status | ||||
|     report</a> for the test results with selected platforms.</p> | ||||
|     <hr> | ||||
|  | ||||
|     <h2><a name="contributors">Contributors</a></h2> | ||||
|  | ||||
|     <dl> | ||||
|       <dt><a href="http://www.boost.org/people/dave_abrahams.htm">Dave Abrahams</a></dt> | ||||
|       <dt><a href="../../people/dave_abrahams.htm">Dave Abrahams</a></dt> | ||||
|  | ||||
|       <dd>Started the library and contributed the arithmetic operators in | ||||
|       <cite><a href= | ||||
|       "../../boost/operators.hpp">boost/operators.hpp</a></cite>.</dd> | ||||
|  | ||||
|       <dt><a href="http://www.boost.org/people/jeremy_siek.htm">Jeremy Siek</a></dt> | ||||
|       <dt><a href="../../people/jeremy_siek.htm">Jeremy Siek</a></dt> | ||||
|  | ||||
|       <dd>Contributed the <a href="#deref">dereference operators and iterator | ||||
|       helpers</a> in <cite><a href= | ||||
| @@ -2054,19 +2043,19 @@ public: | ||||
|       contributed <cite><a href= | ||||
|       "iterators_test.cpp">iterators_test.cpp</a></cite>.</dd> | ||||
|  | ||||
|       <dt><a href="http://www.boost.org/people/aleksey_gurtovoy.htm">Aleksey | ||||
|       <dt><a href="../../people/aleksey_gurtovoy.htm">Aleksey | ||||
|       Gurtovoy</a></dt> | ||||
|  | ||||
|       <dd>Contributed the code to support <a href="#chaining">base class | ||||
|       chaining</a> while remaining backward-compatible with old versions of | ||||
|       the library.</dd> | ||||
|  | ||||
|       <dt><a href="http://www.boost.org/people/beman_dawes.html">Beman Dawes</a></dt> | ||||
|       <dt><a href="../../people/beman_dawes.html">Beman Dawes</a></dt> | ||||
|  | ||||
|       <dd>Contributed <cite><a href= | ||||
|       "operators_test.cpp">operators_test.cpp</a></cite>.</dd> | ||||
|  | ||||
|       <dt><a href="http://www.boost.org/people/daryle_walker.html">Daryle Walker</a></dt> | ||||
|       <dt><a href="../../people/daryle_walker.html">Daryle Walker</a></dt> | ||||
|  | ||||
|       <dd>Contributed classes for the shift operators, equivalence, partial | ||||
|       ordering, and arithmetic conversions. Added the grouped operator | ||||
| @@ -2130,11 +2119,11 @@ public: | ||||
|     backward-compatible.</p> | ||||
|     <hr> | ||||
|  | ||||
|     <p>Revised: 7 Aug 2008</p> | ||||
|     <p>Revised: 29 Oct 2004</p> | ||||
|  | ||||
|     <p>Copyright © Beman Dawes, David Abrahams, 1999-2001.</p> | ||||
|     <p>Copyright © Daniel Frey, 2002-2009.</p> | ||||
|     <p>Use, modification, and distribution is subject to the Boost Software | ||||
|     <p>Copyright © Daniel Frey, 2002-2004.</p> | ||||
|     <p>Use, modification, and distribution is subject to the Boost Software  | ||||
|     License, Version 1.0. (See accompanying file | ||||
|     <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or copy at | ||||
|     <a href="http://www.boost.org/LICENSE_1_0.txt"> | ||||
|   | ||||
| @@ -7,7 +7,6 @@ | ||||
| //  See http://www.boost.org/libs/utility for documentation. | ||||
|  | ||||
| //  Revision History | ||||
| //  03 Apr 08 Added convertible_to_bool (Daniel Frey) | ||||
| //  01 Oct 01 Added tests for "left" operators | ||||
| //            and new grouped operators. (Helmut Zeisel) | ||||
| //  20 May 01 Output progress messages.  Added tests for new operator | ||||
| @@ -44,23 +43,6 @@ namespace | ||||
|     unsigned char true_value(unsigned char x) { return x; } | ||||
|     unsigned short true_value(unsigned short x) { return x; } | ||||
|  | ||||
|     // verify the minimum requirements for some operators | ||||
|     class convertible_to_bool | ||||
|     { | ||||
|     private: | ||||
|         bool _value; | ||||
|  | ||||
|         typedef bool convertible_to_bool::*unspecified_bool_type; | ||||
|  | ||||
|         void operator!() const; | ||||
|  | ||||
|     public: | ||||
|         convertible_to_bool( const bool value ) : _value( value ) {} | ||||
|  | ||||
|         operator unspecified_bool_type() const | ||||
|           { return _value ? &convertible_to_bool::_value : 0; } | ||||
|     }; | ||||
|  | ||||
|     // The use of operators<> here tended to obscure | ||||
|     // interactions with certain compiler bugs | ||||
|     template <class T> | ||||
| @@ -72,10 +54,8 @@ namespace | ||||
|         explicit Wrapped1( T v = T() ) : _value(v) {} | ||||
|         T value() const { return _value; } | ||||
|  | ||||
|         convertible_to_bool operator<(const Wrapped1& x) const | ||||
|           { return _value < x._value; } | ||||
|         convertible_to_bool operator==(const Wrapped1& x) const | ||||
|           { return _value == x._value; } | ||||
|         bool operator<(const Wrapped1& x) const { return _value < x._value; } | ||||
|         bool operator==(const Wrapped1& x) const { return _value == x._value; } | ||||
|          | ||||
|         Wrapped1& operator+=(const Wrapped1& x) | ||||
|           { _value += x._value; return *this; } | ||||
| @@ -117,10 +97,8 @@ namespace | ||||
|         explicit Wrapped2( T v = T() ) : _value(v) {} | ||||
|         T value() const { return _value; } | ||||
|  | ||||
|         convertible_to_bool operator<(const Wrapped2& x) const | ||||
|           { return _value < x._value; } | ||||
|         convertible_to_bool operator==(const Wrapped2& x) const | ||||
|           { return _value == x._value; } | ||||
|         bool operator<(const Wrapped2& x) const { return _value < x._value; } | ||||
|         bool operator==(const Wrapped2& x) const { return _value == x._value; } | ||||
|          | ||||
|         Wrapped2& operator+=(const Wrapped2& x) | ||||
|           { _value += x._value; return *this; } | ||||
| @@ -145,13 +123,9 @@ namespace | ||||
|         Wrapped2& operator++()                { ++_value; return *this; } | ||||
|         Wrapped2& operator--()                { --_value; return *this; } | ||||
|           | ||||
|         convertible_to_bool operator<(U u) const | ||||
|           { return _value < u; } | ||||
|         convertible_to_bool operator>(U u) const | ||||
|           { return _value > u; } | ||||
|         convertible_to_bool operator==(U u) const | ||||
|           { return _value == u; } | ||||
|  | ||||
|         bool operator<(U u) const { return _value < u; } | ||||
|         bool operator>(U u) const { return _value > u; } | ||||
|         bool operator==(U u) const { return _value == u; } | ||||
|         Wrapped2& operator+=(U u) { _value += u; return *this; } | ||||
|         Wrapped2& operator-=(U u) { _value -= u; return *this; } | ||||
|         Wrapped2& operator*=(U u) { _value *= u; return *this; } | ||||
| @@ -179,8 +153,7 @@ namespace | ||||
|         explicit Wrapped3( T v = T() ) : _value(v) {} | ||||
|         T value() const { return _value; } | ||||
|  | ||||
|         convertible_to_bool operator<(const Wrapped3& x) const | ||||
|           { return _value < x._value; } | ||||
|         bool operator<(const Wrapped3& x) const { return _value < x._value; } | ||||
|          | ||||
|     private: | ||||
|         T _value; | ||||
| @@ -201,13 +174,10 @@ namespace | ||||
|         explicit Wrapped4( T v = T() ) : _value(v) {} | ||||
|         T value() const { return _value; } | ||||
|  | ||||
|         convertible_to_bool operator<(const Wrapped4& x) const | ||||
|           { return _value < x._value; } | ||||
|         bool operator<(const Wrapped4& x) const { return _value < x._value; } | ||||
|           | ||||
|         convertible_to_bool operator<(U u) const | ||||
|           { return _value < u; } | ||||
|         convertible_to_bool operator>(U u) const | ||||
|           { return _value > u; } | ||||
|         bool operator<(U u) const { return _value < u; } | ||||
|         bool operator>(U u) const { return _value > u; } | ||||
|  | ||||
|     private: | ||||
|         T _value; | ||||
| @@ -228,18 +198,11 @@ namespace | ||||
|         Wrapped5(U u) : _value(u) {} | ||||
|  | ||||
|         T value() const { return _value; } | ||||
|  | ||||
|         convertible_to_bool operator<(const Wrapped5& x) const | ||||
|           { return _value < x._value; } | ||||
|         convertible_to_bool operator<(U u) const | ||||
|           { return _value < u; } | ||||
|         convertible_to_bool operator>(U u) const | ||||
|           { return _value > u; } | ||||
|         convertible_to_bool operator==(const Wrapped5& u) const | ||||
|           { return _value == u._value; } | ||||
|         convertible_to_bool operator==(U u) const | ||||
|           { return _value == u; } | ||||
|  | ||||
|         bool operator<(const Wrapped5& x) const { return _value < x._value; } | ||||
|         bool operator<(U u) const { return _value < u; } | ||||
|         bool operator>(U u) const { return _value > u; } | ||||
|         bool operator==(const Wrapped5& u) const { return _value == u._value; } | ||||
|         bool operator==(U u) const { return _value == u; } | ||||
|         Wrapped5& operator/=(const Wrapped5& u) { _value /= u._value; return *this;} | ||||
|         Wrapped5& operator/=(U u) { _value /= u; return *this;} | ||||
|         Wrapped5& operator*=(const Wrapped5& u) { _value *= u._value; return *this;} | ||||
| @@ -258,8 +221,8 @@ namespace | ||||
|     // U must be convertible to T | ||||
|     template <class T, class U> | ||||
|     class Wrapped6 | ||||
|         : boost::ordered_euclidean_ring_operators2<Wrapped6<T, U>, U> | ||||
|         , boost::ordered_euclidean_ring_operators1<Wrapped6<T, U> > | ||||
|         : boost::ordered_euclidian_ring_operators2<Wrapped6<T, U>, U> | ||||
|         , boost::ordered_euclidian_ring_operators1<Wrapped6<T, U> > | ||||
|     { | ||||
|     public: | ||||
|         explicit Wrapped6( T v = T() ) : _value(v) {} | ||||
| @@ -268,18 +231,11 @@ namespace | ||||
|         Wrapped6(U u) : _value(u) {} | ||||
|  | ||||
|         T value() const { return _value; } | ||||
|  | ||||
|         convertible_to_bool operator<(const Wrapped6& x) const | ||||
|           { return _value < x._value; } | ||||
|         convertible_to_bool operator<(U u) const | ||||
|           { return _value < u; } | ||||
|         convertible_to_bool operator>(U u) const | ||||
|           { return _value > u; } | ||||
|         convertible_to_bool operator==(const Wrapped6& u) const | ||||
|           { return _value == u._value; } | ||||
|         convertible_to_bool operator==(U u) const | ||||
|           { return _value == u; } | ||||
|  | ||||
|         bool operator<(const Wrapped6& x) const { return _value < x._value; } | ||||
|         bool operator<(U u) const { return _value < u; } | ||||
|         bool operator>(U u) const { return _value > u; } | ||||
|         bool operator==(const Wrapped6& u) const { return _value == u._value; } | ||||
|         bool operator==(U u) const { return _value == u; } | ||||
|         Wrapped6& operator%=(const Wrapped6& u) { _value %= u._value; return *this;} | ||||
|         Wrapped6& operator%=(U u) { _value %= u; return *this;} | ||||
|         Wrapped6& operator/=(const Wrapped6& u) { _value /= u._value; return *this;} | ||||
| @@ -320,10 +276,10 @@ namespace | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
|     void test_less_than_comparable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||
|     { | ||||
|         BOOST_CHECK( static_cast<bool>(x1 < y1) == static_cast<bool>(x2 < y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 <= y1) == static_cast<bool>(x2 <= y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 >= y1) == static_cast<bool>(x2 >= y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 > y1) == static_cast<bool>(x2 > y2) ); | ||||
|         BOOST_CHECK( (x1 < y1) == (x2 < y2) ); | ||||
|         BOOST_CHECK( (x1 <= y1) == (x2 <= y2) ); | ||||
|         BOOST_CHECK( (x1 >= y1) == (x2 >= y2) ); | ||||
|         BOOST_CHECK( (x1 > y1) == (x2 > y2) ); | ||||
|     } | ||||
|      | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
| @@ -337,8 +293,8 @@ namespace | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
|     void test_equality_comparable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||
|     { | ||||
|         BOOST_CHECK( static_cast<bool>(x1 == y1) == static_cast<bool>(x2 == y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 != y1) == static_cast<bool>(x2 != y2) ); | ||||
|         BOOST_CHECK( (x1 == y1) == (x2 == y2) ); | ||||
|         BOOST_CHECK( (x1 != y1) == (x2 != y2) ); | ||||
|     } | ||||
|      | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
| @@ -658,14 +614,14 @@ test_main( int , char * [] ) | ||||
|  | ||||
|     PRIVATE_EXPR_TEST( (i = i2), (i.value() == 2) ); | ||||
|  | ||||
|     BOOST_CHECK( static_cast<bool>(i2 == i) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i1 != i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i1 <  i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i1 <= i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i <= i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i2 >  i1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i2 >= i1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i2 >= i) ); | ||||
|     BOOST_CHECK( i2 == i ); | ||||
|     BOOST_CHECK( i1 != i2 ); | ||||
|     BOOST_CHECK( i1 <  i2 ); | ||||
|     BOOST_CHECK( i1 <= i2 ); | ||||
|     BOOST_CHECK( i <= i2 ); | ||||
|     BOOST_CHECK( i2 >  i1 ); | ||||
|     BOOST_CHECK( i2 >= i1 ); | ||||
|     BOOST_CHECK( i2 >= i ); | ||||
|  | ||||
|     PRIVATE_EXPR_TEST( (i = i1 + i2), (i.value() == 3) ); | ||||
|     PRIVATE_EXPR_TEST( (i = i + i2), (i.value() == 5) ); | ||||
| @@ -697,78 +653,78 @@ test_main( int , char * [] ) | ||||
|  | ||||
|     PRIVATE_EXPR_TEST( (j = j2), (j.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(j2 == j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j == j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 != j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 != 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 != j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <  j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <  j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <  2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <= j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j <= 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >  j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >  j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >  1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= 2) ); | ||||
|     BOOST_CHECK( j2 == j ); | ||||
|     BOOST_CHECK( 2 == j ); | ||||
|     BOOST_CHECK( j2 == 2 );     | ||||
|     BOOST_CHECK( j == j2 ); | ||||
|     BOOST_CHECK( j1 != j2 ); | ||||
|     BOOST_CHECK( j1 != 2 ); | ||||
|     BOOST_CHECK( 1 != j2 ); | ||||
|     BOOST_CHECK( j1 <  j2 ); | ||||
|     BOOST_CHECK( 1 <  j2 ); | ||||
|     BOOST_CHECK( j1 <  2 ); | ||||
|     BOOST_CHECK( j1 <= j2 ); | ||||
|     BOOST_CHECK( 1 <= j2 ); | ||||
|     BOOST_CHECK( j1 <= j ); | ||||
|     BOOST_CHECK( j <= j2 ); | ||||
|     BOOST_CHECK( 2 <= j2 ); | ||||
|     BOOST_CHECK( j <= 2 ); | ||||
|     BOOST_CHECK( j2 >  j1 ); | ||||
|     BOOST_CHECK( 2 >  j1 ); | ||||
|     BOOST_CHECK( j2 >  1 ); | ||||
|     BOOST_CHECK( j2 >= j1 ); | ||||
|     BOOST_CHECK( 2 >= j1 ); | ||||
|     BOOST_CHECK( j2 >= 1 ); | ||||
|     BOOST_CHECK( j2 >= j ); | ||||
|     BOOST_CHECK( 2 >= j ); | ||||
|     BOOST_CHECK( j2 >= 2 ); | ||||
|  | ||||
|     BOOST_CHECK( static_cast<bool>((j1 + 2) == 3) ); | ||||
|     BOOST_CHECK( static_cast<bool>((1 + j2) == 3) ); | ||||
|     BOOST_CHECK( (j1 + 2) == 3 ); | ||||
|     BOOST_CHECK( (1 + j2) == 3 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j1 + j2), (j.value() == 3) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j + 2) == 5) ); | ||||
|     BOOST_CHECK( static_cast<bool>((3 + j2) == 5) ); | ||||
|     BOOST_CHECK( (j + 2) == 5 ); | ||||
|     BOOST_CHECK( (3 + j2) == 5 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j + j2), (j.value() == 5) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j - 1) == 4) ); | ||||
|     BOOST_CHECK( (j - 1) == 4 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j - j1), (j.value() == 4) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j * 2) == 8) ); | ||||
|     BOOST_CHECK( static_cast<bool>((4 * j2) == 8) ); | ||||
|     BOOST_CHECK( (j * 2) == 8 ); | ||||
|     BOOST_CHECK( (4 * j2) == 8 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j * j2), (j.value() == 8) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j / 2) == 4) ); | ||||
|     BOOST_CHECK( (j / 2) == 4 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j / j2), (j.value() == 4) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j % 3) == 1) ); | ||||
|     BOOST_CHECK( (j % 3) == 1 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j % ( j - j1 )), (j.value() == 1) ); | ||||
|      | ||||
|     PRIVATE_EXPR_TEST( (j = j2 + j2), (j.value() == 4) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((1 | j2 | j) == 7) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j1 | 2 | j) == 7) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j1 | j2 | 4) == 7) ); | ||||
|     BOOST_CHECK( (1 | j2 | j) == 7 ); | ||||
|     BOOST_CHECK( (j1 | 2 | j) == 7 ); | ||||
|     BOOST_CHECK( (j1 | j2 | 4) == 7 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j1 | j2 | j), (j.value() == 7) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((7 & j2) == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j & 2) == 2) ); | ||||
|     BOOST_CHECK( (7 & j2) == 2 ); | ||||
|     BOOST_CHECK( (j & 2) == 2 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j & j2), (j.value() == 2) ); | ||||
|      | ||||
|     PRIVATE_EXPR_TEST( (j = j | j1), (j.value() == 3) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((3 ^ j1) == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j ^ 1) == 2) ); | ||||
|     BOOST_CHECK( (3 ^ j1) == 2 ); | ||||
|     BOOST_CHECK( (j ^ 1) == 2 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j ^ j1), (j.value() == 2) ); | ||||
|      | ||||
|     PRIVATE_EXPR_TEST( (j = ( j + j1 ) * ( j2 | j1 )), (j.value() == 9) ); | ||||
|  | ||||
|     BOOST_CHECK( static_cast<bool>((j1 << 2) == 4) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j2 << 1) == 4) ); | ||||
|     BOOST_CHECK( (j1 << 2) == 4 ); | ||||
|     BOOST_CHECK( (j2 << 1) == 4 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j1 << j2), (j.value() == 4) ); | ||||
|  | ||||
|     BOOST_CHECK( static_cast<bool>((j >> 2) == 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j2 >> 1) == 1) ); | ||||
|     BOOST_CHECK( (j >> 2) == 1 ); | ||||
|     BOOST_CHECK( (j2 >> 1) == 1 ); | ||||
|     PRIVATE_EXPR_TEST( (j = j2 >> j1), (j.value() == 1) ); | ||||
|      | ||||
|     cout << "Performed tests on MyLong objects.\n"; | ||||
| @@ -785,14 +741,14 @@ test_main( int , char * [] ) | ||||
|  | ||||
|     PRIVATE_EXPR_TEST( (k = k2), (k.value() == 2) ); | ||||
|  | ||||
|     BOOST_CHECK( static_cast<bool>(k2 == k) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k1 != k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k1 <  k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k1 <= k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k <= k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k2 >  k1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k2 >= k1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k2 >= k) ); | ||||
|     BOOST_CHECK( k2 == k ); | ||||
|     BOOST_CHECK( k1 != k2 ); | ||||
|     BOOST_CHECK( k1 <  k2 ); | ||||
|     BOOST_CHECK( k1 <= k2 ); | ||||
|     BOOST_CHECK( k <= k2 ); | ||||
|     BOOST_CHECK( k2 >  k1 ); | ||||
|     BOOST_CHECK( k2 >= k1 ); | ||||
|     BOOST_CHECK( k2 >= k ); | ||||
|      | ||||
|     cout << "Performed tests on MyChar objects.\n"; | ||||
|  | ||||
| @@ -808,31 +764,31 @@ test_main( int , char * [] ) | ||||
|  | ||||
|     PRIVATE_EXPR_TEST( (l = l2), (l.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(l2 == l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l == l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 != l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 != 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 != l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <  l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <  l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <  2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <= l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l <= 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >  l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >  l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >  1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= 2) ); | ||||
|     BOOST_CHECK( l2 == l ); | ||||
|     BOOST_CHECK( 2 == l ); | ||||
|     BOOST_CHECK( l2 == 2 );     | ||||
|     BOOST_CHECK( l == l2 ); | ||||
|     BOOST_CHECK( l1 != l2 ); | ||||
|     BOOST_CHECK( l1 != 2 ); | ||||
|     BOOST_CHECK( 1 != l2 ); | ||||
|     BOOST_CHECK( l1 <  l2 ); | ||||
|     BOOST_CHECK( 1 <  l2 ); | ||||
|     BOOST_CHECK( l1 <  2 ); | ||||
|     BOOST_CHECK( l1 <= l2 ); | ||||
|     BOOST_CHECK( 1 <= l2 ); | ||||
|     BOOST_CHECK( l1 <= l ); | ||||
|     BOOST_CHECK( l <= l2 ); | ||||
|     BOOST_CHECK( 2 <= l2 ); | ||||
|     BOOST_CHECK( l <= 2 ); | ||||
|     BOOST_CHECK( l2 >  l1 ); | ||||
|     BOOST_CHECK( 2 >  l1 ); | ||||
|     BOOST_CHECK( l2 >  1 ); | ||||
|     BOOST_CHECK( l2 >= l1 ); | ||||
|     BOOST_CHECK( 2 >= l1 ); | ||||
|     BOOST_CHECK( l2 >= 1 ); | ||||
|     BOOST_CHECK( l2 >= l ); | ||||
|     BOOST_CHECK( 2 >= l ); | ||||
|     BOOST_CHECK( l2 >= 2 ); | ||||
|      | ||||
|     cout << "Performed tests on MyShort objects.\n"; | ||||
|      | ||||
| @@ -851,37 +807,37 @@ test_main( int , char * [] ) | ||||
|  | ||||
|     PRIVATE_EXPR_TEST( (di = di2), (di.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(di2 == di) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == di) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 < di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 < di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 <= di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 > di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 > 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 >= di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 / di2 == half) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 / 2 == half) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 / di2 == half) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp/=2) == half) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp/=di2) == half) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 * di2 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 * 2 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 * di2 == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp*=2) == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp*=di2) == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 - di1 == di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 - 1 == di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 - di1 == di1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di2), static_cast<bool>((tmp-=1) == di1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di2), static_cast<bool>((tmp-=di1) == di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 + di1 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 + 1 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 + di1 == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp+=1) == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp+=di1) == di2) ); | ||||
|     BOOST_CHECK( di2 == di ); | ||||
|     BOOST_CHECK( 2 == di ); | ||||
|     BOOST_CHECK( di == 2 ); | ||||
|     BOOST_CHECK( di1 < di2 ); | ||||
|     BOOST_CHECK( 1 < di2 ); | ||||
|     BOOST_CHECK( di1 <= di2 ); | ||||
|     BOOST_CHECK( 1 <= di2 ); | ||||
|     BOOST_CHECK( di2 > di1 ); | ||||
|     BOOST_CHECK( di2 > 1 ); | ||||
|     BOOST_CHECK( di2 >= di1 ); | ||||
|     BOOST_CHECK( di2 >= 1 ); | ||||
|     BOOST_CHECK( di1 / di2 == half ); | ||||
|     BOOST_CHECK( di1 / 2 == half ); | ||||
|     BOOST_CHECK( 1 / di2 == half ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=2) == half) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=di2) == half) ); | ||||
|     BOOST_CHECK( di1 * di2 == di2 ); | ||||
|     BOOST_CHECK( di1 * 2 == di2 ); | ||||
|     BOOST_CHECK( 1 * di2 == di2 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=2) == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=di2) == di2) ); | ||||
|     BOOST_CHECK( di2 - di1 == di1 ); | ||||
|     BOOST_CHECK( di2 - 1 == di1 ); | ||||
|     BOOST_CHECK( 2 - di1 == di1 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=1) == di1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=di1) == di1) ); | ||||
|     BOOST_CHECK( di1 + di1 == di2 ); | ||||
|     BOOST_CHECK( di1 + 1 == di2 ); | ||||
|     BOOST_CHECK( 1 + di1 == di2 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=1) == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=di1) == di2) ); | ||||
|  | ||||
|     cout << "Performed tests on MyDoubleInt objects.\n"; | ||||
|  | ||||
| @@ -898,42 +854,42 @@ test_main( int , char * [] ) | ||||
|  | ||||
|     PRIVATE_EXPR_TEST( (li = li2), (li.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(li2 == li) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == li) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 < li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 < li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 <= li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 > li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 > 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 >= li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 % li2 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 % 2 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 % li2 == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2%=2) == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2%=li2) == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 / li2 == 0) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 / 2 == 0) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 / li2 == 0) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2/=2) == 0) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2/=li2) == 0) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 * li2 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 * 2 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 * li2 == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2*=2) == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2*=li2) == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 - li1 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 - 1 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 - li1 == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), static_cast<bool>((tmp2-=1) == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), static_cast<bool>((tmp2-=li1) == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 + li1 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 + 1 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 + li1 == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2+=1) == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2+=li1) == li2) ); | ||||
|     BOOST_CHECK( li2 == li ); | ||||
|     BOOST_CHECK( 2 == li ); | ||||
|     BOOST_CHECK( li == 2 ); | ||||
|     BOOST_CHECK( li1 < li2 ); | ||||
|     BOOST_CHECK( 1 < li2 ); | ||||
|     BOOST_CHECK( li1 <= li2 ); | ||||
|     BOOST_CHECK( 1 <= li2 ); | ||||
|     BOOST_CHECK( li2 > li1 ); | ||||
|     BOOST_CHECK( li2 > 1 ); | ||||
|     BOOST_CHECK( li2 >= li1 ); | ||||
|     BOOST_CHECK( li2 >= 1 ); | ||||
|     BOOST_CHECK( li1 % li2 == li1 ); | ||||
|     BOOST_CHECK( li1 % 2 == li1 ); | ||||
|     BOOST_CHECK( 1 % li2 == li1 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=2) == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=li2) == li1) ); | ||||
|     BOOST_CHECK( li1 / li2 == 0 ); | ||||
|     BOOST_CHECK( li1 / 2 == 0 ); | ||||
|     BOOST_CHECK( 1 / li2 == 0 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=2) == 0) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=li2) == 0) ); | ||||
|     BOOST_CHECK( li1 * li2 == li2 ); | ||||
|     BOOST_CHECK( li1 * 2 == li2 ); | ||||
|     BOOST_CHECK( 1 * li2 == li2 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=2) == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=li2) == li2) ); | ||||
|     BOOST_CHECK( li2 - li1 == li1 ); | ||||
|     BOOST_CHECK( li2 - 1 == li1 ); | ||||
|     BOOST_CHECK( 2 - li1 == li1 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=1) == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=li1) == li1) ); | ||||
|     BOOST_CHECK( li1 + li1 == li2 ); | ||||
|     BOOST_CHECK( li1 + 1 == li2 ); | ||||
|     BOOST_CHECK( 1 + li1 == li2 ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=1) == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=li1) == li2) ); | ||||
|  | ||||
|     cout << "Performed tests on MyLongInt objects.\n"; | ||||
|  | ||||
|   | ||||
| @@ -315,7 +315,7 @@ Last modified: Mon Aug 11 11:27:03 EST 2003 | ||||
| <p><EFBFBD> Copyright 2003 The Trustees of Indiana University. | ||||
|  Use, modification and distribution is subject to 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)</p> | ||||
|  http:www.boost.org/LICENSE_1_0.txt)</p> | ||||
|  | ||||
| </body> | ||||
|  | ||||
|   | ||||
							
								
								
									
										94
									
								
								swap.html
									
									
									
									
									
								
							
							
						
						
									
										94
									
								
								swap.html
									
									
									
									
									
								
							| @@ -1,94 +0,0 @@ | ||||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US" lang="en-US"> | ||||
|   <head> | ||||
|     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> | ||||
|     <title>Boost: Swap Documentation</title> | ||||
|    </head> | ||||
|   <body> | ||||
|     <!-- Page header --> | ||||
|     <img src="../../boost.png" alt="C++ Boost" align="middle" width="277" height="86"/> | ||||
|     <h1>Swap</h1> | ||||
|      | ||||
|     <p> | ||||
|       <tt>template<class T> void swap(T& <em>left</em>, T& <em>right</em>);</tt> | ||||
|     </p> | ||||
|       | ||||
|     <!-- Introduction --> | ||||
|     <p> | ||||
|       The template function <tt>boost::swap</tt> allows the values of two variables to be swapped, using argument dependent lookup to select a specialized swap function if available. If no specialized swap function is available, <tt>std::swap</tt> is used. | ||||
|     </p> | ||||
|      | ||||
|     <!-- Rationale --> | ||||
|     <h2>Rationale</h2> | ||||
|     <p> | ||||
|       The generic <tt>std::swap</tt> function requires that the elements to be swapped are assignable and copy constructible. It is usually implemented using one copy construction and two assignments - this is often both unnecessarily restrictive and unnecessarily slow. In addition, where the generic swap implementation provides only the basic guarantee, specialized swap functions are often able to provide the no-throw exception guarantee (and it is considered best practice to do so where possible<sup><a href="#ref1">1</a></sup>).</p> | ||||
|     <p> | ||||
|       The alternative to using argument dependent lookup in this situation is to provide a template specialization of <tt>std::swap</tt> for every type that requires a specialized swap. Although this is legal C++, no Boost libraries use this method, whereas many Boost libraries provide specialized swap functions in their own namespaces. | ||||
|     </p> | ||||
|     <p> | ||||
|       <tt>boost::swap</tt> also supports swapping built-in arrays. Note that <tt>std::swap</tt> originally did not do so, but a request to add an overload of <tt>std::swap</tt> for built-in arrays has been accepted by the C++ Standards Committee<sup><a href="#ref2">2</a></sup>. | ||||
|     </p> | ||||
|      | ||||
|     <!-- Exception Safety --> | ||||
|     <h2>Exception Safety</h2> | ||||
|     <p> | ||||
|       <tt>boost::swap</tt> provides the same exception guarantee as the underlying swap function used, with one exception; for an array of type <tt>T[n]</tt>, where <tt>n > 1</tt> and the underlying swap function for <tt>T</tt> provides the strong exception guarantee, <tt>boost::swap</tt> provides only the basic exception guarantee. | ||||
|     </p> | ||||
|      | ||||
|     <!-- Requirements --> | ||||
|     <h2>Requirements</h2> | ||||
|     <p>Either:</p> | ||||
|     <ul>       | ||||
|       <li>T must be assignable</li> | ||||
|       <li>T must be copy constructible</li> | ||||
|     </ul> | ||||
|     <p>Or:</p> | ||||
|     <ul> | ||||
|       <li>A function with the signature <tt>swap(T&,T&)</tt> is available via argument dependent lookup</li> | ||||
|     </ul> | ||||
|     <p>Or:</p> | ||||
|     <ul> | ||||
|       <li>A template specialization of <tt>std::swap</tt> exists for T</li> | ||||
|     </ul> | ||||
|     <p>Or:</p> | ||||
|     <ul> | ||||
|       <li>T is a built-in array of swappable elements</li> | ||||
|     </ul> | ||||
|  | ||||
|      | ||||
|     <!-- Portability --> | ||||
|     <h2>Portability</h2> | ||||
|     <p> | ||||
|       Several older compilers do not support argument dependent lookup ‒ on these compilers <tt>boost::swap</tt> will call <tt>std::swap</tt>, ignoring any specialized swap functions that could be found as a result of argument dependent lookup. | ||||
|     </p> | ||||
|      | ||||
|     <!-- Credits --> | ||||
|     <h2>Credits</h2> | ||||
|     <ul> | ||||
|       <li> | ||||
|         <em>Niels Dekker</em> - for implementing and documenting support for built-in arrays | ||||
|       </li> | ||||
|       <li> | ||||
|         <em><a href="mailto:Joseph.Gauterin@googlemail.com">Joseph Gauterin</a></em> - for the initial idea, implementation, tests, and documentation | ||||
|       </li> | ||||
|       <li> | ||||
|         <em>Steven Watanabe</em> - for the idea to make <tt>boost::swap</tt> less specialized than <tt>std::swap</tt>, thereby allowing the function to have the name 'swap' without introducing ambiguity | ||||
|       </li>       | ||||
|     </ul> | ||||
|  | ||||
|     <!-- References --> | ||||
|     <hr/> | ||||
|     <p><sup><a id="ref1"/>[1]</sup>Scott Meyers, Effective C++ Third Edition, Item 25: "Consider support for a non-throwing swap"</p> | ||||
|     <p><sup><a id="ref2"/>[2]</sup><a href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html#809">LWG Defect Report 809 (std::swap should be overloaded for array types)</a></p> | ||||
|  | ||||
|     <!-- Copyright info -->     | ||||
|     <hr/> | ||||
|     <p>Revised: 15 November 2008</p> | ||||
|     <p> | ||||
|       Copyright 2007, 2008 Joseph Gauterin. Use, modification, and distribution are subject to the Boost Software License, Version 1.0. | ||||
|       (See accompanying file <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or a copy at <<a href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>>.) | ||||
|     </p> | ||||
|      | ||||
|   </body> | ||||
| </html> | ||||
| @@ -1,41 +0,0 @@ | ||||
| # | ||||
| # Copyright Troy D. Straszheim | ||||
| # | ||||
| # Distributed under the Boost Software License, Version 1.0. | ||||
| # See http://www.boost.org/LICENSE_1_0.txt | ||||
| # | ||||
|  | ||||
| foreach(T  | ||||
|     root_header_1 root_header_2  | ||||
|     lib_header_1 lib_header_2  | ||||
|     mixed_headers_1 mixed_headers_2) | ||||
|   boost_test_compile(${T}) | ||||
| endforeach()  | ||||
|  | ||||
|  | ||||
| #     [ run primitive.cpp ../../../test/build//boost_test_exec_monitor/<link>static                      ] | ||||
|  | ||||
|  | ||||
| foreach(T | ||||
|     primitive | ||||
|     specialized_in_boost | ||||
|     specialized_in_global | ||||
|     specialized_in_other | ||||
|     specialized_in_std | ||||
|     specialized_in_boost_and_other | ||||
|     std_bitset | ||||
|     std_dateorder | ||||
|     std_string | ||||
|     std_typeinfo_ptr | ||||
|     std_vector_of_boost | ||||
|     std_vector_of_global | ||||
|     std_vector_of_other | ||||
|     no_ambiguity_in_boost | ||||
|     array_of_array_of_class | ||||
|     array_of_array_of_int | ||||
|     array_of_class | ||||
|     array_of_int | ||||
|     array_of_template) | ||||
|   boost_test_run(${T} DEPENDS boost_test_exec_monitor) | ||||
| endforeach() | ||||
|      | ||||
| @@ -1,37 +0,0 @@ | ||||
| # Copyright (c) 2007, 2008 Joseph Gauterin | ||||
| # | ||||
| # 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) | ||||
|  | ||||
| # bring in rules for testing | ||||
| import testing ; | ||||
|  | ||||
| test-suite utility/swap | ||||
|     : | ||||
|     [ compile root_header_1.cpp                                  ] | ||||
|     [ compile root_header_2.cpp                                  ] | ||||
|     [ compile lib_header_1.cpp                                   ] | ||||
|     [ compile lib_header_2.cpp                                   ] | ||||
|     [ compile mixed_headers_1.cpp                                ] | ||||
|     [ compile mixed_headers_2.cpp                                ] | ||||
|     [ run primitive.cpp ../../../test/build//boost_test_exec_monitor/<link>static                      ] | ||||
|     [ run specialized_in_boost.cpp ../../../test/build//boost_test_exec_monitor/<link>static           ] | ||||
|     [ run specialized_in_global.cpp ../../../test/build//boost_test_exec_monitor/<link>static          ] | ||||
|     [ run specialized_in_other.cpp ../../../test/build//boost_test_exec_monitor/<link>static           ] | ||||
|     [ run specialized_in_std.cpp ../../../test/build//boost_test_exec_monitor/<link>static             ] | ||||
|     [ run specialized_in_boost_and_other.cpp ../../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|     [ run std_bitset.cpp ../../../test/build//boost_test_exec_monitor/<link>static                     ] | ||||
|     [ run std_dateorder.cpp ../../../test/build//boost_test_exec_monitor/<link>static                  ] | ||||
|     [ run std_string.cpp ../../../test/build//boost_test_exec_monitor/<link>static                     ] | ||||
|     [ run std_typeinfo_ptr.cpp ../../../test/build//boost_test_exec_monitor/<link>static               ] | ||||
|     [ run std_vector_of_boost.cpp ../../../test/build//boost_test_exec_monitor/<link>static            ] | ||||
|     [ run std_vector_of_global.cpp ../../../test/build//boost_test_exec_monitor/<link>static           ] | ||||
|     [ run std_vector_of_other.cpp ../../../test/build//boost_test_exec_monitor/<link>static            ] | ||||
|     [ run no_ambiguity_in_boost.cpp ../../../test/build//boost_test_exec_monitor/<link>static          ] | ||||
|     [ run array_of_array_of_class.cpp ../../../test/build//boost_test_exec_monitor/<link>static        ] | ||||
|     [ run array_of_array_of_int.cpp ../../../test/build//boost_test_exec_monitor/<link>static          ] | ||||
|     [ run array_of_class.cpp ../../../test/build//boost_test_exec_monitor/<link>static                 ] | ||||
|     [ run array_of_int.cpp ../../../test/build//boost_test_exec_monitor/<link>static                   ] | ||||
|     [ run array_of_template.cpp ../../../test/build//boost_test_exec_monitor/<link>static              ] | ||||
|     ; | ||||
| @@ -1,69 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping an array of arrays of swap_test_class objects by means of boost::swap. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in the global namespace | ||||
| #include "./swap_test_class.hpp" | ||||
|  | ||||
| #include <algorithm> //for std::copy and std::equal | ||||
| #include <cstddef> //for std::size_t | ||||
|  | ||||
| //Provide swap function in both the namespace of swap_test_class | ||||
| //(which is the global namespace), and the std namespace. | ||||
| //It's common to provide a swap function for a class in both | ||||
| //namespaces. Scott Meyers recommends doing so: Effective C++, | ||||
| //Third Edition, item 25, "Consider support for a non-throwing swap". | ||||
| void swap(swap_test_class& left, swap_test_class& right) | ||||
| { | ||||
|   left.swap(right); | ||||
| } | ||||
|  | ||||
| namespace std | ||||
| { | ||||
|   template <> | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::size_t first_dimension = 3; | ||||
|   const std::size_t second_dimension = 4; | ||||
|   const std::size_t number_of_elements = first_dimension * second_dimension; | ||||
|  | ||||
|   swap_test_class array1[first_dimension][second_dimension]; | ||||
|   swap_test_class array2[first_dimension][second_dimension]; | ||||
|  | ||||
|   swap_test_class* const ptr1 = array1[0]; | ||||
|   swap_test_class* const ptr2 = array2[0]; | ||||
|  | ||||
|   for (std::size_t i = 0; i < number_of_elements; ++i) | ||||
|   { | ||||
|     ptr1[i].set_data( static_cast<int>(i) ); | ||||
|     ptr2[i].set_data( static_cast<int>(i + number_of_elements) ); | ||||
|   } | ||||
|  | ||||
|   boost::swap(array1, array2); | ||||
|  | ||||
|   for (std::size_t i = 0; i < number_of_elements; ++i) | ||||
|   { | ||||
|     BOOST_CHECK_EQUAL(ptr1[i].get_data(), static_cast<int>(i + number_of_elements) ); | ||||
|     BOOST_CHECK_EQUAL(ptr2[i].get_data(), static_cast<int>(i) ); | ||||
|   } | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(), number_of_elements); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(), 0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -1,42 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping an array of arrays of integers by means of boost::swap. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <algorithm> //for std::copy and std::equal | ||||
| #include <cstddef> //for std::size_t | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::size_t first_dimension = 3; | ||||
|   const std::size_t second_dimension = 4; | ||||
|   const std::size_t number_of_elements = first_dimension * second_dimension; | ||||
|  | ||||
|   int array1[first_dimension][second_dimension]; | ||||
|   int array2[first_dimension][second_dimension]; | ||||
|  | ||||
|   int* const ptr1 = array1[0]; | ||||
|   int* const ptr2 = array2[0]; | ||||
|  | ||||
|   for (std::size_t i = 0; i < number_of_elements; ++i) | ||||
|   { | ||||
|     ptr1[i] = static_cast<int>(i); | ||||
|     ptr2[i] = static_cast<int>(i + number_of_elements); | ||||
|   } | ||||
|  | ||||
|   boost::swap(array1, array2); | ||||
|  | ||||
|   for (std::size_t i = 0; i < number_of_elements; ++i) | ||||
|   { | ||||
|     BOOST_CHECK_EQUAL(ptr1[i], static_cast<int>(i + number_of_elements) ); | ||||
|     BOOST_CHECK_EQUAL(ptr2[i], static_cast<int>(i) ); | ||||
|   } | ||||
|   return 0; | ||||
| } | ||||
| @@ -1,61 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping an array of arrays of swap_test_class objects by means of boost::swap. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in the global namespace | ||||
| #include "./swap_test_class.hpp" | ||||
|  | ||||
| #include <algorithm> //for std::copy and std::equal | ||||
| #include <cstddef> //for std::size_t | ||||
|  | ||||
| //Provide swap function in both the namespace of swap_test_class | ||||
| //(which is the global namespace), and the std namespace. | ||||
| //It's common to provide a swap function for a class in both | ||||
| //namespaces. Scott Meyers recommends doing so: Effective C++, | ||||
| //Third Edition, item 25, "Consider support for a non-throwing swap". | ||||
| void swap(swap_test_class& left, swap_test_class& right) | ||||
| { | ||||
|   left.swap(right); | ||||
| } | ||||
|  | ||||
| namespace std | ||||
| { | ||||
|   template <> | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::size_t array_size = 2; | ||||
|   const swap_test_class initial_array1[array_size] = { swap_test_class(1), swap_test_class(2) }; | ||||
|   const swap_test_class initial_array2[array_size] = { swap_test_class(3), swap_test_class(4) }; | ||||
|    | ||||
|   swap_test_class array1[array_size]; | ||||
|   swap_test_class array2[array_size]; | ||||
|  | ||||
|   std::copy(initial_array1, initial_array1 + array_size, array1); | ||||
|   std::copy(initial_array2, initial_array2 + array_size, array2); | ||||
|    | ||||
|   swap_test_class::reset(); | ||||
|   boost::swap(array1, array2); | ||||
|  | ||||
|   BOOST_CHECK(std::equal(array1, array1 + array_size, initial_array2)); | ||||
|   BOOST_CHECK(std::equal(array2, array2 + array_size, initial_array1)); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(), array_size); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(), 0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -1,35 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping an array of integers by means of boost::swap. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <algorithm> //for std::copy and std::equal | ||||
| #include <cstddef> //for std::size_t | ||||
|  | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::size_t array_size = 3; | ||||
|   const int initial_array1[array_size] = { 1, 2, 3 }; | ||||
|   const int initial_array2[array_size] = { 4, 5, 6 }; | ||||
|    | ||||
|   int array1[array_size]; | ||||
|   int array2[array_size]; | ||||
|  | ||||
|   std::copy(initial_array1, initial_array1 + array_size, array1); | ||||
|   std::copy(initial_array2, initial_array2 + array_size, array2); | ||||
|    | ||||
|   boost::swap(array1, array2); | ||||
|  | ||||
|   BOOST_CHECK(std::equal(array1, array1 + array_size, initial_array2)); | ||||
|   BOOST_CHECK(std::equal(array2, array2 + array_size, initial_array1)); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -1,71 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping an array of swap_test_template<int> objects by means of boost::swap. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in the global namespace | ||||
| #include "./swap_test_class.hpp" | ||||
|  | ||||
| #include <algorithm> //for std::copy and std::equal | ||||
| #include <cstddef> //for std::size_t | ||||
|  | ||||
| template <class T> | ||||
| class swap_test_template | ||||
| { | ||||
| public: | ||||
|   typedef T template_argument; | ||||
|   swap_test_class swap_test_object; | ||||
| }; | ||||
|  | ||||
| template <class T> | ||||
| inline bool operator==(const swap_test_template<T> & lhs, const swap_test_template<T> & rhs) | ||||
| { | ||||
|   return lhs.swap_test_object == rhs.swap_test_object; | ||||
| } | ||||
|  | ||||
| template <class T> | ||||
| inline bool operator!=(const swap_test_template<T> & lhs, const swap_test_template<T> & rhs) | ||||
| { | ||||
|   return !(lhs == rhs); | ||||
| } | ||||
|  | ||||
| //Provide swap function in the namespace of swap_test_template | ||||
| //(which is the global namespace).  Note that it isn't allowed to put | ||||
| //an overload of this function within the std namespace. | ||||
| template <class T> | ||||
| void swap(swap_test_template<T>& left, swap_test_template<T>& right) | ||||
| { | ||||
|   left.swap_test_object.swap(right.swap_test_object); | ||||
| } | ||||
|  | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::size_t array_size = 2; | ||||
|   const swap_test_template<int> initial_array1[array_size] = { swap_test_class(1), swap_test_class(2) }; | ||||
|   const swap_test_template<int> initial_array2[array_size] = { swap_test_class(3), swap_test_class(4) }; | ||||
|    | ||||
|   swap_test_template<int> array1[array_size]; | ||||
|   swap_test_template<int> array2[array_size]; | ||||
|  | ||||
|   std::copy(initial_array1, initial_array1 + array_size, array1); | ||||
|   std::copy(initial_array2, initial_array2 + array_size, array2); | ||||
|    | ||||
|   swap_test_class::reset(); | ||||
|   boost::swap(array1, array2); | ||||
|  | ||||
|   BOOST_CHECK(std::equal(array1, array1 + array_size, initial_array2)); | ||||
|   BOOST_CHECK(std::equal(array2, array2 + array_size, initial_array1)); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(), array_size); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(), 0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -1,10 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests that the swap header compiles as a standalone translation unit | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
|  | ||||
| @@ -1,11 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests that the swap header include guards work correctly | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #include <boost/utility/swap.hpp> | ||||
|  | ||||
| @@ -1,11 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests that the swap headers work when both are included | ||||
|  | ||||
| #include <boost/swap.hpp> | ||||
| #include <boost/utility/swap.hpp> | ||||
|  | ||||
| @@ -1,12 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests that the swap headers work when both are included | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #include <boost/swap.hpp> | ||||
|  | ||||
|  | ||||
| @@ -1,44 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // boost::swap internally does an unqualified function call to swap. | ||||
| // This could have led to ambiguity or infinite recursion, when the | ||||
| // objects to be swapped would themselves be from the boost namespace. | ||||
| // If so, boost::swap itself might be found by argument dependent lookup. | ||||
| // The implementation of boost::swap resolves this issue by giving | ||||
| // boost::swap two template argumetns, thereby making it less specialized | ||||
| // than std::swap. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in namespace boost | ||||
| namespace boost | ||||
| { | ||||
|   #include "./swap_test_class.hpp" | ||||
| } | ||||
|  | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const boost::swap_test_class initial_value1(1); | ||||
|   const boost::swap_test_class initial_value2(2); | ||||
|  | ||||
|   boost::swap_test_class object1 = initial_value1; | ||||
|   boost::swap_test_class object2 = initial_value2; | ||||
|  | ||||
|   boost::swap_test_class::reset(); | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|   BOOST_CHECK_EQUAL(boost::swap_test_class::swap_count(),0); | ||||
|   BOOST_CHECK_EQUAL(boost::swap_test_class::copy_count(),3); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,23 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   int object1 = 1; | ||||
|   int object2 = 2; | ||||
|  | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1,2); | ||||
|   BOOST_CHECK_EQUAL(object2,1); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,10 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests that the swap header compiles as a standalone translation unit | ||||
|  | ||||
| #include <boost/swap.hpp> | ||||
|  | ||||
| @@ -1,11 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests that the swap header include guards work correctly | ||||
|  | ||||
| #include <boost/swap.hpp> | ||||
| #include <boost/swap.hpp> | ||||
|  | ||||
| @@ -1,45 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in namespace boost | ||||
| namespace boost | ||||
| { | ||||
|   #include "./swap_test_class.hpp" | ||||
| } | ||||
|  | ||||
| //Provide swap function in namespace boost | ||||
| namespace boost | ||||
| { | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const boost::swap_test_class initial_value1(1); | ||||
|   const boost::swap_test_class initial_value2(2); | ||||
|  | ||||
|   boost::swap_test_class object1 = initial_value1; | ||||
|   boost::swap_test_class object2 = initial_value2; | ||||
|    | ||||
|   boost::swap_test_class::reset(); | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(boost::swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(boost::swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,64 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests whether instances of a class from a namespace other than boost are | ||||
| // properly swapped, when both boost and the other namespace have a custom | ||||
| // swap function for that class. Note that it shouldn't be necessary for a class | ||||
| // in an other namespace to have a custom swap function in boost, because the | ||||
| // boost::swap utility should find the swap function in the other namespace, by | ||||
| // argument dependent lookup (ADL). Unfortunately ADL isn't fully implemented | ||||
| // by some specific compiler versions, including Intel C++ 8.1, MSVC 7.1, and  | ||||
| // Borland 5.9.3. Users of those compilers might consider adding a swap overload | ||||
| // to the boost namespace. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in namespace other | ||||
| namespace other | ||||
| { | ||||
|   #include "./swap_test_class.hpp" | ||||
| } | ||||
|  | ||||
| //Provide swap function in namespace boost | ||||
| namespace boost | ||||
| { | ||||
|   void swap(::other::swap_test_class& left, ::other::swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| //Provide swap function in namespace other | ||||
| namespace other | ||||
| { | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const other::swap_test_class initial_value1(1); | ||||
|   const other::swap_test_class initial_value2(2); | ||||
|  | ||||
|   other::swap_test_class object1 = initial_value1; | ||||
|   other::swap_test_class object2 = initial_value2; | ||||
|    | ||||
|   other::swap_test_class::reset(); | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|    | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,39 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in the global namespace | ||||
| #include "./swap_test_class.hpp" | ||||
|  | ||||
| //Provide swap function in gloabl namespace | ||||
| void swap(swap_test_class& left, swap_test_class& right) | ||||
| { | ||||
|   left.swap(right); | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const swap_test_class initial_value1(1); | ||||
|   const swap_test_class initial_value2(2); | ||||
|  | ||||
|   swap_test_class object1 = initial_value1; | ||||
|   swap_test_class object2 = initial_value2; | ||||
|    | ||||
|   swap_test_class::reset(); | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|    | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,45 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in namespace other | ||||
| namespace other | ||||
| { | ||||
|   #include "./swap_test_class.hpp" | ||||
| } | ||||
|  | ||||
| //Provide swap function in namespace other | ||||
| namespace other | ||||
| { | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const other::swap_test_class initial_value1(1); | ||||
|   const other::swap_test_class initial_value2(2); | ||||
|  | ||||
|   other::swap_test_class object1 = initial_value1; | ||||
|   other::swap_test_class object2 = initial_value2; | ||||
|    | ||||
|   other::swap_test_class::reset(); | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|    | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,44 +0,0 @@ | ||||
| // Copyright (c) 2007 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| //Put test class in the global namespace | ||||
| #include "./swap_test_class.hpp" | ||||
|  | ||||
|  | ||||
| //Provide swap function in namespace std | ||||
| namespace std | ||||
| { | ||||
|   template <> | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const swap_test_class initial_value1(1); | ||||
|   const swap_test_class initial_value2(2); | ||||
|  | ||||
|   swap_test_class object1 = initial_value1; | ||||
|   swap_test_class object2 = initial_value2; | ||||
|    | ||||
|   swap_test_class::reset(); | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|    | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,33 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping std::bitset<T> objects by means of boost::swap. | ||||
| // Unlike most other Standard C++ Library template classes, | ||||
| // std::bitset<T> does not have its own std::swap overload. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <bitset> | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   typedef std::bitset<8> bitset_type; | ||||
|   const bitset_type initial_value1 = 1ul; | ||||
|   const bitset_type initial_value2 = 2ul; | ||||
|  | ||||
|   bitset_type object1 = initial_value1; | ||||
|   bitset_type object2 = initial_value2; | ||||
|  | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1,initial_value2); | ||||
|   BOOST_CHECK_EQUAL(object2,initial_value1); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,32 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping std::time_base::dateorder objects by means of boost::swap. | ||||
| // std::time_base::dateorder is an enumerated type. It does not have an | ||||
| // std::swap overload or template specialization. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <locale> | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::time_base::dateorder initial_value1 = std::time_base::dmy; | ||||
|   const std::time_base::dateorder initial_value2 = std::time_base::mdy; | ||||
|  | ||||
|   std::time_base::dateorder object1 = initial_value1; | ||||
|   std::time_base::dateorder object2 = initial_value2; | ||||
|  | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1,initial_value2); | ||||
|   BOOST_CHECK_EQUAL(object2,initial_value1); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,31 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping std::string objects by means of boost::swap. | ||||
| // std::string has its own std::swap overload. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <string> | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::string initial_value1 = "one"; | ||||
|   const std::string initial_value2 = "two"; | ||||
|  | ||||
|   std::string object1 = initial_value1; | ||||
|   std::string object2 = initial_value2; | ||||
|  | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1,initial_value2); | ||||
|   BOOST_CHECK_EQUAL(object2,initial_value1); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,32 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping std::type_info pointers by means of boost::swap. | ||||
| // There is no std::swap overload or template specialization | ||||
| // for std::type_info pointers. | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <typeinfo> | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   const std::type_info * const initial_value1 = 0; | ||||
|   const std::type_info * const initial_value2 = &typeid(double); | ||||
|    | ||||
|   const std::type_info * ptr1 = initial_value1; | ||||
|   const std::type_info * ptr2 = initial_value2; | ||||
|  | ||||
|   boost::swap(ptr1,ptr2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(ptr1,initial_value2); | ||||
|   BOOST_CHECK_EQUAL(ptr2,initial_value1); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,60 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping std::vector objects by means of boost::swap, | ||||
| // having boost::swap_test_class as vector element type.  | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <vector> | ||||
|  | ||||
| //Put test class in namespace boost | ||||
| namespace boost | ||||
| { | ||||
|   #include "./swap_test_class.hpp" | ||||
| } | ||||
|  | ||||
| //Provide swap function in namespace boost | ||||
| namespace boost | ||||
| { | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   typedef boost::swap_test_class swap_test_class_type; | ||||
|   typedef std::vector<swap_test_class_type> vector_type; | ||||
|  | ||||
|   const vector_type::size_type initial_size1 = 1; | ||||
|   const vector_type::size_type initial_size2 = 2; | ||||
|  | ||||
|   const vector_type initial_value1(initial_size1, swap_test_class_type(1)); | ||||
|   const vector_type initial_value2(initial_size2, swap_test_class_type(2)); | ||||
|    | ||||
|   vector_type object1 = initial_value1; | ||||
|   vector_type object2 = initial_value2; | ||||
|  | ||||
|   swap_test_class_type::reset(); | ||||
|    | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1.size(),initial_size2); | ||||
|   BOOST_CHECK_EQUAL(object2.size(),initial_size1); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|    | ||||
|   BOOST_CHECK_EQUAL(swap_test_class_type::swap_count(),0); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class_type::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,53 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping std::vector objects by means of boost::swap, | ||||
| // having ::swap_test_class as vector element type.  | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <vector> | ||||
|  | ||||
| //Put test class in the global namespace | ||||
| #include "./swap_test_class.hpp" | ||||
|  | ||||
| //Provide swap function in the global namespace  | ||||
| void swap(swap_test_class& left, swap_test_class& right) | ||||
| { | ||||
|   left.swap(right); | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   typedef std::vector<swap_test_class> vector_type; | ||||
|  | ||||
|   const vector_type::size_type initial_size1 = 1; | ||||
|   const vector_type::size_type initial_size2 = 2; | ||||
|  | ||||
|   const vector_type initial_value1(initial_size1, swap_test_class(1)); | ||||
|   const vector_type initial_value2(initial_size2, swap_test_class(2)); | ||||
|    | ||||
|   vector_type object1 = initial_value1; | ||||
|   vector_type object2 = initial_value2; | ||||
|  | ||||
|   swap_test_class::reset(); | ||||
|    | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1.size(),initial_size2); | ||||
|   BOOST_CHECK_EQUAL(object2.size(),initial_size1); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(),0); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,60 +0,0 @@ | ||||
| // Copyright (c) 2008 Joseph Gauterin, Niels Dekker | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests swapping std::vector objects by means of boost::swap, | ||||
| // having other::swap_test_class as vector element type.  | ||||
|  | ||||
| #include <boost/utility/swap.hpp> | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <vector> | ||||
|  | ||||
| //Put test class in namespace other | ||||
| namespace other | ||||
| { | ||||
|   #include "./swap_test_class.hpp" | ||||
| } | ||||
|  | ||||
| //Provide swap function in namespace other | ||||
| namespace other | ||||
| { | ||||
|   void swap(swap_test_class& left, swap_test_class& right) | ||||
|   { | ||||
|     left.swap(right); | ||||
|   } | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|   typedef other::swap_test_class swap_test_class_type; | ||||
|   typedef std::vector<swap_test_class_type> vector_type; | ||||
|  | ||||
|   const vector_type::size_type initial_size1 = 1; | ||||
|   const vector_type::size_type initial_size2 = 2; | ||||
|  | ||||
|   const vector_type initial_value1(initial_size1, swap_test_class_type(1)); | ||||
|   const vector_type initial_value2(initial_size2, swap_test_class_type(2)); | ||||
|    | ||||
|   vector_type object1 = initial_value1; | ||||
|   vector_type object2 = initial_value2; | ||||
|  | ||||
|   swap_test_class_type::reset(); | ||||
|    | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1.size(),initial_size2); | ||||
|   BOOST_CHECK_EQUAL(object2.size(),initial_size1); | ||||
|  | ||||
|   BOOST_CHECK(object1 == initial_value2); | ||||
|   BOOST_CHECK(object2 == initial_value1); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class_type::swap_count(),0); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class_type::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,114 +0,0 @@ | ||||
| // Copyright (c) 2007-2008 Joseph Gauterin | ||||
| // | ||||
| // 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) | ||||
|  | ||||
| // Tests class used by the Boost.Swap tests | ||||
|  | ||||
| #ifndef BOOST_UTILITY_SWAP_TEST_CLASS_HPP | ||||
| #define BOOST_UTILITY_SWAP_TEST_CLASS_HPP | ||||
|  | ||||
|  | ||||
| class swap_test_class | ||||
| { | ||||
|   int m_data; | ||||
| public: | ||||
|   explicit swap_test_class(int arg = 0) | ||||
|   : | ||||
|   m_data(arg) | ||||
|   { | ||||
|     ++constructCount(); | ||||
|   } | ||||
|  | ||||
|   ~swap_test_class() | ||||
|   { | ||||
|     ++destructCount(); | ||||
|   } | ||||
|  | ||||
|   swap_test_class(const swap_test_class& arg) | ||||
|   : | ||||
|   m_data(arg.m_data) | ||||
|   { | ||||
|     ++copyCount(); | ||||
|     ++destructCount(); | ||||
|   } | ||||
|  | ||||
|   swap_test_class& operator=(const swap_test_class& arg) | ||||
|   { | ||||
|     m_data = arg.m_data; | ||||
|     ++copyCount(); | ||||
|     return *this; | ||||
|   } | ||||
|  | ||||
|   void swap(swap_test_class& other) | ||||
|   { | ||||
|     const int temp = m_data; | ||||
|     m_data = other.m_data; | ||||
|     other.m_data = temp; | ||||
|  | ||||
|     ++swapCount(); | ||||
|   } | ||||
|  | ||||
|   int get_data() const | ||||
|   { | ||||
|     return m_data; | ||||
|   } | ||||
|  | ||||
|   void set_data(int arg) | ||||
|   { | ||||
|     m_data = arg; | ||||
|   } | ||||
|    | ||||
|   static unsigned int swap_count(){ return swapCount(); } | ||||
|   static unsigned int copy_count(){ return copyCount(); } | ||||
|   static unsigned int construct_count(){ return constructCount(); } | ||||
|   static unsigned int destruct_count(){ return destructCount(); } | ||||
|  | ||||
|   static void reset() | ||||
|   { | ||||
|     swapCount() = 0; | ||||
|     copyCount() = 0;     | ||||
|     constructCount() = 0; | ||||
|     destructCount() = 0; | ||||
|   } | ||||
|  | ||||
| private: | ||||
|   static unsigned int& swapCount() | ||||
|   { | ||||
|     static unsigned int value = 0; | ||||
|     return value; | ||||
|   } | ||||
|  | ||||
|   static unsigned int& copyCount()     | ||||
|   { | ||||
|     static unsigned int value = 0; | ||||
|     return value; | ||||
|   } | ||||
|  | ||||
|   static unsigned int& constructCount()     | ||||
|   { | ||||
|     static unsigned int value = 0; | ||||
|     return value; | ||||
|   } | ||||
|  | ||||
|   static unsigned int& destructCount()     | ||||
|   { | ||||
|     static unsigned int value = 0; | ||||
|     return value; | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
|  | ||||
| inline bool operator==(const swap_test_class & lhs, const swap_test_class & rhs) | ||||
| { | ||||
|   return lhs.get_data() == rhs.get_data(); | ||||
| } | ||||
|  | ||||
| inline bool operator!=(const swap_test_class & lhs, const swap_test_class & rhs) | ||||
| { | ||||
|   return !(lhs == rhs); | ||||
| } | ||||
|  | ||||
| #endif | ||||
| @@ -1,47 +0,0 @@ | ||||
| # | ||||
| # Copyright Troy D. Straszheim | ||||
| # | ||||
| # Distributed under the Boost Software License, Version 1.0. | ||||
| # See http://www.boost.org/LICENSE_1_0.txt | ||||
| # | ||||
| boost_additional_test_dependencies(utility BOOST_DEPENDS test) | ||||
|  | ||||
| boost_test_run(addressof_fn_test ../addressof_fn_test.cpp) | ||||
| boost_test_run(addressof_test ../addressof_test.cpp) | ||||
| boost_test_run(addressof_test2 ../addressof_test2.cpp) | ||||
| boost_test_run(assert_test ../assert_test.cpp) | ||||
| boost_test_run(base_from_member_test ../base_from_member_test.cpp) | ||||
| boost_test_run(binary_search_test ../binary_search_test.cpp) | ||||
| boost_test_run(call_traits_test ../call_traits_test.cpp ARGS -u) | ||||
| boost_test_compile_fail(checked_delete_test ../checked_delete_test.cpp) | ||||
| boost_test_run(compressed_pair_test  | ||||
|   ../compressed_pair_test  | ||||
|   DEPENDS boost_test_exec_monitor) | ||||
| boost_test_run(current_function_test ../current_function_test.cpp) | ||||
| boost_test_run(iterators_test  | ||||
|   ../iterators_test.cpp  | ||||
|   DEPENDS boost_test_exec_monitor) | ||||
| boost_test_run(next_prior_test DEPENDS boost_test_exec_monitor) | ||||
| boost_test_compile_fail(noncopyable_test ../noncopyable_test.cpp) | ||||
| boost_test_run(numeric_traits_test ../numeric_traits_test.cpp) | ||||
| if (${CMAKE_SYSTEM} MATCHES "FreeBSD-.*") | ||||
| boost_test_compile_fail("operators_test_compilerbug") | ||||
| elseif(${CMAKE_SYSTEM} MATCHES "FreeBSD-.*") | ||||
| boost_test_run(operators_test  | ||||
|   ../operators_test.cpp | ||||
|   DEPENDS boost_test_exec_monitor) | ||||
| endif(${CMAKE_SYSTEM} MATCHES "FreeBSD-.*") | ||||
| boost_test_compile(ref_ct_test ../ref_ct_test.cpp) | ||||
| boost_test_run(ref_test  | ||||
|   ../ref_test.cpp | ||||
|   DEPENDS boost_test_exec_monitor) | ||||
| boost_test_compile(result_of_test) | ||||
| boost_test_run(shared_iterator_test ../shared_iterator_test.cpp) | ||||
| boost_test_run(value_init_test ../value_init_test.cpp) | ||||
| boost_test_compile_fail(value_init_test_fail1  | ||||
|   ../value_init_test_fail1.cpp) | ||||
| boost_test_compile_fail(value_init_test_fail2 | ||||
|   ../value_init_test_fail2.cpp) | ||||
| boost_test_compile_fail(value_init_test_fail3 | ||||
|   ../value_init_test_fail3.cpp) | ||||
| boost_test_run(verify_test ../verify_test.cpp) | ||||
| @@ -1,7 +1,8 @@ | ||||
| # Copyright David Abrahams 2003. | ||||
|  | ||||
| # Distributed under the Boost Software License, Version 1.0. | ||||
| # See http://www.boost.org/LICENSE_1_0.txt | ||||
| # Copyright David Abrahams 2003. Permission to copy, use, | ||||
| # modify, sell and distribute this software is granted provided this | ||||
| # copyright notice appears in all copies. This software is provided | ||||
| # "as is" without express or implied warranty, and with no claim as | ||||
| # to its suitability for any purpose. | ||||
|  | ||||
| # For more information, see http://www.boost.org/ | ||||
|  | ||||
| @@ -11,13 +12,10 @@ import testing ; | ||||
| # Please keep the tests ordered by filename | ||||
| test-suite utility | ||||
|     : | ||||
|         [ run ../addressof_fn_test.cpp ] | ||||
|         [ run ../addressof_test.cpp ] | ||||
|         [ run ../addressof_test2.cpp ] | ||||
|         [ run ../assert_test.cpp ] | ||||
|         [ run ../base_from_member_test.cpp ] | ||||
|         [ run ../binary_search_test.cpp ] | ||||
|         [ run ../binary_test.cpp ] | ||||
|         [ run ../call_traits_test.cpp : -u ] | ||||
|         [ compile-fail ../checked_delete_test.cpp ] | ||||
|         [ run ../compressed_pair_test.cpp ../../test/build//boost_test_exec_monitor/<link>static : -u ] | ||||
| @@ -35,6 +33,4 @@ test-suite utility | ||||
|         [ compile-fail ../value_init_test_fail1.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail2.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail3.cpp ] | ||||
|         [ run ../verify_test.cpp ] | ||||
|     ; | ||||
|  | ||||
|   | ||||
							
								
								
									
										0
									
								
								test/next_prior_test.cpp
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								test/next_prior_test.cpp
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -1,15 +1,58 @@ | ||||
| <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> | ||||
| <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> | ||||
| <html> | ||||
| <head> | ||||
| <meta http-equiv=refresh content="0; URL=../exception/doc/throw_exception.html"> | ||||
| <title>Automatic redirection</title> | ||||
| </head> | ||||
| <body> | ||||
| Automatic redirection failed, please go to | ||||
| <a href="../exception/doc/throw_exception.html">throw_exception.html</a>. <hr> | ||||
| <p><EFBFBD> Copyright Beman Dawes, 2001</p> | ||||
| <p>Distributed under the Boost Software License, Version 1.0. (See accompanying  | ||||
| file <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or copy  | ||||
| at <a href="http://www.boost.org/LICENSE_1_0.txt">www.boost.org/LICENSE_1_0.txt</a>)</p> | ||||
| </body> | ||||
| 	<head> | ||||
| 		<title>Boost: throw_exception.hpp documentation</title> | ||||
| 		<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> | ||||
| 	</head> | ||||
| 	<body bgcolor="white" style="MARGIN-LEFT: 5%; MARGIN-RIGHT: 5%"> | ||||
| 		<table border="0" width="100%"> | ||||
| 			<tr> | ||||
| 				<td width="277"><A href="../../index.htm"> <img src="../../boost.png" alt="boost.png (6897 bytes)" width="277" height="86" border="0"></A> | ||||
| 				</td> | ||||
| 				<td align="center"> | ||||
| 					<h1>throw_exception.hpp</h1> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td colspan="2" height="64"> </td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 		<p> | ||||
| 			The header <STRONG><boost/throw_exception.hpp></STRONG> defines the  | ||||
| 			helper function <STRONG>boost::throw_exception</STRONG>. It is intended to be  | ||||
| 			used in Boost libraries that need to throw exceptions, but support  | ||||
| 			configurations and platforms where exceptions aren't available, as indicated by  | ||||
| 			the presence of the <STRONG>BOOST_NO_EXCEPTIONS</STRONG> <A href="../config/config.htm#macro_ref"> | ||||
| 				configuration macro</A>. | ||||
| 		</p> | ||||
| 		<P>When <STRONG>BOOST_NO_EXCEPTIONS</STRONG> is not defined, <tt>boost::throw_exception(e)</tt> | ||||
| 			is equivalent to <tt>throw e</tt>. Otherwise, the function is left undefined,  | ||||
| 			and the user is expected to supply an appropriate definition. Callers of <tt>throw_exception</tt> | ||||
| 			are allowed to assume that the function never returns; therefore, if the  | ||||
| 			user-defined <tt>throw_exception</tt> returns, the behavior is undefined.</P> | ||||
| 		<h3><a name="Synopsis">Synopsis</a></h3> | ||||
| 		<pre> | ||||
| namespace boost | ||||
| { | ||||
|  | ||||
| #ifdef BOOST_NO_EXCEPTIONS | ||||
|  | ||||
| void throw_exception(std::exception const & e); // user defined | ||||
|  | ||||
| #else | ||||
|  | ||||
| template<class E> void throw_exception(E const & e) | ||||
| { | ||||
|     throw e; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| } | ||||
| </pre> | ||||
| 		<p><br> | ||||
| 			<small>Copyright <20> 2002 by Peter Dimov. Distributed under the Boost Software License, Version  | ||||
| 				1.0. See accompanying file <A href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</A> or  | ||||
| 				copy at <A href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</A>.</small></p> | ||||
| 	</body> | ||||
| </html> | ||||
|   | ||||
							
								
								
									
										70
									
								
								utility.htm
									
									
									
									
									
								
							
							
						
						
									
										70
									
								
								utility.htm
									
									
									
									
									
								
							| @@ -23,8 +23,6 @@ | ||||
| 			<li> | ||||
| 				Function template <a href="#addressof">addressof()</a></li> | ||||
|                         <li>Class template <a href="#result_of">result_of</a></li> | ||||
|                         <li> | ||||
| 				Macro <a href="#BOOST_BINARY">BOOST_BINARY</a></li> | ||||
|                         <li><a href="index.html">Other utilities not part of <code>utility.hpp</code></a></li> | ||||
| 		</ul> | ||||
| 		<h2> | ||||
| @@ -70,7 +68,7 @@ const std::list<T>::iterator next = boost::next(prev, 2);</pre> | ||||
|                 <p>The distance from the given iterator should be supplied as an absolute value. For | ||||
| 			example, the iterator four iterators prior to the given iterator <code>p</code> | ||||
| 			may be obtained by <code>prior(p, 4)</code>.</p> | ||||
| 		<p>Contributed by <a href="http://www.boost.org/people/dave_abrahams.htm">Dave Abrahams</a>.  Two-argument versions by Daniel Walker.</p> | ||||
| 		<p>Contributed by <a href="../../people/dave_abrahams.htm">Dave Abrahams</a>.  Two-argument versions by Daniel Walker.</p> | ||||
| 		<h2><a name="Class_noncopyable">Class noncopyable</a></h2> | ||||
| 		<p>Class <strong>noncopyable</strong> is a base class.  Derive your own class  | ||||
| 			from <strong>noncopyable</strong> when you want to prohibit copy construction  | ||||
| @@ -91,7 +89,7 @@ const std::list<T>::iterator next = boost::next(prev, 2);</pre> | ||||
| 			to verify class <b>noncopyable</b> works as expected. It has have been run  | ||||
| 			successfully under GCC 2.95, Metrowerks CodeWarrior 5.0, and Microsoft Visual  | ||||
| 			C++ 6.0 sp 3.</p> | ||||
| 		<p>Contributed by <a href="http://www.boost.org/people/dave_abrahams.htm">Dave Abrahams</a>.</p> | ||||
| 		<p>Contributed by <a href="../../people/dave_abrahams.htm">Dave Abrahams</a>.</p> | ||||
| 		<h3>Example</h3> | ||||
| 		<blockquote> | ||||
| 			<pre>// inside one of your own headers ... | ||||
| @@ -183,68 +181,14 @@ void f() { | ||||
|  | ||||
| 		<h2>Class templates for the Base-from-Member Idiom</h2> | ||||
| 		<p>See <a href="base_from_member.html">separate documentation</a>.</p> | ||||
| 		<h2><a name="BOOST_BINARY">Macro BOOST_BINARY</a></h2> | ||||
|  | ||||
| 		<p>The macro <code>BOOST_BINARY</code> is used for the | ||||
|                 representation of binary literals. It takes as an argument | ||||
|                 a binary number arranged as an arbitrary amount of 1s and 0s in | ||||
|                 groupings of length 1 to 8, with groups separated | ||||
|                 by spaces. The type of the literal yielded is determined by | ||||
|                 the same rules as those of hex and octal | ||||
|                 literals (<i>2.13.1p1</i>). By implementation, this macro | ||||
|                 expands directly to an octal literal during preprocessing, so | ||||
|                 there is no overhead at runtime and the result is useable in | ||||
|                 any place that an octal literal would be.</p> | ||||
|  | ||||
| 		<p>In order to directly support binary literals with suffixes, | ||||
|                 additional macros of the form BOOST_BINARY_XXX are also | ||||
|                 provided, where XXX is a standard integer suffix in all capital | ||||
|                 letters. In addition, LL and ULL suffixes may be used for representing | ||||
|                 long long and unsigned long long types in compilers which provide | ||||
|                 them as an extension.</p> | ||||
|  | ||||
|  | ||||
|                 <p>The BOOST_BINARY family of macros resides in the header | ||||
|                 <a | ||||
|                 href="../../boost/utility/binary.hpp"><boost/utility/binary.hpp></a> | ||||
|                 which is automatically included by | ||||
|                 <a | ||||
|                 href="../../boost/utility.hpp"><boost/utility.hpp></a>. | ||||
|  | ||||
| 		<p>Contributed by Matt Calabrese.</p><p> | ||||
| 		</p><h3>Example</h3> | ||||
| 		<blockquote> | ||||
| 			<pre> | ||||
| void foo( int ); | ||||
|  | ||||
| void foo( unsigned long ); | ||||
|  | ||||
| void bar() | ||||
| { | ||||
|   int value1 = BOOST_BINARY( 100 111000 01 1 110 ); | ||||
|  | ||||
|   unsigned long value2 = BOOST_BINARY_UL( 100 001 ); // unsigned long | ||||
|  | ||||
|   long long value3 = BOOST_BINARY_LL( 11 000 ); // long long if supported | ||||
|  | ||||
|   assert(    BOOST_BINARY( 10010 ) | ||||
|           &  BOOST_BINARY( 11000 ) | ||||
|           == BOOST_BINARY( 10000 ) | ||||
|         ); | ||||
|  | ||||
|   foo( BOOST_BINARY( 1010 ) ); // calls the first foo | ||||
|  | ||||
|   foo( BOOST_BINARY_LU( 1010 ) ); // calls the second foo | ||||
| } | ||||
| </pre></blockquote> | ||||
| 		<hr> | ||||
| 		<p>Revised  <!--webbot bot="Timestamp" S-Type="EDITED" S-Format="%d %B, %Y" startspan | ||||
| -->04 September, 2008<!--webbot bot="Timestamp" endspan i-checksum="39369" | ||||
| -->02 May, 2004<!--webbot bot="Timestamp" endspan i-checksum="38582" | ||||
| --> | ||||
| 		</p> | ||||
| 		<p>© Copyright Beman Dawes 1999-2003.</p> | ||||
| <p>Distributed under the Boost Software License, Version 1.0. See | ||||
| <a href="http://www.boost.org/LICENSE_1_0.txt">www.boost.org/LICENSE_1_0.txt</a></p> | ||||
|  | ||||
| 		<p>© Copyright boost.org 1999-2003. Permission to copy, use, modify, sell and distribute  | ||||
| 			this document is granted provided this copyright notice appears in all copies.  | ||||
| 			This document is provided "as is" without express or implied  | ||||
| 			warranty, and with no claim as to its suitability for any purpose.</p> | ||||
| 	</body> | ||||
| </html> | ||||
|   | ||||
							
								
								
									
										242
									
								
								value_init.htm
									
									
									
									
									
								
							
							
						
						
									
										242
									
								
								value_init.htm
									
									
									
									
									
								
							| @@ -17,23 +17,20 @@ | ||||
| <dl> | ||||
|   <dt><a href="#rationale">Rationale</a></dt> | ||||
|   <dt><a href="#intro">Introduction</a></dt> | ||||
|   <dt><a href="#details">Details</a></dt> | ||||
| </dl> | ||||
|                     | ||||
| <ul> | ||||
|           <li><a href="#valueinit">value-initialization</a></li> | ||||
|           <li><a href="#valueinitsyn">value-initialization syntax</a></li> | ||||
|           <li><a href="#compiler_issues">compiler issues</a></li> | ||||
|                     | ||||
| </ul> | ||||
|                     | ||||
| <dl class="page-index"> | ||||
|   <dt><a href="#types">Types and objects</a></dt> | ||||
|   <dt><a href="#types">Types</a></dt> | ||||
| </dl> | ||||
|                     | ||||
| <ul> | ||||
|           <li><a href="#val_init"><code>template class value_initialized<T></code></a></li> | ||||
|           <li><a href="#initialized_value"><code>initialized_value</code></a></li> | ||||
|           <li><a href="#val_init"><code>value_initialized<></code></a></li> | ||||
|                     | ||||
| </ul> | ||||
|               <a href="#acknowledgements">Acknowledgements</a><br> | ||||
| @@ -47,104 +44,24 @@ | ||||
| for    initialization. Depending on the type, the value of a newly constructed | ||||
|   object  can be zero-initialized (logically 0), default-constructed (using | ||||
|   the default constructor), or indeterminate. When writing generic code, | ||||
| this  problem must be addressed. The template <code>value_initialized</code> provides | ||||
| this   problem must be addressed. <code>value_initialized</code> provides | ||||
| a solution   with consistent syntax for value   initialization of scalar, | ||||
| union and class   types. | ||||
| Moreover, <code>value_initialized</code> offers a workaround to various | ||||
| compiler issues regarding value-initialization. | ||||
|  | ||||
| Furthermore, a <code>const</code> object, <code>initialized_value</code> is provided, | ||||
| to avoid repeating the type name when retrieving the value from a | ||||
| <code>value_initialized<T></code> object. | ||||
| <br> | ||||
| union and class   types. <br> | ||||
|   </p> | ||||
|          | ||||
| <h2><a name="intro"></a>Introduction</h2> | ||||
|       | ||||
| <p> | ||||
| There are various ways to initialize a variable, in C++. The following | ||||
| declarations all <em>may</em> have a local variable initialized to its default | ||||
| value: | ||||
| <pre> | ||||
|   T1 var1; | ||||
|   T2 var2 = 0; | ||||
|   T3 var3 = {}; | ||||
|   T4 var4 = T4(); | ||||
| </pre>  | ||||
| Unfortunately, whether or not any of those declarations correctly | ||||
| initialize the variable very much depends on its type. The first | ||||
| declaration is valid for any <a href="http://www.sgi.com/tech/stl/DefaultConstructible.html"> | ||||
| DefaultConstructible</a> type (by definition). | ||||
| However, it does not always do an initialization! | ||||
| It correctly initializes the variable when it's an instance of a | ||||
| class, and the author of the class has provided a proper default | ||||
| constructor. On the other hand, the value of <code>var1</code> is <em>indeterminate</em> when | ||||
| its type is an arithmetic type, like <code>int</code>, <code>float</code>, or <code>char</code>. | ||||
| An arithmetic variable | ||||
| is of course initialized properly by the second declaration, <code>T2 | ||||
| var2 = 0</code>. But this initialization form usually won't work for a | ||||
| class type (unless the class was especially written to support being | ||||
| initialized that way). The third form,  <code>T3 var3 = {}</code> | ||||
| initializes an aggregate, typically a "C-style" <code>struct</code> or a "C-style" array. | ||||
| However, the syntax is not allowed for a class that has an explicitly declared | ||||
| constructor.  (But watch out for an upcoming C++ language change,  | ||||
| by Bjarne Stroustrup et al [<a href="#references">1</a>]!) | ||||
| The fourth form is the most generic form of them, as it | ||||
| can be used to initialize arithmetic types, class types, aggregates, pointers, and | ||||
| other types. The declaration,  <code>T4 var4 = T4()</code>, should be read | ||||
| as follows: First a temporary object is created, by <code>T4()</code>. | ||||
| This object is <a href="#valueinit">value-initialized</a>. Next the temporary | ||||
| object is copied to the named variable, <code>var4</code>. Afterwards, the temporary | ||||
| is destroyed. While the copying and the destruction are likely to | ||||
| be optimized away, C++ still requires the type <code>T4</code> to be | ||||
| <a href="CopyConstructible.html">CopyConstructible</a>. | ||||
| (So <code>T4</code> needs to be <em>both</em> DefaultConstructible <em>and</em> CopyConstructible.)  | ||||
| A class may not be CopyConstructible, for example because it may have a | ||||
| private and undefined copy constructor, | ||||
| or because it may be derived from <a href="utility.htm#Class_noncopyable">boost::noncopyable</a>. | ||||
| Scott Meyers [<a href="#references">2</a>] explains why a class would be defined like that. | ||||
| </p> | ||||
| <p> | ||||
| There is another, less obvious disadvantage to the fourth form, <code>T4 var4 = T4()</code>: | ||||
| It suffers from various  <a href="#compiler_issues">compiler issues</a>, causing | ||||
| a variable to be left uninitialized in some compiler specific cases. | ||||
| </p> | ||||
| <p> | ||||
| The template <a href="#val_init"><code>value_initialized</code></a> | ||||
| offers a generic way to initialize | ||||
| an object, like <code>T4 var4 = T4()</code>, but without requiring its type | ||||
| to be CopyConstructible. And it offers a workaround to those compiler issues | ||||
| regarding value-initialization as well! It allows getting an initialized | ||||
| variable of any type; it <em>only</em> requires the type to be DefaultConstructible. | ||||
| A properly <em>value-initialized</em> object of type <code>T</code> is | ||||
| constructed by the following declaration: | ||||
| <pre> | ||||
|   value_initialized<T> var; | ||||
| </pre> | ||||
| </p> | ||||
| <p> | ||||
| The <code>const</code> object <a href="#initialized_value"><code>initialized_value</code></a> | ||||
| allows value-initializing a variable as follows: | ||||
| <pre> | ||||
|   T var = initialized_value ; | ||||
| </pre> | ||||
| This form of initialization is semantically equivalent to <code>T4 var4 = T4()</code>, | ||||
| but robust against the aforementioned compiler issues. | ||||
|  | ||||
| </p> | ||||
|  | ||||
| <h2><a name="details"></a>Details</h2> | ||||
| <p>The C++ standard [<a href="#references">3</a>] contains the definitions  | ||||
| <p>The C++ standard [<a href="#references">1</a>] contains the definitions  | ||||
|     of <code>zero-initialization</code> and <code>default-initialization</code>. | ||||
|      Informally, zero-initialization means that the object is given the initial | ||||
|      value 0 (converted to the type) and default-initialization means that | ||||
|  POD   [<a href="#references">4</a>] types are zero-initialized, while non-POD class | ||||
|  POD   [<a href="#references">2</a>] types are zero-initialized, while class | ||||
|  types   are initialized with their corresponding default constructors. A | ||||
| <i>declaration</i>   can contain an <i>initializer</i>, which specifies the | ||||
| object's initial value.  The initializer can be just '()', which states that | ||||
| the object shall be value-initialized  (but see below). However, if a <i>declaration</i>  | ||||
| the object shall be default-initialized  (but see below). However, if a <i>declaration</i>  | ||||
|   has no <i>initializer</i>  and it is of a non-<code>const</code>, non-<code>static</code>  | ||||
|    POD type, the initial value is indeterminate: <cite>(see §8.5, [dcl.init], for the | ||||
|    POD type, the initial value is indeterminate:<cite>(see §8.5 for the | ||||
|    accurate definitions).</cite></p> | ||||
|                     | ||||
| <pre>int x ; // no initializer. x value is indeterminate.<br>std::string s ; // no initializer, s is default-constructed.<br><br>int y = int() ; <br>// y is initialized using copy-initialization<br>// but the temporary uses an empty set of parentheses as the initializer,<br>// so it is default-constructed.<br>// A default constructed POD type is zero-initialized,<br>// therefore, y == 0.<br><br>void foo ( std::string ) ;<br>foo ( std::string() ) ; <br>// the temporary string is default constructed <br>// as indicated by the initializer ()  </pre> | ||||
| @@ -170,11 +87,14 @@ the object shall be value-initialized  (but see below). However, if a <i>declara | ||||
| <p>In order to specify value-initialization of an object we need to use the | ||||
|      empty-set initializer: (). </p> | ||||
|                     | ||||
| <p><i>(but recall that the current C++ Standard states that '()' invokes default-initialization, | ||||
| not value-initialization)</i></p> | ||||
|                     | ||||
| <p>As before, a declaration with no intializer specifies default-initialization,  | ||||
|     and a declaration with a non-empty initializer specifies copy (=xxx) or | ||||
|   direct  (xxx) initialization. </p> | ||||
|                     | ||||
| <pre>template<class T> void eat(T);<br>int x ; // indeterminate initial value.<br>std::string s; // default-initialized.<br>eat ( int() ) ; // value-initialized<br>eat ( std::string() ) ; // value-initialized</pre> | ||||
| <pre>template<class T> void eat(T);<br>int x ; // indeterminate initial value.<br>std::string s; // default-initialized.<br>eat ( int() ) ; // value-initialized<br>eat ( std::string() ) ; // value-initialied</pre> | ||||
|                      | ||||
| <h4><a name="valueinitsyn">value-initialization</a> syntax</h4> | ||||
|                     | ||||
| @@ -182,7 +102,7 @@ the object shall be value-initialized  (but see below). However, if a <i>declara | ||||
| parentheses is not permitted by the syntax of initializers because it is | ||||
| parsed as the declaration of a function taking no arguments: </p> | ||||
|                     | ||||
| <pre>int x() ; // declares function int(*)()</pre> | ||||
| <pre>int x() ; // declares function int(*)()<br>int y ( int() ) ; // decalares function int(*)( int(*)() )</pre> | ||||
|                      | ||||
| <p>Thus, the empty () must be put in some other initialization context.</p> | ||||
|                     | ||||
| @@ -204,56 +124,14 @@ data member:</p> | ||||
|                     | ||||
| <pre>template<class T> <br>struct W <br>{<br>  // value-initialization of 'data' here.<br>  W() : data() {}<br>  T data ;<br>} ;<br>W<int> w ;<br>// w.data is value-initialized for any type. </pre> | ||||
|                      | ||||
| <p>This is the solution as it was supplied by earlier versions of the | ||||
| <code>value_initialized<T></code> template | ||||
|      class. Unfortunately this approach suffered from various compiler issues.</p> | ||||
| 		  | ||||
| <h4><a name="compiler_issues">compiler issues</a> </h4> | ||||
|  | ||||
| Various compilers haven't yet fully implemented value-initialization. | ||||
| So when an object should be <em>value-initialized</em> (according to the C++ Standard), | ||||
| it <em>may</em> in practice still be left uninitialized, because of those | ||||
| compiler issues! It's hard to make a general statement on what those issues | ||||
| are like, because they depend on the compiler you are using, its version number, | ||||
| and the type of object you would like to have value-initialized. | ||||
| Compilers usually support value-initialization for built-in types properly. | ||||
| But objects of user-defined types that involve <em>aggregates</em> may <em>in some cases</em> | ||||
| be partially, or even entirely left uninitialized, when they should be value-initialized. | ||||
| </p> | ||||
| <p> | ||||
| We have encountered issues regarding value-initialization on compilers by | ||||
| Microsoft, Sun, Borland, and GNU. Here is a list of bug reports on those issues: | ||||
| <table summary="Compiler bug reports regarding value-initialization" border="0" cellpadding="7" cellspacing="1" > | ||||
| <tr><td> | ||||
| <a href="https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=100744"> | ||||
| Microsoft Feedback ID 100744 - Value-initialization in new-expression</a> | ||||
| <br>Reported by Pavel Kuznetsov (MetaCommunications Engineering), 2005-07-28 | ||||
| <br> | ||||
| <a href="http://gcc.gnu.org/bugzilla/show_bug.cgi?id=30111"> | ||||
| GCC Bug 30111 - Value-initialization of POD base class doesn't initialize members</a> | ||||
| <br>Reported by Jonathan Wakely, 2006-12-07  | ||||
| <br> | ||||
| <a href="http://gcc.gnu.org/bugzilla/show_bug.cgi?id=33916"> | ||||
| GCC Bug 33916 - Default constructor fails to initialize array members</a> | ||||
| <br>Reported by Michael Elizabeth Chastain, 2007-10-26 | ||||
| <br> | ||||
| <a href="http://qc.codegear.com/wc/qcmain.aspx?d=51854"> | ||||
| Borland Report 51854 - Value-initialization: POD struct should be zero-initialized</a> | ||||
| <br>Reported by Niels Dekker (LKEB, Leiden University Medical Center), 2007-09-11 | ||||
| <br> | ||||
| </td></tr></table> | ||||
| </p><p> | ||||
| New versions of <code>value_initialized</code> | ||||
| (Boost release version 1.35 or higher) | ||||
| offer a workaround to these issues: <code>value_initialized</code> will now clear | ||||
| its internal data, prior to constructing the object that it contains. | ||||
| </p> | ||||
| <p><code>This is the solution supplied by the value_initialized<> template | ||||
|      class.</code></p> | ||||
|                     | ||||
| <h2><a name="types"></a>Types and objects</h2> | ||||
| <h2><a name="types"></a>Types</h2> | ||||
|                     | ||||
| <h2><a name="val_init"><code>template class value_initialized<T></code></a></h2> | ||||
|                     | ||||
| <pre>namespace boost {<br><br>template<class T><br>class value_initialized<br>{<br>  public :<br>    value_initialized() : x() {}<br>    operator T&() const { return x ; }<br>    T& data() const { return x ; }<br>    void swap( value_initialized<T>& );<br><br>  private :<br>    <i>unspecified</i> x ;<br>} ;<br><br>template<class T><br>T const& get ( value_initialized<T> const& x )<br>{<br>  return x.data() ;<br>}<br><br>template<class T><br>T& get ( value_initialized<T>& x )<br>{<br>  return x.data() ;<br>}<br><br>} // namespace boost<br></pre> | ||||
| <pre>namespace boost {<br><br>template<class T><br>class value_initialized<br>{<br>  public :<br>    value_initialized() : x() {}<br>    operator T&() const { return x ; }<br>    T& data() const { return x ; }<br><br>  private :<br>    <i>unspecified</i> x ;<br>} ;<br><br>template<class T><br>T const& get ( value_initialized<T> const& x )<br>{<br>  return x.data() ;<br>}<br><br>template<class T><br>T& get ( value_initialized<T>& x )<br>{<br>  return x.data() ;<br>}<br><br>} // namespace boost<br></pre> | ||||
|                      | ||||
| <p>An object of this template class is a <code>T</code>-wrapper convertible  | ||||
|     to <code>'T&'</code> whose wrapped object (data member of type <code>T</code>)  | ||||
| @@ -276,10 +154,6 @@ non-member    function <code>get()</code>:  </p> | ||||
| <p>Both <code>const</code> and non-<code>const</code> objects can be wrapped.  | ||||
|     Mutable objects can be modified directly from within the wrapper but constant | ||||
|     objects cannot:</p> | ||||
|  | ||||
| <p>When <code>T</code> is a <em>Swappable</em> type, <code>value_initialized<T></code> | ||||
|     is swappable as well, by calling its <code>swap</code> member function | ||||
|     as well as by calling <code>boost::swap</code>.</p> | ||||
|                     | ||||
| <pre>value_initialized<int> x ; <br>static_cast<int&>(x) = 1 ; // OK<br>get(x) = 1 ; // OK<br><br>value_initialized<int const> y ; <br>static_cast<int&>(y) = 1 ; // ERROR: cannot cast to int&<br>static_cast<int const&>(y) = 1 ; // ERROR: cannot modify a const value<br>get(y) = 1 ; // ERROR: cannot modify a const value</pre> | ||||
|                      | ||||
| @@ -315,83 +189,31 @@ wrapped object from within a constant wrapper can be avoided if access to | ||||
| the wrapped object is always performed with the <code>get()</code> idiom:</p> | ||||
|                     | ||||
| <pre>value_initialized<int> x ;<br>get(x) = 1 ; // OK<br><br>value_initialized<int const> cx ;<br>get(x) = 1 ; // ERROR: Cannot modify a const object<br><br>value_initialized<int> const x_c ;<br>get(x_c) = 1 ; // ERROR: Cannot modify a const object<br><br>value_initialized<int const> const cx_c ;<br>get(cx_c) = 1 ; // ERROR: Cannot modify a const object<br></pre> | ||||
|  | ||||
| <h2><a name="initialized_value"><code>initialized_value</code></a></h2> | ||||
|  | ||||
| <pre> | ||||
| namespace boost { | ||||
| class initialized_value_t | ||||
| { | ||||
|   public : | ||||
|     template <class T> operator T() const ; | ||||
| }; | ||||
|  | ||||
| initialized_value_t const initialized_value = {} ; | ||||
|  | ||||
| } // namespace boost | ||||
| </pre> | ||||
|  | ||||
| <code>initialized_value</code> provides a convenient way to get | ||||
| an initialized value: its conversion operator provides an appropriate | ||||
| <em>value-initialized</em> object for any CopyConstructible type. | ||||
|  | ||||
| Suppose you need to have an initialized variable of type <code>T</code>. | ||||
| You could do it as follows: | ||||
| <pre> | ||||
|   T var = T(); | ||||
| </pre> | ||||
| But as mentioned before, this form suffers from various compiler issues. | ||||
| The template <code>value_initialized</code> offers a workaround: | ||||
| <pre> | ||||
|   T var = get( value_initialized<T>() ); | ||||
| </pre> | ||||
| Unfortunately both forms repeat the type name, which | ||||
| is rather short now (<code>T</code>), but could of course be  | ||||
| more like <code>Namespace::Template<Arg>::Type</code>. | ||||
| Instead, one could use <code>initialized_value</code> as follows: | ||||
| <pre> | ||||
|   T var = initialized_value ; | ||||
| </pre> | ||||
|                      | ||||
| <h3><a name="references">References</a></h3> | ||||
|           [1] Bjarne Stroustrup, Gabriel Dos Reis, and J. Stephen Adamczyk wrote | ||||
|           various papers, proposing to extend the support for brace-enclosed <em>initializer lists</em> | ||||
|           in the next version of C++. | ||||
|           This would allow a variable <code>var</code> of any DefaultConstructible type | ||||
|           <code>T</code> to be <em>value-initialized</em> by doing <code>T var = {}</code>. | ||||
|           The papers are listed at Bjarne's web page, | ||||
|           <a href="http://www.research.att.com/~bs/WG21.html">My C++ Standards committee papers</a>  <br>  | ||||
|           [2] Scott Meyers, Effective C++, Third Edition, item 6, | ||||
|           <em>Explicitly disallow the use of compiler-generated functions you do not want</em>,  | ||||
|           <a href="http://www.aristeia.com/books.html">Scott Meyers: Books and CDs</a>  <br> | ||||
|           [3] The C++ Standard, Second edition (2003), ISO/IEC 14882:2003 <br> | ||||
|           [4] POD stands for "Plain Old Data" | ||||
|  | ||||
|           [1] The C++ Standard, ISO/IEC 14882:98 <br> | ||||
|           [2] Plain Old Data            | ||||
| <h3><a name="acknowledgements"></a>Acknowledgements</h3> | ||||
|      value_initialized was developed by Fernando Cacciola, with help and | ||||
| suggestions from David Abrahams and Darin Adler.<br> | ||||
| Special thanks to Björn Karlsson who carefully edited and completed this documentation. | ||||
|                   | ||||
| <p>value_initialized was reimplemented by Fernando Cacciola and Niels Dekker | ||||
| for Boost release version 1.35 (2008), offering a workaround to various compiler issues. | ||||
|      </p> | ||||
| <p>initialized_value was written by Niels Dekker, and added to Boost release version 1.36 (2008). | ||||
|      </p> | ||||
| <p>Developed by <a href="mailto:fernando_cacciola@hotmail.com">Fernando Cacciola</a>, | ||||
|      the latest version of this file can be found at <a | ||||
|  href="http://www.boost.org">www.boost.org</a>. | ||||
|      </p> | ||||
| Special thanks to Bj<EFBFBD>rn Karlsson who carefully edited and completed this documentation. | ||||
| <pre> </pre> | ||||
|                      | ||||
| <hr>           | ||||
| <p>Revised 28 August 2008</p> | ||||
| <p>Revised 19 September 2002</p> | ||||
|                     | ||||
| <p>© Copyright Fernando Cacciola, 2002, 2008.</p> | ||||
| <p>© Copyright boost.org 2002. Permission to copy, use, modify, sell  | ||||
| and distribute this document is granted provided this copyright notice  appears  | ||||
| in all copies. This document is provided "as is" without express or implied  | ||||
| warranty, and with no claim as to its suitability for any purpose.</p> | ||||
|                     | ||||
| <p>Distributed under the Boost Software License, Version 1.0. See | ||||
| <a href="http://www.boost.org/LICENSE_1_0.txt">www.boost.org/LICENSE_1_0.txt</a></p> | ||||
|  | ||||
| <p>Developed by <a href="mailto:fernando_cacciola@hotmail.com">Fernando Cacciola</a>, | ||||
|      the latest version of this file can be found at <a | ||||
|  href="http://www.boost.org">www.boost.org</a>, and the boost discussion list | ||||
| at <a href="http://www.yahoogroups.com/list/boost">www.yahoogroups.com/list/boost</a>. | ||||
|      </p> | ||||
|  <br> | ||||
|  <br> | ||||
|      | ||||
| </body> | ||||
| </html> | ||||
| </html> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| // Copyright 2002-2008, Fernando Luis Cacciola Carballal. | ||||
| // (C) 2002, Fernando Luis Cacciola Carballal. | ||||
| // | ||||
| // Distributed under the Boost Software License, Version 1.0. (See | ||||
| // accompanying file LICENSE_1_0.txt or copy at | ||||
| @@ -6,17 +6,12 @@ | ||||
| // | ||||
| // Test program for "boost/utility/value_init.hpp" | ||||
| // | ||||
| // 21 Ago 2002 (Created) Fernando Cacciola | ||||
| // 15 Jan 2008 (Added tests regarding compiler issues) Fernando Cacciola, Niels Dekker | ||||
| // 23 May 2008 (Added tests regarding initialized_value) Niels Dekker | ||||
| // 21 Ago 2008 (Added swap test) Niels Dekker | ||||
| // Initial: 21 Agu 2002 | ||||
|  | ||||
| #include <cstring>  // For memcmp. | ||||
| #include <iostream> | ||||
| #include <string> | ||||
|  | ||||
| #include "boost/utility/value_init.hpp" | ||||
| #include <boost/shared_ptr.hpp> | ||||
|  | ||||
| #ifdef __BORLANDC__ | ||||
| #pragma hdrstop | ||||
| @@ -54,7 +49,7 @@ struct NonPODBase | ||||
| struct NonPOD : NonPODBase | ||||
| { | ||||
|   NonPOD () : id() {} | ||||
|   explicit NonPOD ( std::string const& id_) : id(id_) {} | ||||
|   NonPOD ( std::string const& id_) : id(id_) {} | ||||
|  | ||||
|   friend std::ostream& operator << ( std::ostream& os, NonPOD const& npod ) | ||||
|     { return os << '(' << npod.id << ')' ; } | ||||
| @@ -67,9 +62,6 @@ struct NonPOD : NonPODBase | ||||
|  | ||||
| // | ||||
| // Sample aggregate POD struct type | ||||
| // Some compilers do not correctly value-initialize such a struct, for example: | ||||
| // Borland C++ Report #51854, "Value-initialization: POD struct should be zero-initialized " | ||||
| // http://qc.codegear.com/wc/qcmain.aspx?d=51854 | ||||
| // | ||||
| struct AggregatePODStruct | ||||
| { | ||||
| @@ -81,178 +73,13 @@ struct AggregatePODStruct | ||||
| bool operator == ( AggregatePODStruct const& lhs, AggregatePODStruct const& rhs ) | ||||
| { return lhs.f == rhs.f && lhs.c == rhs.c && lhs.i == rhs.i ; } | ||||
|  | ||||
| // | ||||
| // An aggregate struct that contains an std::string and an int. | ||||
| // Pavel Kuznetsov (MetaCommunications Engineering) used a struct like | ||||
| // this to reproduce the Microsoft Visual C++ compiler bug, reported as | ||||
| // Feedback ID 100744, "Value-initialization in new-expression" | ||||
| // https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=100744 | ||||
| // | ||||
| struct StringAndInt | ||||
| { | ||||
|   std::string s; | ||||
|   int i; | ||||
| }; | ||||
|  | ||||
| bool operator == ( StringAndInt const& lhs, StringAndInt const& rhs ) | ||||
| { return lhs.s == rhs.s && lhs.i == rhs.i ; } | ||||
|  | ||||
|  | ||||
| // | ||||
| // A struct that has an explicit (user defined) destructor. | ||||
| // Some compilers do not correctly value-initialize such a struct, for example: | ||||
| // Microsoft Visual C++, Feedback ID 100744, "Value-initialization in new-expression" | ||||
| // https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=100744 | ||||
| // | ||||
| struct StructWithDestructor | ||||
| { | ||||
|   int i; | ||||
|   ~StructWithDestructor() {} | ||||
| }; | ||||
|  | ||||
| bool operator == ( StructWithDestructor const& lhs, StructWithDestructor const& rhs ) | ||||
| { return lhs.i == rhs.i ; } | ||||
|  | ||||
|  | ||||
| // | ||||
| // A struct that has a virtual function. | ||||
| // Some compilers do not correctly value-initialize such a struct either, for example: | ||||
| // Microsoft Visual C++, Feedback ID 100744, "Value-initialization in new-expression" | ||||
| // https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=100744 | ||||
| // | ||||
| struct StructWithVirtualFunction | ||||
| { | ||||
|   int i; | ||||
|   virtual void VirtualFunction();  | ||||
| }; | ||||
|  | ||||
| void StructWithVirtualFunction::VirtualFunction() | ||||
| { | ||||
| } | ||||
|  | ||||
| bool operator == ( StructWithVirtualFunction const& lhs, StructWithVirtualFunction const& rhs ) | ||||
| { return lhs.i == rhs.i ; } | ||||
|  | ||||
|  | ||||
| // | ||||
| // A struct that is derived from an aggregate POD struct. | ||||
| // Some compilers do not correctly value-initialize such a struct, for example: | ||||
| // GCC Bugzilla Bug 30111,  "Value-initialization of POD base class doesn't initialize members", | ||||
| // reported by Jonathan Wakely, http://gcc.gnu.org/bugzilla/show_bug.cgi?id=30111 | ||||
| // | ||||
| struct DerivedFromAggregatePODStruct : AggregatePODStruct | ||||
| { | ||||
|   DerivedFromAggregatePODStruct() : AggregatePODStruct() {} | ||||
| }; | ||||
|  | ||||
| // | ||||
| // A struct that wraps an aggregate POD struct as data member. | ||||
| // | ||||
| struct AggregatePODStructWrapper | ||||
| { | ||||
|   AggregatePODStructWrapper() : dataMember() {} | ||||
|   AggregatePODStruct dataMember; | ||||
| }; | ||||
|  | ||||
| bool operator == ( AggregatePODStructWrapper const& lhs, AggregatePODStructWrapper const& rhs ) | ||||
| { return lhs.dataMember == rhs.dataMember ; } | ||||
|  | ||||
| typedef unsigned char ArrayOfBytes[256]; | ||||
|  | ||||
|  | ||||
| // | ||||
| // A struct that allows testing whether the appropriate copy functions are called. | ||||
| // | ||||
| struct CopyFunctionCallTester | ||||
| { | ||||
|   bool is_copy_constructed; | ||||
|   bool is_assignment_called; | ||||
|  | ||||
|   CopyFunctionCallTester() | ||||
|   : is_copy_constructed(false), is_assignment_called(false) {} | ||||
|  | ||||
|   CopyFunctionCallTester(const CopyFunctionCallTester & ) | ||||
|   : is_copy_constructed(true), is_assignment_called(false) {} | ||||
|  | ||||
|   CopyFunctionCallTester & operator=(const CopyFunctionCallTester & ) | ||||
|   { | ||||
|     is_assignment_called = true ; | ||||
|     return *this ; | ||||
|   } | ||||
| }; | ||||
|  | ||||
|  | ||||
| // | ||||
| // A struct that allows testing whether its customized swap function is called. | ||||
| // | ||||
| struct SwapFunctionCallTester | ||||
| { | ||||
|   bool is_custom_swap_called; | ||||
|   int data; | ||||
|  | ||||
|   SwapFunctionCallTester() | ||||
|   : is_custom_swap_called(false), data(0) {} | ||||
|  | ||||
|   SwapFunctionCallTester(const SwapFunctionCallTester & arg) | ||||
|   : is_custom_swap_called(false), data(arg.data) {} | ||||
|  | ||||
|   void swap(SwapFunctionCallTester & arg) | ||||
|   { | ||||
|     std::swap(data, arg.data); | ||||
|     is_custom_swap_called = true; | ||||
|     arg.is_custom_swap_called = true; | ||||
|   } | ||||
| }; | ||||
|  | ||||
| void swap(SwapFunctionCallTester & lhs, SwapFunctionCallTester & rhs) | ||||
| { | ||||
|   lhs.swap(rhs); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| template<class T> | ||||
| void check_initialized_value ( T const& y ) | ||||
| void test ( T const& y, T const& z ) | ||||
| { | ||||
|   T initializedValue = boost::initialized_value ; | ||||
|   BOOST_CHECK ( y == initializedValue ) ; | ||||
| } | ||||
|  | ||||
| #ifdef  __BORLANDC__ | ||||
| #if __BORLANDC__ == 0x582 | ||||
| void check_initialized_value( NonPOD const& ) | ||||
| { | ||||
|   // The initialized_value check is skipped for Borland 5.82 | ||||
|   // and this type (NonPOD), because the following statement | ||||
|   // won't compile on this particular compiler version: | ||||
|   //   NonPOD initializedValue = boost::initialized_value() ; | ||||
|   // | ||||
|   // This is caused by a compiler bug, that is fixed with a newer version | ||||
|   // of the Borland compiler.  The Release Notes for Delphi(R) 2007 for | ||||
|   // Win32(R) and C++Builder(R) 2007 (http://dn.codegear.com/article/36575) | ||||
|   // say about similar statements: | ||||
|   //   both of these statements now compile but under 5.82 got the error: | ||||
|   //   Error E2015: Ambiguity between 'V::V(const A &)' and 'V::V(const V &)' | ||||
| } | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| // | ||||
| // This test function tests boost::value_initialized<T> for a specific type T. | ||||
| // The first argument (y) is assumed have the value of a value-initialized object. | ||||
| // Returns true on success. | ||||
| // | ||||
| template<class T> | ||||
| bool test ( T const& y, T const& z ) | ||||
| { | ||||
|   const boost::unit_test::counter_t counter_before_test = boost::minimal_test::errors_counter(); | ||||
|  | ||||
|   check_initialized_value(y); | ||||
|  | ||||
|   boost::value_initialized<T> x ; | ||||
|   BOOST_CHECK ( y == x ) ; | ||||
|   BOOST_CHECK ( y == boost::get(x) ) ; | ||||
|  | ||||
|   static_cast<T&>(x) = z ; | ||||
|   boost::get(x) = z ; | ||||
|   BOOST_CHECK ( x == z ) ; | ||||
| @@ -264,16 +91,6 @@ bool test ( T const& y, T const& z ) | ||||
|   x_c_ref = z ; | ||||
|   BOOST_CHECK ( x_c == z ) ; | ||||
|  | ||||
|   boost::value_initialized<T> const copy1 = x; | ||||
|   BOOST_CHECK ( boost::get(copy1) == boost::get(x) ) ; | ||||
|  | ||||
|   boost::value_initialized<T> copy2; | ||||
|   copy2 = x; | ||||
|   BOOST_CHECK ( boost::get(copy2) == boost::get(x) ) ; | ||||
|    | ||||
|   boost::shared_ptr<boost::value_initialized<T> > ptr( new boost::value_initialized<T> ); | ||||
|   BOOST_CHECK ( y == *ptr ) ; | ||||
|  | ||||
| #if !BOOST_WORKAROUND(BOOST_MSVC, < 1300) | ||||
|   boost::value_initialized<T const> cx ; | ||||
|   BOOST_CHECK ( y == cx ) ; | ||||
| @@ -283,85 +100,21 @@ bool test ( T const& y, T const& z ) | ||||
|   BOOST_CHECK ( y == cx_c ) ; | ||||
|   BOOST_CHECK ( y == boost::get(cx_c) ) ; | ||||
| #endif | ||||
|  | ||||
|   return boost::minimal_test::errors_counter() == counter_before_test ; | ||||
| } | ||||
|  | ||||
| int test_main(int, char **) | ||||
| { | ||||
|   BOOST_CHECK ( test( 0,1234 ) ) ; | ||||
|   BOOST_CHECK ( test( 0.0,12.34 ) ) ; | ||||
|   BOOST_CHECK ( test( POD(0,0,0.0), POD('a',1234,56.78) ) ) ; | ||||
|   BOOST_CHECK ( test( NonPOD( std::string() ), NonPOD( std::string("something") ) ) ) ; | ||||
|   test( 0,1234 ) ; | ||||
|   test( 0.0,12.34 ) ; | ||||
|   test( POD(0,0,0.0), POD('a',1234,56.78) ) ; | ||||
|   test( NonPOD( std::string() ), NonPOD( std::string("something") ) ) ; | ||||
|  | ||||
|   NonPOD NonPOD_object( std::string("NonPOD_object") ); | ||||
|   BOOST_CHECK ( test<NonPOD *>( 0, &NonPOD_object ) ) ; | ||||
|   test<NonPOD *>( 0, &NonPOD_object ) ; | ||||
|  | ||||
|   AggregatePODStruct zeroInitializedAggregatePODStruct = { 0.0f, '\0', 0 }; | ||||
|   AggregatePODStruct nonZeroInitializedAggregatePODStruct = { 1.25f, 'a', -1 }; | ||||
|   BOOST_CHECK ( test(zeroInitializedAggregatePODStruct, nonZeroInitializedAggregatePODStruct) ); | ||||
|  | ||||
|   StringAndInt stringAndInt0; | ||||
|   StringAndInt stringAndInt1; | ||||
|   stringAndInt0.i = 0; | ||||
|   stringAndInt1.i = 1; | ||||
|   stringAndInt1.s = std::string("1"); | ||||
|   BOOST_CHECK ( test(stringAndInt0, stringAndInt1) ); | ||||
|  | ||||
|   StructWithDestructor structWithDestructor0; | ||||
|   StructWithDestructor structWithDestructor1; | ||||
|   structWithDestructor0.i = 0; | ||||
|   structWithDestructor1.i = 1; | ||||
|   BOOST_CHECK ( test(structWithDestructor0, structWithDestructor1) ); | ||||
|  | ||||
|   StructWithVirtualFunction structWithVirtualFunction0; | ||||
|   StructWithVirtualFunction structWithVirtualFunction1; | ||||
|   structWithVirtualFunction0.i = 0; | ||||
|   structWithVirtualFunction1.i = 1; | ||||
|   BOOST_CHECK ( test(structWithVirtualFunction0, structWithVirtualFunction1) ); | ||||
|  | ||||
|   DerivedFromAggregatePODStruct derivedFromAggregatePODStruct0; | ||||
|   DerivedFromAggregatePODStruct derivedFromAggregatePODStruct1; | ||||
|   static_cast<AggregatePODStruct &>(derivedFromAggregatePODStruct0) = zeroInitializedAggregatePODStruct; | ||||
|   static_cast<AggregatePODStruct &>(derivedFromAggregatePODStruct1) = nonZeroInitializedAggregatePODStruct; | ||||
|   BOOST_CHECK ( test(derivedFromAggregatePODStruct0, derivedFromAggregatePODStruct1) ); | ||||
|  | ||||
|   AggregatePODStructWrapper aggregatePODStructWrapper0; | ||||
|   AggregatePODStructWrapper aggregatePODStructWrapper1; | ||||
|   aggregatePODStructWrapper0.dataMember = zeroInitializedAggregatePODStruct; | ||||
|   aggregatePODStructWrapper1.dataMember = nonZeroInitializedAggregatePODStruct; | ||||
|   BOOST_CHECK ( test(aggregatePODStructWrapper0, aggregatePODStructWrapper1) ); | ||||
|  | ||||
|   ArrayOfBytes zeroInitializedArrayOfBytes = { 0 }; | ||||
|   boost::value_initialized<ArrayOfBytes> valueInitializedArrayOfBytes; | ||||
|   BOOST_CHECK (std::memcmp(get(valueInitializedArrayOfBytes), zeroInitializedArrayOfBytes, sizeof(ArrayOfBytes)) == 0); | ||||
|  | ||||
|   boost::value_initialized<ArrayOfBytes> valueInitializedArrayOfBytes2; | ||||
|   valueInitializedArrayOfBytes2 = valueInitializedArrayOfBytes; | ||||
|   BOOST_CHECK (std::memcmp(get(valueInitializedArrayOfBytes), get(valueInitializedArrayOfBytes2), sizeof(ArrayOfBytes)) == 0); | ||||
|  | ||||
|   boost::value_initialized<CopyFunctionCallTester> copyFunctionCallTester1; | ||||
|   BOOST_CHECK ( ! get(copyFunctionCallTester1).is_copy_constructed); | ||||
|   BOOST_CHECK ( ! get(copyFunctionCallTester1).is_assignment_called); | ||||
|  | ||||
|   boost::value_initialized<CopyFunctionCallTester> copyFunctionCallTester2 = boost::value_initialized<CopyFunctionCallTester>(copyFunctionCallTester1); | ||||
|   BOOST_CHECK ( get(copyFunctionCallTester2).is_copy_constructed); | ||||
|   BOOST_CHECK ( ! get(copyFunctionCallTester2).is_assignment_called); | ||||
|  | ||||
|   boost::value_initialized<CopyFunctionCallTester> copyFunctionCallTester3; | ||||
|   copyFunctionCallTester3 = boost::value_initialized<CopyFunctionCallTester>(copyFunctionCallTester1); | ||||
|   BOOST_CHECK ( ! get(copyFunctionCallTester3).is_copy_constructed); | ||||
|   BOOST_CHECK ( get(copyFunctionCallTester3).is_assignment_called); | ||||
|  | ||||
|   boost::value_initialized<SwapFunctionCallTester> swapFunctionCallTester1; | ||||
|   boost::value_initialized<SwapFunctionCallTester> swapFunctionCallTester2; | ||||
|   get(swapFunctionCallTester1).data = 1; | ||||
|   get(swapFunctionCallTester2).data = 2; | ||||
|   boost::swap(swapFunctionCallTester1, swapFunctionCallTester2); | ||||
|   BOOST_CHECK( get(swapFunctionCallTester1).data == 2 ); | ||||
|   BOOST_CHECK( get(swapFunctionCallTester2).data == 1 ); | ||||
|   BOOST_CHECK( get(swapFunctionCallTester1).is_custom_swap_called ); | ||||
|   BOOST_CHECK( get(swapFunctionCallTester2).is_custom_swap_called ); | ||||
|   test(zeroInitializedAggregatePODStruct, nonZeroInitializedAggregatePODStruct); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -370,3 +123,6 @@ int test_main(int, char **) | ||||
| unsigned int expected_failures = 0; | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| // Copyright 2002, Fernando Luis Cacciola Carballal. | ||||
| // (C) 2002, Fernando Luis Cacciola Carballal. | ||||
| // | ||||
| // Distributed under the Boost Software License, Version 1.0. (See | ||||
| // accompanying file LICENSE_1_0.txt or copy at | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| // Copyright 2002, Fernando Luis Cacciola Carballal. | ||||
| // (C) 2002, Fernando Luis Cacciola Carballal. | ||||
| // | ||||
| // Distributed under the Boost Software License, Version 1.0. (See | ||||
| // accompanying file LICENSE_1_0.txt or copy at | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| // Copyright 2002, Fernando Luis Cacciola Carballal. | ||||
| // (C) 2002, Fernando Luis Cacciola Carballal. | ||||
| // | ||||
| // Distributed under the Boost Software License, Version 1.0. (See | ||||
| // accompanying file LICENSE_1_0.txt or copy at | ||||
|   | ||||
							
								
								
									
										126
									
								
								verify_test.cpp
									
									
									
									
									
								
							
							
						
						
									
										126
									
								
								verify_test.cpp
									
									
									
									
									
								
							| @@ -1,126 +0,0 @@ | ||||
| // | ||||
| //  verify_test.cpp - a test for BOOST_VERIFY | ||||
| // | ||||
| //  Copyright (c) 2002 Peter Dimov and Multi Media Ltd. | ||||
| //  Copyright (c) 2007 Peter Dimov | ||||
| // | ||||
| // 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) | ||||
| // | ||||
|  | ||||
| #include <boost/detail/lightweight_test.hpp> | ||||
|  | ||||
| #include <boost/assert.hpp> | ||||
|  | ||||
| int f( int & x ) | ||||
| { | ||||
|     return ++x; | ||||
| } | ||||
|  | ||||
| void test_default() | ||||
| { | ||||
|     int x = 1; | ||||
|  | ||||
|     BOOST_VERIFY( 1 ); | ||||
|     BOOST_VERIFY( x == 1 ); | ||||
|     BOOST_VERIFY( ++x ); | ||||
|     BOOST_VERIFY( f(x) ); | ||||
|     BOOST_VERIFY( &x ); | ||||
|  | ||||
|     BOOST_TEST( x == 3 ); | ||||
| } | ||||
|  | ||||
| #define BOOST_DISABLE_ASSERTS | ||||
| #include <boost/assert.hpp> | ||||
|  | ||||
| void test_disabled() | ||||
| { | ||||
|     int x = 1; | ||||
|  | ||||
|     BOOST_VERIFY( 1 ); | ||||
|     BOOST_VERIFY( x == 1 ); | ||||
|     BOOST_VERIFY( ++x ); | ||||
|     BOOST_VERIFY( f(x) ); | ||||
|     BOOST_VERIFY( &x ); | ||||
|  | ||||
|     BOOST_TEST( x == 3 ); | ||||
|  | ||||
|     BOOST_VERIFY( 0 ); | ||||
|     BOOST_VERIFY( !x ); | ||||
|     BOOST_VERIFY( x == 0 ); | ||||
|     BOOST_VERIFY( !++x ); | ||||
|     BOOST_VERIFY( !f(x) ); | ||||
|  | ||||
|     BOOST_TEST( x == 5 ); | ||||
|  | ||||
|     void * p = 0; | ||||
|     BOOST_VERIFY( p ); | ||||
| } | ||||
|  | ||||
| #undef BOOST_DISABLE_ASSERTS | ||||
|  | ||||
| #define BOOST_ENABLE_ASSERT_HANDLER | ||||
| #include <boost/assert.hpp> | ||||
| #include <boost/config.hpp> | ||||
| #include <cstdio> | ||||
|  | ||||
| int handler_invoked = 0; | ||||
|  | ||||
| void boost::assertion_failed(char const * expr, char const * function, char const * file, long line) | ||||
| { | ||||
| #if !defined(BOOST_NO_STDC_NAMESPACE) | ||||
|     using std::printf; | ||||
| #endif | ||||
|  | ||||
|     printf("Expression: %s\nFunction: %s\nFile: %s\nLine: %ld\n\n", expr, function, file, line); | ||||
|     ++handler_invoked; | ||||
| } | ||||
|  | ||||
| struct X | ||||
| { | ||||
|     static bool f() | ||||
|     { | ||||
|         BOOST_VERIFY( 0 ); | ||||
|         return false; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| void test_handler() | ||||
| { | ||||
|     int x = 1; | ||||
|  | ||||
|     BOOST_VERIFY( 1 ); | ||||
|     BOOST_VERIFY( x == 1 ); | ||||
|     BOOST_VERIFY( ++x ); | ||||
|     BOOST_VERIFY( f(x) ); | ||||
|     BOOST_VERIFY( &x ); | ||||
|  | ||||
|     BOOST_TEST( x == 3 ); | ||||
|  | ||||
|     BOOST_VERIFY( 0 ); | ||||
|     BOOST_VERIFY( !x ); | ||||
|     BOOST_VERIFY( x == 0 ); | ||||
|     BOOST_VERIFY( !++x ); | ||||
|     BOOST_VERIFY( !f(x) ); | ||||
|  | ||||
|     BOOST_TEST( x == 5 ); | ||||
|  | ||||
|     void * p = 0; | ||||
|     BOOST_VERIFY( p ); | ||||
|  | ||||
|     BOOST_VERIFY( X::f() ); | ||||
|  | ||||
|     BOOST_TEST( handler_invoked == 8 ); | ||||
| } | ||||
|  | ||||
| #undef BOOST_ENABLE_ASSERT_HANDLER | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     test_default(); | ||||
|     test_disabled(); | ||||
|     test_handler(); | ||||
|  | ||||
|     return boost::report_errors(); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user