mirror of
				https://github.com/boostorg/utility.git
				synced 2025-10-24 22:11:46 +02:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
			svn-branch
			...
			boost-1.33
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 66c9386b20 | ||
|  | 1770e47f97 | ||
|  | d4f4893ee1 | ||
|  | 23ec8fc788 | ||
|  | 3ab8d14a59 | 
							
								
								
									
										199
									
								
								Assignable.html
									
									
									
									
									
								
							
							
						
						
									
										199
									
								
								Assignable.html
									
									
									
									
									
								
							| @@ -1,109 +1,116 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | ||||
| <HTML> | ||||
| <!-- | ||||
|   -- Copyright (c) Jeremy Siek 2000 | ||||
|   -- | ||||
|   -- Permission to use, copy, modify, distribute and sell this software | ||||
|   -- and its documentation for any purpose is hereby granted without fee, | ||||
|   -- provided that the above copyright notice appears in all copies and | ||||
|   -- that both that copyright notice and this permission notice appear | ||||
|   -- in supporting documentation.  Silicon Graphics makes no | ||||
|   -- representations about the suitability of this software for any | ||||
|   -- purpose.  It is provided "as is" without express or implied warranty. | ||||
|   --> | ||||
| <Head> | ||||
| <Title>Assignable</Title> | ||||
| </HEAD> | ||||
| <BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"  | ||||
|         ALINK="#ff0000">  | ||||
| <IMG SRC="../../boost.png"  | ||||
|      ALT="C++ Boost" width="277" height="86">  | ||||
| <!--end header--> | ||||
| <BR Clear> | ||||
| <H1>Assignable</H1> | ||||
|  | ||||
| <html> | ||||
| <head> | ||||
|   <meta http-equiv="Content-Language" content="en-us"> | ||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> | ||||
| <h3>Description</h3> | ||||
| A type is Assignable if it is possible to assign one object of the type | ||||
| to another object of that type. | ||||
|  | ||||
|   <title>Assignable</title> | ||||
| </head> | ||||
|  | ||||
| <body bgcolor="#FFFFFF" link="#0000EE" text="#000000" vlink="#551A8B" alink= | ||||
| "#FF0000"> | ||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | ||||
|   "86"><br clear="none"> | ||||
| <h3>Notation</h3> | ||||
| <Table> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>T</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| is type that is a model of Assignable | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
|   <h1>Assignable</h1> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>t</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| is an object of type <tt>T</tt> | ||||
| </TD> | ||||
| </tr> | ||||
|  | ||||
|   <h3>Description</h3> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>u</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| is an object of type <tt>T</tt> or possibly <tt>const T</tt> | ||||
| </TD> | ||||
| </tr> | ||||
|  | ||||
|   <p>A type is Assignable if it is possible to assign one object of the type | ||||
|   to another object of that type.</p> | ||||
| </table> | ||||
| <h3>Definitions</h3> | ||||
| <h3>Valid expressions</h3> | ||||
| <Table border> | ||||
| <TR> | ||||
| <TH> | ||||
| Name | ||||
| </TH> | ||||
| <TH> | ||||
| Expression | ||||
| </TH> | ||||
| <TH> | ||||
| Return type | ||||
| </TH> | ||||
| <TH> | ||||
| Semantics | ||||
| </TH> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Assignment | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>t = u</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>T&</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>t</tt> is equivalent to <tt>u</tt> | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
|   <h3>Notation</h3> | ||||
| </table> | ||||
|  | ||||
|   <table summary=""> | ||||
|     <tr> | ||||
|       <td valign="top"><tt>T</tt></td> | ||||
|  | ||||
|       <td valign="top">is type that is a model of Assignable</td> | ||||
|     </tr> | ||||
| </table> | ||||
| <h3>Models</h3> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top"><tt>t</tt></td> | ||||
| <UL> | ||||
| <LI><tt>int</tt> | ||||
| <LI><tt>std::pair</tt> | ||||
| </UL> | ||||
|  | ||||
|       <td valign="top">is an object of type <tt>T</tt></td> | ||||
|     </tr> | ||||
| <h3>See also</h3> | ||||
| <a href="http://www.sgi.com/tech/stl/DefaultConstructible.html">DefaultConstructible</A> | ||||
| and  | ||||
| <A href="./CopyConstructible.html">CopyConstructible</A> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top"><tt>u</tt></td> | ||||
| <br> | ||||
| <HR> | ||||
| <TABLE> | ||||
| <TR valign=top> | ||||
| <TD nowrap>Copyright © 2000</TD><TD> | ||||
| <A HREF=http://www.lsc.nd.edu/~jsiek>Jeremy Siek</A>, Univ.of Notre Dame (<A HREF="mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</A>) | ||||
| </TD></TR></TABLE> | ||||
|  | ||||
|       <td valign="top">is an object of type <tt>T</tt> or possibly <tt>const | ||||
|       T</tt></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Definitions</h3> | ||||
|  | ||||
|   <h3>Valid expressions</h3> | ||||
|  | ||||
|   <table border summary=""> | ||||
|     <tr> | ||||
|       <th>Name</th> | ||||
|  | ||||
|       <th>Expression</th> | ||||
|  | ||||
|       <th>Return type</th> | ||||
|  | ||||
|       <th>Semantics</th> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Assignment</td> | ||||
|  | ||||
|       <td valign="top"><tt>t = u</tt></td> | ||||
|  | ||||
|       <td valign="top"><tt>T&</tt></td> | ||||
|  | ||||
|       <td valign="top"><tt>t</tt> is equivalent to <tt>u</tt></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Models</h3> | ||||
|  | ||||
|   <ul> | ||||
|     <li><tt>int</tt></li> | ||||
|  | ||||
|     <li><tt>std::pair</tt></li> | ||||
|   </ul> | ||||
|  | ||||
|   <h3>See also</h3> | ||||
|  | ||||
|   <p><a href= | ||||
|   "http://www.sgi.com/tech/stl/DefaultConstructible.html">DefaultConstructible</a> | ||||
|   and <a href="./CopyConstructible.html">CopyConstructible</a><br></p> | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "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> | ||||
|  | ||||
|   <table summary=""> | ||||
|     <tr valign="top"> | ||||
|       <td nowrap><i>Copyright © 2000</i></td> | ||||
|  | ||||
|       <td><i><a href="http://www.lsc.nd.edu/~jsiek">Jeremy Siek</a>, Univ.of | ||||
|       Notre Dame (<a href= | ||||
|       "mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</a>)</i></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <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 | ||||
|   copy at <a href= | ||||
|   "http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>)</i></p> | ||||
| </body> | ||||
| </html> | ||||
| </BODY> | ||||
| </HTML>  | ||||
|   | ||||
| @@ -1,31 +0,0 @@ | ||||
| #---------------------------------------------------------------------------- | ||||
| # 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 | ||||
|   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  | ||||
| ) | ||||
|  | ||||
|  | ||||
							
								
								
									
										1096
									
								
								Collection.html
									
									
									
									
									
								
							
							
						
						
									
										1096
									
								
								Collection.html
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,139 +1,178 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | ||||
| <HTML> | ||||
| <!-- | ||||
|   -- Copyright (c) Jeremy Siek 2000 | ||||
|   -- | ||||
|   -- Permission to use, copy, modify, distribute and sell this software | ||||
|   -- and its documentation for any purpose is hereby granted without fee, | ||||
|   -- provided that the above copyright notice appears in all copies and | ||||
|   -- that both that copyright notice and this permission notice appear | ||||
|   -- in supporting documentation.  Silicon Graphics makes no | ||||
|   -- representations about the suitability of this software for any | ||||
|   -- purpose.  It is provided "as is" without express or implied warranty. | ||||
|   --> | ||||
| <Head> | ||||
| <Title>Copy Constructible</Title> | ||||
| </HEAD> | ||||
| <BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"  | ||||
|         ALINK="#ff0000">  | ||||
| <IMG SRC="../../boost.png"  | ||||
|      ALT="C++ Boost" width="277" height="86">  | ||||
| <!--end header--> | ||||
| <BR Clear> | ||||
| <H1>Copy Constructible</H1> | ||||
|  | ||||
| <html> | ||||
| <head> | ||||
|   <meta http-equiv="Content-Language" content="en-us"> | ||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> | ||||
| <h3>Description</h3> | ||||
| A type is Copy Constructible if it is possible to copy objects of that | ||||
| type. | ||||
|  | ||||
|   <title>Copy Constructible</title> | ||||
| </head> | ||||
| <h3>Notation</h3> | ||||
| <Table> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>T</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| is type that is a model of Copy Constructible | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
| <body bgcolor="#FFFFFF" link="#0000EE" text="#000000" vlink="#551A8B" alink= | ||||
| "#FF0000"> | ||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | ||||
|   "86"><br clear="none"> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>t</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| is an object of type <tt>T</tt> | ||||
| </TD> | ||||
| </tr> | ||||
|  | ||||
|   <h1>Copy Constructible</h1> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>u</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| is an object of type <tt>const T</tt> | ||||
| </TD> | ||||
| </tr> | ||||
|  | ||||
|   <h3>Description</h3> | ||||
| </table> | ||||
| <h3>Definitions</h3> | ||||
| <h3>Valid expressions</h3> | ||||
| <Table border> | ||||
| <TR> | ||||
| <TH> | ||||
| Name | ||||
| </TH> | ||||
| <TH> | ||||
| Expression | ||||
| </TH> | ||||
| <TH> | ||||
| Return type | ||||
| </TH> | ||||
| <TH> | ||||
| Semantics | ||||
| </TH> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Copy constructor | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>T(t)</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>T</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>t</tt> is equivalent to <tt>T(t)</tt> | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
|   <p>A type is Copy Constructible if it is possible to copy objects of that | ||||
|   type.</p> | ||||
|  | ||||
|   <h3>Notation</h3> | ||||
|  | ||||
|   <table summary=""> | ||||
|     <tr> | ||||
|       <td valign="top"><tt>T</tt></td> | ||||
|  | ||||
|       <td valign="top">is type that is a model of Copy Constructible</td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top"><tt>t</tt></td> | ||||
|  | ||||
|       <td valign="top">is an object of type <tt>T</tt></td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top"><tt>u</tt></td> | ||||
|  | ||||
|       <td valign="top">is an object of type <tt>const T</tt></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Definitions</h3> | ||||
|  | ||||
|   <h3>Valid expressions</h3> | ||||
|  | ||||
|   <table border summary=""> | ||||
|     <tr> | ||||
|       <th>Name</th> | ||||
|  | ||||
|       <th>Expression</th> | ||||
|  | ||||
|       <th>Return type</th> | ||||
|  | ||||
|       <th>Semantics</th> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Copy constructor</td> | ||||
|  | ||||
|       <td valign="top"><tt>T(t)</tt></td> | ||||
|  | ||||
|       <td valign="top"><tt>T</tt></td> | ||||
|  | ||||
|       <td valign="top"><tt>t</tt> is equivalent to <tt>T(t)</tt></td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Copy constructor</td> | ||||
|  | ||||
|       <td valign="top"> | ||||
|         <pre> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Copy constructor | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <pre> | ||||
| T(u) | ||||
| </pre> | ||||
|       </td> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>T</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>u</tt> is equivalent to <tt>T(u)</tt> | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
|       <td valign="top"><tt>T</tt></td> | ||||
|  | ||||
|       <td valign="top"><tt>u</tt> is equivalent to <tt>T(u)</tt></td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Destructor</td> | ||||
|  | ||||
|       <td valign="top"> | ||||
|         <pre> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Destructor | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <pre> | ||||
| t.~T() | ||||
| </pre> | ||||
|       </td> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>T</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
|   | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
|       <td valign="top"><tt>T</tt></td> | ||||
|  | ||||
|       <td valign="top"> </td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Address Operator</td> | ||||
|  | ||||
|       <td valign="top"> | ||||
|         <pre> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Address Operator | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <pre> | ||||
| &t | ||||
| </pre> | ||||
|       </td> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>T*</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| denotes the address of <tt>t</tt> | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
|       <td valign="top"><tt>T*</tt></td> | ||||
|  | ||||
|       <td valign="top">denotes the address of <tt>t</tt></td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Address Operator</td> | ||||
|  | ||||
|       <td valign="top"> | ||||
|         <pre> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Address Operator | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <pre> | ||||
| &u | ||||
| </pre> | ||||
|       </td> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>T*</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| denotes the address of <tt>u</tt> | ||||
| </TD> | ||||
| </TR> | ||||
|  | ||||
|       <td valign="top"><tt>T*</tt></td> | ||||
|  | ||||
|       <td valign="top">denotes the address of <tt>u</tt></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Models</h3> | ||||
| </table> | ||||
|  | ||||
|   <ul> | ||||
|     <li><tt>int</tt></li> | ||||
|  | ||||
|     <li><tt>std::pair</tt></li> | ||||
|   </ul> | ||||
| </table> | ||||
| <h3>Models</h3> | ||||
|  | ||||
|   <h3>Concept Checking Class</h3> | ||||
|   <pre> | ||||
| <UL> | ||||
| <LI><tt>int</tt> | ||||
| <LI><tt>std::pair</tt> | ||||
| </UL> | ||||
|  | ||||
| <h3>Concept Checking Class</h3> | ||||
|  | ||||
| <pre> | ||||
|   template <class T> | ||||
|   struct CopyConstructibleConcept | ||||
|   { | ||||
| @@ -153,33 +192,19 @@ t.~T() | ||||
|   }; | ||||
| </pre> | ||||
|  | ||||
|   <h3>See also</h3> | ||||
| <h3>See also</h3> | ||||
| <A | ||||
| href="http://www.sgi.com/tech/stl/DefaultConstructible.html">Default Constructible</A> | ||||
| and  | ||||
| <A hrefa="./Assignable.html">Assignable</A> | ||||
|  | ||||
|   <p><a href="http://www.sgi.com/tech/stl/DefaultConstructible.html">Default | ||||
|   Constructible</a> and <a href="./Assignable.html">Assignable</a><br></p> | ||||
|   <hr> | ||||
| <br> | ||||
| <HR> | ||||
| <TABLE> | ||||
| <TR valign=top> | ||||
| <TD nowrap>Copyright © 2000</TD><TD> | ||||
| <A HREF=http://www.lsc.nd.edu/~jsiek>Jeremy Siek</A>, Univ.of Notre Dame (<A HREF="mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</A>) | ||||
| </TD></TR></TABLE> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "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> | ||||
|  | ||||
|   <table summary=""> | ||||
|     <tr valign="top"> | ||||
|       <td nowrap><i>Copyright © 2000</i></td> | ||||
|  | ||||
|       <td><i><a href="http://www.lsc.nd.edu/~jsiek">Jeremy Siek</a>, Univ.of | ||||
|       Notre Dame (<a href= | ||||
|       "mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</a>)</i></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <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 | ||||
|   copy at <a href= | ||||
|   "http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>)</i></p> | ||||
| </body> | ||||
| </html> | ||||
| </BODY> | ||||
| </HTML>  | ||||
|   | ||||
| @@ -1,210 +1,212 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | ||||
|  | ||||
| <html> | ||||
| <HTML> | ||||
| <!-- | ||||
|   == Copyright (c) 1996-1999 | ||||
|   == Silicon Graphics Computer Systems, Inc. | ||||
|   == | ||||
|   == Permission to use, copy, modify, distribute and sell this software | ||||
|   == and its documentation for any purpose is hereby granted without fee, | ||||
|   == provided that the above copyright notice appears in all copies and | ||||
|   == that both that copyright notice and this permission notice appear | ||||
|   == in supporting documentation.  Silicon Graphics makes no | ||||
|   == representations about the suitability of this software for any | ||||
|   == purpose.  It is provided "as is" without express or implied warranty. | ||||
|   == | ||||
|   == Copyright (c) 1994 | ||||
|   == Hewlett-Packard Company | ||||
|   == | ||||
|   == Permission to use, copy, modify, distribute and sell this software | ||||
|   == and its documentation for any purpose is hereby granted without fee, | ||||
|   == provided that the above copyright notice appears in all copies and | ||||
|   == that both that copyright notice and this permission notice appear | ||||
|   == in supporting documentation.  Hewlett-Packard Company makes no | ||||
|   == representations about the suitability of this software for any | ||||
|   == purpose.  It is provided "as is" without express or implied warranty. | ||||
|   == | ||||
|   -- Copyright (c) Jeremy Siek 2000 | ||||
|   -- | ||||
|   -- Permission to use, copy, modify, distribute and sell this software | ||||
|   -- and its documentation for any purpose is hereby granted without fee, | ||||
|   -- provided that the above copyright notice appears in all copies and | ||||
|   -- that both that copyright notice and this permission notice appear | ||||
|   -- in supporting documentation.  Silicon Graphics makes no | ||||
|   -- representations about the suitability of this software for any | ||||
|   -- purpose.  It is provided "as is" without express or implied warranty. | ||||
|   --> | ||||
| <!-- | ||||
|   -- Copyright (c) 1996-1999 | ||||
|   -- Silicon Graphics Computer Systems, Inc. | ||||
|   -- | ||||
|   -- Permission to use, copy, modify, distribute and sell this software | ||||
|   -- and its documentation for any purpose is hereby granted without fee, | ||||
|   -- provided that the above copyright notice appears in all copies and | ||||
|   -- that both that copyright notice and this permission notice appear | ||||
|   -- in supporting documentation.  Silicon Graphics makes no | ||||
|   -- representations about the suitability of this software for any | ||||
|   -- purpose.  It is provided "as is" without express or implied warranty. | ||||
|   -- | ||||
|   -- Copyright (c) 1994 | ||||
|   -- Hewlett-Packard Company | ||||
|   -- | ||||
|   -- Permission to use, copy, modify, distribute and sell this software | ||||
|   -- and its documentation for any purpose is hereby granted without fee, | ||||
|   -- provided that the above copyright notice appears in all copies and | ||||
|   -- that both that copyright notice and this permission notice appear | ||||
|   -- in supporting documentation.  Hewlett-Packard Company makes no | ||||
|   -- representations about the suitability of this software for any | ||||
|   -- purpose.  It is provided "as is" without express or implied warranty. | ||||
|   -- | ||||
|   --> | ||||
| <Head> | ||||
| <Title>LessThanComparable</Title> | ||||
| </Head> | ||||
| <BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"  | ||||
|         ALINK="#ff0000">  | ||||
| <IMG SRC="../../boost.png"  | ||||
|      ALT="C++ Boost" width="277" height="86">  | ||||
| <!--end header--> | ||||
| <BR Clear> | ||||
| <H1>LessThanComparable</H1> | ||||
|  | ||||
| <head> | ||||
|   <meta http-equiv="Content-Language" content="en-us"> | ||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> | ||||
| <h3>Description</h3> | ||||
| A type is LessThanComparable if it is ordered: it must | ||||
| be possible to compare two objects of that type using <tt>operator<</tt>, and | ||||
| <tt>operator<</tt> must be a strict weak ordering relation. | ||||
|  | ||||
|   <title>LessThanComparable</title> | ||||
| </head> | ||||
|  | ||||
| <body bgcolor="#FFFFFF" link="#0000EE" text="#000000" vlink="#551A8B" alink= | ||||
| "#FF0000"> | ||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | ||||
|   "86"><br clear="none"> | ||||
| <h3>Refinement of</h3> | ||||
| <h3>Associated types</h3> | ||||
| <h3>Notation</h3> | ||||
| <Table> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>X</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| A type that is a model of LessThanComparable | ||||
| </TD> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| <tt>x</tt>, <tt>y</tt>, <tt>z</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| Object of type <tt>X</tt> | ||||
| </TD> | ||||
| </tr> | ||||
| </table> | ||||
| <h3>Definitions</h3> | ||||
| Consider the relation <tt>!(x < y) && !(y < x)</tt>.  If this relation is | ||||
| transitive (that is, if <tt>!(x < y) && !(y < x) && !(y < z) && !(z < y)</tt> | ||||
| implies <tt>!(x < z) && !(z < x)</tt>), then it satisfies the mathematical | ||||
| definition of an equivalence relation.  In this case, <tt>operator<</tt> | ||||
| is a <i>strict weak ordering</i>. | ||||
| <P> | ||||
| If <tt>operator<</tt> is a strict weak ordering, and if each equivalence class | ||||
| has only a single element, then <tt>operator<</tt> is a <i>total ordering</i>. | ||||
| <h3>Valid expressions</h3> | ||||
| <Table border> | ||||
| <TR> | ||||
| <TH> | ||||
| Name | ||||
| </TH> | ||||
| <TH> | ||||
| Expression | ||||
| </TH> | ||||
| <TH> | ||||
| Type requirements | ||||
| </TH> | ||||
| <TH> | ||||
| Return type | ||||
| </TH> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Less | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>x < y</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
|   | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| Convertible to <tt>bool</tt> | ||||
| </TD> | ||||
| </TR> | ||||
| </table> | ||||
|  | ||||
|   <h1>LessThanComparable</h1> | ||||
|  | ||||
|   <h3>Description</h3> | ||||
|  | ||||
|   <p>A type is LessThanComparable if it is ordered: it must be possible to | ||||
|   compare two objects of that type using <tt>operator<</tt>, and | ||||
|   <tt>operator<</tt> must be a strict weak ordering relation.</p> | ||||
| <h3>Expression semantics</h3> | ||||
| <Table border> | ||||
| <TR> | ||||
| <TH> | ||||
| Name | ||||
| </TH> | ||||
| <TH> | ||||
| Expression | ||||
| </TH> | ||||
| <TH> | ||||
| Precondition | ||||
| </TH> | ||||
| <TH> | ||||
| Semantics | ||||
| </TH> | ||||
| <TH> | ||||
| Postcondition | ||||
| </TH> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Less | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>x < y</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>x</tt> and <tt>y</tt> are in the domain of <tt><</tt> | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
|   | ||||
| </TD> | ||||
| </table> | ||||
|  | ||||
|   <h3>Refinement of</h3> | ||||
|  | ||||
|   <h3>Associated types</h3> | ||||
| <h3>Complexity guarantees</h3> | ||||
| <h3>Invariants</h3> | ||||
| <Table border> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Irreflexivity | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>x < x</tt> must be false. | ||||
| </TD> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Antisymmetry | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>x < y</tt> implies !(y < x) <A href="#2">[2]</A> | ||||
| </TD> | ||||
| </TR> | ||||
| <TR> | ||||
| <TD VAlign=top> | ||||
| Transitivity | ||||
| </TD> | ||||
| <TD VAlign=top> | ||||
| <tt>x < y</tt> and <tt>y < z</tt> implies <tt>x < z</tt> <A href="#3">[3]</A> | ||||
| </TD> | ||||
| </tr> | ||||
| </table> | ||||
| <h3>Models</h3> | ||||
| <UL> | ||||
| <LI> | ||||
| int | ||||
| </UL> | ||||
| <h3>Notes</h3> | ||||
| <P><A name="1">[1]</A> | ||||
| Only <tt>operator<</tt> is fundamental; the other inequality operators | ||||
| are essentially syntactic sugar. | ||||
| <P><A name="2">[2]</A> | ||||
| Antisymmetry is a theorem, not an axiom: it follows from | ||||
| irreflexivity and transitivity. | ||||
| <P><A name="3">[3]</A> | ||||
| Because of irreflexivity and transitivity, <tt>operator<</tt> always | ||||
| satisfies the definition of a <i>partial ordering</i>.  The definition of | ||||
| a <i>strict weak ordering</i> is stricter, and the definition of a | ||||
| <i>total ordering</i> is stricter still. | ||||
| <h3>See also</h3> | ||||
| <A href="http://www.sgi.com/tech/stl/EqualityComparable.html">EqualityComparable</A>, <A href="http://www.sgi.com/tech/stl/StrictWeakOrdering.html">StrictWeakOrdering</A> | ||||
|  | ||||
|   <h3>Notation</h3> | ||||
|  | ||||
|   <table summary=""> | ||||
|     <tr> | ||||
|       <td valign="top"><tt>X</tt></td> | ||||
|  | ||||
|       <td valign="top">A type that is a model of LessThanComparable</td> | ||||
|     </tr> | ||||
| <br> | ||||
| <HR> | ||||
| <TABLE> | ||||
| <TR valign=top> | ||||
| <TD nowrap>Copyright © 2000</TD><TD> | ||||
| <A HREF=http://www.lsc.nd.edu/~jsiek>Jeremy Siek</A>, Univ.of Notre Dame (<A HREF="mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</A>) | ||||
| </TD></TR></TABLE> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top"><tt>x</tt>, <tt>y</tt>, <tt>z</tt></td> | ||||
|  | ||||
|       <td valign="top">Object of type <tt>X</tt></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Definitions</h3> | ||||
|  | ||||
|   <p>Consider the relation <tt>!(x < y) && !(y < x)</tt>. If | ||||
|   this relation is transitive (that is, if <tt>!(x < y) && !(y | ||||
|   < x) && !(y < z) && !(z < y)</tt> implies <tt>!(x | ||||
|   < z) && !(z < x)</tt>), then it satisfies the mathematical | ||||
|   definition of an equivalence relation. In this case, <tt>operator<</tt> | ||||
|   is a <i>strict weak ordering</i>.</p> | ||||
|  | ||||
|   <p>If <tt>operator<</tt> is a strict weak ordering, and if each | ||||
|   equivalence class has only a single element, then <tt>operator<</tt> is | ||||
|   a <i>total ordering</i>.</p> | ||||
|  | ||||
|   <h3>Valid expressions</h3> | ||||
|  | ||||
|   <table border summary=""> | ||||
|     <tr> | ||||
|       <th>Name</th> | ||||
|  | ||||
|       <th>Expression</th> | ||||
|  | ||||
|       <th>Type requirements</th> | ||||
|  | ||||
|       <th>Return type</th> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Less</td> | ||||
|  | ||||
|       <td valign="top"><tt>x < y</tt></td> | ||||
|  | ||||
|       <td valign="top"> </td> | ||||
|  | ||||
|       <td valign="top">Convertible to <tt>bool</tt></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Expression semantics</h3> | ||||
|  | ||||
|   <table border summary=""> | ||||
|     <tr> | ||||
|       <th>Name</th> | ||||
|  | ||||
|       <th>Expression</th> | ||||
|  | ||||
|       <th>Precondition</th> | ||||
|  | ||||
|       <th>Semantics</th> | ||||
|  | ||||
|       <th>Postcondition</th> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Less</td> | ||||
|  | ||||
|       <td valign="top"><tt>x < y</tt></td> | ||||
|  | ||||
|       <td valign="top"><tt>x</tt> and <tt>y</tt> are in the domain of | ||||
|       <tt><</tt></td> | ||||
|  | ||||
|       <td valign="top"> </td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Complexity guarantees</h3> | ||||
|  | ||||
|   <h3>Invariants</h3> | ||||
|  | ||||
|   <table border summary=""> | ||||
|     <tr> | ||||
|       <td valign="top">Irreflexivity</td> | ||||
|  | ||||
|       <td valign="top"><tt>x < x</tt> must be false.</td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Antisymmetry</td> | ||||
|  | ||||
|       <td valign="top"><tt>x < y</tt> implies !(y < x) <a href= | ||||
|       "#n2">[2]</a></td> | ||||
|     </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td valign="top">Transitivity</td> | ||||
|  | ||||
|       <td valign="top"><tt>x < y</tt> and <tt>y < z</tt> implies <tt>x | ||||
|       < z</tt> <a href="#n3">[3]</a></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <h3>Models</h3> | ||||
|  | ||||
|   <ul> | ||||
|     <li>int</li> | ||||
|   </ul> | ||||
|  | ||||
|   <h3>Notes</h3> | ||||
|  | ||||
|   <p><a name="n1" id="n1">[1]</a> Only <tt>operator<</tt> is fundamental; | ||||
|   the other inequality operators are essentially syntactic sugar.</p> | ||||
|  | ||||
|   <p><a name="n2" id="n2">[2]</a> Antisymmetry is a theorem, not an axiom: it | ||||
|   follows from irreflexivity and transitivity.</p> | ||||
|  | ||||
|   <p><a name="n3" id="n3">[3]</a> Because of irreflexivity and transitivity, | ||||
|   <tt>operator<</tt> always satisfies the definition of a <i>partial | ||||
|   ordering</i>. The definition of a <i>strict weak ordering</i> is stricter, | ||||
|   and the definition of a <i>total ordering</i> is stricter still.</p> | ||||
|  | ||||
|   <h3>See also</h3> | ||||
|  | ||||
|   <p><a href= | ||||
|   "http://www.sgi.com/tech/stl/EqualityComparable.html">EqualityComparable</a>, | ||||
|   <a href= | ||||
|   "http://www.sgi.com/tech/stl/StrictWeakOrdering.html">StrictWeakOrdering</a><br> | ||||
|   </p> | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "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> | ||||
|  | ||||
|   <table summary=""> | ||||
|     <tr valign="top"> | ||||
|       <td nowrap><i>Copyright © 2000</i></td> | ||||
|  | ||||
|       <td><i><a href="http://www.lsc.nd.edu/~jsiek">Jeremy Siek</a>, Univ.of | ||||
|       Notre Dame (<a href= | ||||
|       "mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</a>)</i></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <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 | ||||
|   copy at <a href= | ||||
|   "http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>)</i></p> | ||||
| </body> | ||||
| </html> | ||||
| </BODY> | ||||
| </HTML>  | ||||
|   | ||||
| @@ -1,95 +1,92 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | ||||
| <HTML> | ||||
| <!-- | ||||
|   -- Copyright (c) Jeremy Siek 2000 | ||||
|   -- | ||||
|   -- Permission to use, copy, modify, distribute and sell this software | ||||
|   -- and its documentation for any purpose is hereby granted without fee, | ||||
|   -- provided that the above copyright notice appears in all copies and | ||||
|   -- that both that copyright notice and this permission notice appear | ||||
|   -- in supporting documentation.  Silicon Graphics makes no | ||||
|   -- representations about the suitability of this software for any | ||||
|   -- purpose.  It is provided "as is" without express or implied warranty. | ||||
|   --> | ||||
| <Head> | ||||
| <Title>MultiPassInputIterator</Title> | ||||
| <BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"  | ||||
| 	ALINK="#ff0000">  | ||||
| <IMG SRC="../../boost.png"  | ||||
|      ALT="C++ Boost" width="277" height="86">  | ||||
|  | ||||
| <html> | ||||
| <head> | ||||
|   <meta http-equiv="Content-Language" content="en-us"> | ||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> | ||||
| <BR Clear> | ||||
|  | ||||
|   <title>MultiPassInputIterator</title> | ||||
| </head> | ||||
| <H2> | ||||
| <A NAME="concept:MultiPassInputIterator"></A> | ||||
| Multi-Pass Input Iterator | ||||
| </H2> | ||||
|  | ||||
| <body bgcolor="#FFFFFF" link="#0000EE" text="#000000" vlink="#551A8B" alink= | ||||
| "#FF0000"> | ||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | ||||
|   "86"><br clear="none"> | ||||
| This concept is a refinement of <a | ||||
| href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>, | ||||
| adding the requirements that the iterator can be used to make multiple | ||||
| passes through a range, and that if <TT>it1 == it2</TT> and | ||||
| <TT>it1</TT> is dereferenceable then <TT>++it1 == ++it2</TT>. The | ||||
| Multi-Pass Input Iterator is very similar to the <a | ||||
| href="http://www.sgi.com/tech/stl/ForwardIterator.html">Forward Iterator</a>. The | ||||
| only difference is that a <a | ||||
| href="http://www.sgi.com/tech/stl/ForwardIterator.html">Forward Iterator</a> | ||||
| requires the <TT>reference</TT> type to be <TT>value_type&</TT>, whereas | ||||
| MultiPassInputIterator is like <a | ||||
| href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a> | ||||
| in that the <TT>reference</TT> type merely has to be convertible to | ||||
| <TT>value_type</TT>. | ||||
|  | ||||
|   <h2><a name="concept:MultiPassInputIterator" id= | ||||
|   "concept:MultiPassInputIterator"></a> Multi-Pass Input Iterator</h2> | ||||
|  | ||||
|   <p>This concept is a refinement of <a href= | ||||
|   "http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>, adding | ||||
|   the requirements that the iterator can be used to make multiple passes | ||||
|   through a range, and that if <tt>it1 == it2</tt> and <tt>it1</tt> is | ||||
|   dereferenceable then <tt>++it1 == ++it2</tt>. The Multi-Pass Input Iterator | ||||
|   is very similar to the <a href= | ||||
|   "http://www.sgi.com/tech/stl/ForwardIterator.html">Forward Iterator</a>. | ||||
|   The only difference is that a <a href= | ||||
|   "http://www.sgi.com/tech/stl/ForwardIterator.html">Forward Iterator</a> | ||||
|   requires the <tt>reference</tt> type to be <tt>value_type&</tt>, | ||||
|   whereas MultiPassInputIterator is like <a href= | ||||
|   "http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a> in that | ||||
|   the <tt>reference</tt> type merely has to be convertible to | ||||
|   <tt>value_type</tt>.</p> | ||||
| <h3>Design Notes</h3> | ||||
|  | ||||
|   <h3>Design Notes</h3> | ||||
| comments by Valentin Bonnard: | ||||
|  | ||||
|   <p>comments by Valentin Bonnard:</p> | ||||
| <p> I think that introducing Multi-Pass Input Iterator isn't the right | ||||
| solution. Do you also want to define Multi-Pass Bidirectionnal Iterator | ||||
| and Multi-Pass Random Access Iterator ? I don't, definitly. It only | ||||
| confuses the issue. The problem lies into the existing hierarchy of | ||||
| iterators, which mixes movabillity, modifiabillity and lvalue-ness, | ||||
| and these are clearly independant. | ||||
|  | ||||
|   <p>I think that introducing Multi-Pass Input Iterator isn't the right | ||||
|   solution. Do you also want to define Multi-Pass Bidirectionnal Iterator and | ||||
|   Multi-Pass Random Access Iterator ? I don't, definitly. It only confuses | ||||
|   the issue. The problem lies into the existing hierarchy of iterators, which | ||||
|   mixes movabillity, modifiabillity and lvalue-ness, and these are clearly | ||||
|   independant.</p> | ||||
| <p> The terms Forward, Bidirectionnal and Random Access are about | ||||
| movabillity and shouldn't be used to mean anything else.  In a | ||||
| completly orthogonal way, iterators can be immutable, mutable, or | ||||
| neither.  Lvalueness of iterators is also orthogonal with | ||||
| immutabillity.  With these clean concepts, your Multi-Pass Input Iterator | ||||
| is just called a Forward Iterator. | ||||
|  | ||||
|   <p>The terms Forward, Bidirectionnal and Random Access are about | ||||
|   movabillity and shouldn't be used to mean anything else. In a completly | ||||
|   orthogonal way, iterators can be immutable, mutable, or neither. Lvalueness | ||||
|   of iterators is also orthogonal with immutabillity. With these clean | ||||
|   concepts, your Multi-Pass Input Iterator is just called a Forward | ||||
|   Iterator.</p> | ||||
| <p>                 | ||||
| Other translations are:<br> | ||||
| std::Forward Iterator -> ForwardIterator & Lvalue Iterator<br> | ||||
| std::Bidirectionnal Iterator -> Bidirectionnal Iterator & Lvalue Iterator<br> | ||||
| std::Random Access Iterator -> Random Access Iterator & Lvalue Iterator<br> | ||||
|  | ||||
|   <p>Other translations are:<br> | ||||
|   std::Forward Iterator -> ForwardIterator & Lvalue Iterator<br> | ||||
|   std::Bidirectionnal Iterator -> Bidirectionnal Iterator & Lvalue | ||||
|   Iterator<br> | ||||
|   std::Random Access Iterator -> Random Access Iterator & Lvalue | ||||
|   Iterator<br></p> | ||||
| <p> | ||||
| Note that in practice the only operation not allowed on my  | ||||
| Forward Iterator which is allowed on std::Forward Iterator is  | ||||
| <tt>&*it</tt>. I think that <tt>&*</tt> is rarely needed in generic code. | ||||
|  | ||||
|   <p>Note that in practice the only operation not allowed on my Forward | ||||
|   Iterator which is allowed on std::Forward Iterator is <tt>&*it</tt>. I | ||||
|   think that <tt>&*</tt> is rarely needed in generic code.</p> | ||||
| <p> | ||||
| reply by Jeremy Siek: | ||||
|  | ||||
|   <p>reply by Jeremy Siek:</p> | ||||
| <p> | ||||
| The above analysis by Valentin is right on. Of course, there is | ||||
| the problem with backward compatibility. The current STL implementations | ||||
| are based on the old definition of Forward Iterator. The right course | ||||
| of action is to get Forward Iterator, etc. changed in the C++ standard. | ||||
| Once that is done we can drop Multi-Pass Input Iterator. | ||||
|  | ||||
|   <p>The above analysis by Valentin is right on. Of course, there is the | ||||
|   problem with backward compatibility. The current STL implementations are | ||||
|   based on the old definition of Forward Iterator. The right course of action | ||||
|   is to get Forward Iterator, etc. changed in the C++ standard. Once that is | ||||
|   done we can drop Multi-Pass Input Iterator.<br></p> | ||||
|   <hr> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
| <br> | ||||
| <HR> | ||||
| <TABLE> | ||||
| <TR valign=top> | ||||
| <TD nowrap>Copyright © 2000</TD><TD> | ||||
| <a HREF="../../people/jeremy_siek.htm">Jeremy Siek</a>, Univ.of Notre Dame (<A HREF="mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</A>) | ||||
| </TD></TR></TABLE> | ||||
|  | ||||
|   <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> | ||||
|  | ||||
|   <table summary=""> | ||||
|     <tr valign="top"> | ||||
|       <td nowrap><i>Copyright © 2000</i></td> | ||||
|  | ||||
|       <td><i><a href="http://www.lsc.nd.edu/~jsiek">Jeremy Siek</a>, Univ.of | ||||
|       Notre Dame (<a href= | ||||
|       "mailto:jsiek@lsc.nd.edu">jsiek@lsc.nd.edu</a>)</i></td> | ||||
|     </tr> | ||||
|   </table> | ||||
|  | ||||
|   <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 | ||||
|   copy at <a href= | ||||
|   "http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>)</i></p> | ||||
| </body> | ||||
| </html> | ||||
| </BODY> | ||||
| </HTML>  | ||||
|   | ||||
| @@ -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> | ||||
							
								
								
									
										18
									
								
								assert.html
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								assert.html
									
									
									
									
									
								
							| @@ -7,9 +7,10 @@ | ||||
| 	<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 width="277"> | ||||
| 					<img src="../../boost.png" alt="boost.png (6897 bytes)" width="277" height="86"> | ||||
| 				</td> | ||||
| 				<td align="center"> | ||||
| 				<td align="middle"> | ||||
| 					<h1>assert.hpp</h1> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| @@ -47,15 +48,10 @@ 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. 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.</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>. | ||||
| @@ -351,9 +351,9 @@ with the exact pointer type used in <code>switcher</code>'s constructor.</p> | ||||
| 	<dt>Jonathan Turkanis | ||||
| 	<dd>Supplied an implementation of generating the constructor templates that | ||||
| 		can be controlled and automated with macros.  The implementation uses | ||||
| 		the <a href="../preprocessor/index.html">Preprocessor library</a>. | ||||
| 		the <a href="../preprocessor/">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; | ||||
| } | ||||
| @@ -606,7 +606,7 @@ template <bool opt> | ||||
| struct filler | ||||
| { | ||||
|    template <typename I, typename T> | ||||
|    static void do_fill(I first, I last, typename boost::call_traits<T>::param_type val) | ||||
|    static void do_fill(I first, I last, typename boost::call_traits<T>::param_type val); | ||||
|    { | ||||
|       while(first != last) | ||||
|       { | ||||
| @@ -740,16 +740,25 @@ 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> | ||||
|  | ||||
|   | ||||
| @@ -12,6 +12,7 @@ | ||||
| // 03 Oct 2000: | ||||
| //    Enabled extra tests for VC6. | ||||
|  | ||||
| #include <cassert> | ||||
| #include <iostream> | ||||
| #include <iomanip> | ||||
| #include <algorithm> | ||||
| @@ -21,6 +22,40 @@ | ||||
| #include <libs/type_traits/test/test.hpp> | ||||
| #include <libs/type_traits/test/check_type.hpp> | ||||
|  | ||||
| // | ||||
| // define tests here | ||||
| unsigned failures = 0; | ||||
| unsigned test_count = 0; | ||||
| // | ||||
| // This must get defined within the test file. | ||||
| // All compilers have bugs, set this to the number of | ||||
| // regressions *expected* from a given compiler, | ||||
| // if there are no workarounds for the bugs, *and* | ||||
| // the regressions have been investigated. | ||||
| // | ||||
| extern unsigned int expected_failures; | ||||
| // | ||||
| // proc check_result() | ||||
| // Checks that there were no regressions: | ||||
| // | ||||
| int check_result(int argc, char** argv) | ||||
| { | ||||
|    std::cout << test_count << " tests completed, " | ||||
|       << failures << " failures found, " | ||||
|       << expected_failures << " failures expected from this compiler." << std::endl; | ||||
|    if((argc == 2)  | ||||
|       && (argv[1][0] == '-') | ||||
|       && (argv[1][1] == 'a') | ||||
|       && (argv[1][2] == 0)) | ||||
|    { | ||||
|       std::cout << "Press any key to continue..."; | ||||
|       std::cin.get(); | ||||
|    } | ||||
|    return (failures == expected_failures) | ||||
|        ? 0 | ||||
|        : (failures != 0) ? static_cast<int>(failures) : -1; | ||||
| } | ||||
|  | ||||
| // a way prevent warnings for unused variables | ||||
| template<class T> inline void unused_variable(const T&) {} | ||||
|  | ||||
| @@ -121,9 +156,9 @@ void call_traits_checker<T>::operator()(param_type p) | ||||
|    T t(p); | ||||
|    contained<T> c(t); | ||||
|    cout << "checking contained<" << typeid(T).name() << ">..." << endl; | ||||
|    BOOST_CHECK(t == c.value()); | ||||
|    BOOST_CHECK(t == c.get()); | ||||
|    BOOST_CHECK(t == c.const_get()); | ||||
|    assert(t == c.value()); | ||||
|    assert(t == c.get()); | ||||
|    assert(t == c.const_get()); | ||||
| #ifndef __ICL | ||||
|    //cout << "typeof contained<" << typeid(T).name() << ">::v_ is:           " << typeid(&contained<T>::v_).name() << endl; | ||||
|    cout << "typeof contained<" << typeid(T).name() << ">::value() is:      " << typeid(&contained<T>::value).name() << endl; | ||||
| @@ -145,11 +180,11 @@ struct call_traits_checker<T[N]> | ||||
|       cout << "checking contained<" << typeid(T[N]).name() << ">..." << endl; | ||||
|       unsigned int i = 0; | ||||
|       for(i = 0; i < N; ++i) | ||||
|          BOOST_CHECK(t[i] == c.value()[i]); | ||||
|          assert(t[i] == c.value()[i]); | ||||
|       for(i = 0; i < N; ++i) | ||||
|          BOOST_CHECK(t[i] == c.get()[i]); | ||||
|          assert(t[i] == c.get()[i]); | ||||
|       for(i = 0; i < N; ++i) | ||||
|          BOOST_CHECK(t[i] == c.const_get()[i]); | ||||
|          assert(t[i] == c.const_get()[i]); | ||||
|  | ||||
|       cout << "typeof contained<" << typeid(T[N]).name() << ">::v_ is:         " << typeid(&contained<T[N]>::v_).name() << endl; | ||||
|       cout << "typeof contained<" << typeid(T[N]).name() << ">::value is:      " << typeid(&contained<T[N]>::value).name() << endl; | ||||
| @@ -167,7 +202,7 @@ template <class W, class U> | ||||
| void check_wrap(const W& w, const U& u) | ||||
| { | ||||
|    cout << "checking " << typeid(W).name() << "..." << endl; | ||||
|    BOOST_CHECK(w.value() == u); | ||||
|    assert(w.value() == u); | ||||
| } | ||||
|  | ||||
| // | ||||
| @@ -178,8 +213,8 @@ template <class T, class U, class V> | ||||
| void check_make_pair(T c, U u, V v) | ||||
| { | ||||
|    cout << "checking std::pair<" << typeid(c.first).name() << ", " << typeid(c.second).name() << ">..." << endl; | ||||
|    BOOST_CHECK(c.first == u); | ||||
|    BOOST_CHECK(c.second == v); | ||||
|    assert(c.first == u); | ||||
|    assert(c.second == v); | ||||
|    cout << endl; | ||||
| } | ||||
|  | ||||
| @@ -255,6 +290,8 @@ int main(int argc, char *argv[ ]) | ||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<cr_type>::param_type); | ||||
| #else | ||||
|    std::cout << "Your compiler cannot instantiate call_traits<int&const>, skipping four tests (4 errors)" << std::endl; | ||||
|    failures += 4; | ||||
|    test_count += 4; | ||||
| #endif | ||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<const int&>::value_type); | ||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<const int&>::reference); | ||||
| @@ -276,9 +313,13 @@ int main(int argc, char *argv[ ]) | ||||
|    BOOST_CHECK_TYPE(const test_abc1&, boost::call_traits<test_abc1>::param_type); | ||||
| #else | ||||
|    std::cout << "You're compiler does not support partial template specialiation, skipping 8 tests (8 errors)" << std::endl; | ||||
|    failures += 12; | ||||
|    test_count += 12; | ||||
| #endif | ||||
| #else | ||||
|    std::cout << "You're compiler does not support partial template specialiation, skipping 20 tests (20 errors)" << std::endl; | ||||
|    failures += 24; | ||||
|    test_count += 24; | ||||
| #endif | ||||
|    // test with an incomplete type: | ||||
|    BOOST_CHECK_TYPE(incomplete_type, boost::call_traits<incomplete_type>::value_type); | ||||
| @@ -286,12 +327,12 @@ int main(int argc, char *argv[ ]) | ||||
|    BOOST_CHECK_TYPE(const incomplete_type&, boost::call_traits<incomplete_type>::const_reference); | ||||
|    BOOST_CHECK_TYPE(const incomplete_type&, boost::call_traits<incomplete_type>::param_type); | ||||
|  | ||||
|    return 0; | ||||
|    return check_result(argc, argv); | ||||
| } | ||||
|  | ||||
| // | ||||
| // define call_traits tests to check that the assertions in the docs do actually work | ||||
| // this is an compile-time only set of tests: | ||||
| // this is an instantiate only set of tests: | ||||
| // | ||||
| template <typename T, bool isarray = false> | ||||
| struct call_traits_test | ||||
| @@ -403,3 +444,23 @@ template struct call_traits_test<int[2], true>; | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #if defined(BOOST_MSVC) && _MSC_VER <= 1300 | ||||
| unsigned int expected_failures = 12; | ||||
| #elif defined(__SUNPRO_CC) | ||||
| #if(__SUNPRO_CC <= 0x520) | ||||
| unsigned int expected_failures = 18; | ||||
| #elif(__SUNPRO_CC < 0x530) | ||||
| unsigned int expected_failures = 17; | ||||
| #else | ||||
| unsigned int expected_failures = 6; | ||||
| #endif | ||||
| #elif defined(__BORLANDC__) | ||||
| unsigned int expected_failures = 2; | ||||
| #elif (defined(__GNUC__) && ((__GNUC__ < 3) || (__GNUC__ == 3) && (__GNUC_MINOR__ < 1))) | ||||
| unsigned int expected_failures = 4; | ||||
| #elif defined(__HP_aCC) | ||||
| unsigned int expected_failures = 24; | ||||
| #else | ||||
| unsigned int expected_failures = 0; | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -7,9 +7,10 @@ | ||||
| 	<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 width="277"> | ||||
| 					<img src="../../boost.png" alt="boost.png (6897 bytes)" width="277" height="86"> | ||||
| 				</td> | ||||
| 				<td align="center"> | ||||
| 				<td align="middle"> | ||||
| 					<h1>checked_delete.hpp</h1> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| @@ -115,8 +116,9 @@ template<class T> struct checked_array_deleter | ||||
| 		</p> | ||||
| 		<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> | ||||
| 			<small>Copyright <20> 2002 by Peter Dimov. 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.</small></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> | ||||
|   | ||||
| @@ -7,9 +7,10 @@ | ||||
| 	<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 width="277"> | ||||
| 					<img src="../../boost.png" alt="boost.png (6897 bytes)" width="277" height="86"> | ||||
| 				</td> | ||||
| 				<td align="center"> | ||||
| 				<td align="middle"> | ||||
| 					<h1>current_function.hpp</h1> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| @@ -29,8 +30,9 @@ | ||||
| 			function. On such compilers, the string literal has an unspecified value.</p> | ||||
| 		<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> | ||||
| 			<small>Copyright <20> 2002 by Peter Dimov. 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.</small></p> | ||||
| 	</body> | ||||
| </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--> | ||||
|   | ||||
							
								
								
									
										33
									
								
								enable_if/test/Jamfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								enable_if/test/Jamfile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| # Copyright David Abrahams 2003. | ||||
| # 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/ | ||||
|  | ||||
| subproject libs/utility/enable_if/test ; | ||||
|  | ||||
| # bring in rules for testing | ||||
| import testing ; | ||||
|  | ||||
| # Make tests run by default. | ||||
| DEPENDS all : test ; | ||||
|  | ||||
| { | ||||
|     local test_monitor = <lib>@boost/libs/test/build/boost_test_exec_monitor ; | ||||
|  | ||||
|     # look in BOOST_ROOT for sources first, just in this Jamfile | ||||
|     local SEARCH_SOURCE = $(BOOST_ROOT) $(SEARCH_SOURCE) ; | ||||
|  | ||||
|     test-suite utility/enable_if | ||||
|         : | ||||
|         [ run libs/utility/enable_if/test/constructors.cpp $(test_monitor) ] | ||||
|         [ run libs/utility/enable_if/test/dummy_arg_disambiguation.cpp $(test_monitor) ] | ||||
|         [ run libs/utility/enable_if/test/lazy.cpp $(test_monitor) ] | ||||
|         [ run libs/utility/enable_if/test/lazy_test.cpp $(test_monitor) ] | ||||
|         [ run libs/utility/enable_if/test/member_templates.cpp $(test_monitor) ] | ||||
|         [ run libs/utility/enable_if/test/namespace_disambiguation.cpp $(test_monitor) ] | ||||
|         [ run libs/utility/enable_if/test/no_disambiguation.cpp $(test_monitor) ] | ||||
|         [ run libs/utility/enable_if/test/partial_specializations.cpp $(test_monitor) ] | ||||
|     ; | ||||
| } | ||||
| @@ -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) | ||||
|  | ||||
| @@ -61,7 +61,7 @@ mult(const T& x, const U& y) {return x * y;} | ||||
| #if 1 | ||||
| template <class T, class U> | ||||
| typename lazy_enable_if_c< | ||||
|   is_int<T>::value & is_int<U>::value, | ||||
|   is_int<T>::value && is_int<U>::value, | ||||
|   mult_traits<T, U>  | ||||
| >::type | ||||
| mult(const T& x, const U& y) {return x * y;} | ||||
|   | ||||
| @@ -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,37 +1,33 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN"> | ||||
|  | ||||
| <html> | ||||
| <head> | ||||
|   <meta http-equiv="Content-Language" content="en-us"> | ||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> | ||||
|  | ||||
|   <title>Generator Iterator Adaptor Documentation</title> | ||||
| <title>Generator Iterator Adaptor Documentation</title> | ||||
| </head> | ||||
|  | ||||
| <body bgcolor="#FFFFFF" text="#000000"> | ||||
|   <img src="../../boost.png" alt="boost.png (6897 bytes)" align="middle" | ||||
|   width="277" height="86"> | ||||
|          | ||||
| <img src="../../boost.png" alt="boost.png (6897 bytes)" align="center" width="277" height="86">  | ||||
|  | ||||
|   <h1>Generator Iterator Adaptor</h1> | ||||
| <h1>Generator Iterator Adaptor</h1> | ||||
| Defined in header <a href="../../boost/generator_iterator.hpp">boost/generator_iterator.hpp</a>  | ||||
| <p> | ||||
| The generator iterator adaptor makes it easier to create custom input | ||||
| iterators from 0-ary functions and function objects.  The adaptor | ||||
| takes a | ||||
| <a href="http://www.sgi.com/tech/stl/Generator.html">Generator</a> | ||||
| and creates a model of | ||||
| <a href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>. | ||||
| Each increment retrieves an item from the generator and makes it | ||||
| available to be retrieved by dereferencing.  The motivation for this | ||||
| iterator is that some concepts can be more naturally expressed as a | ||||
| generator, while most STL algorithms expect an iterator.  An example | ||||
| is the <a href="../random/index.html">Random Number</a> library. | ||||
|  | ||||
|   <p>Defined in header <a href= | ||||
|   "../../boost/generator_iterator.hpp">boost/generator_iterator.hpp</a></p> | ||||
| <h2>Synopsis</h2> | ||||
|  | ||||
|   <p>The generator iterator adaptor makes it easier to create custom input | ||||
|   iterators from 0-ary functions and function objects. The adaptor takes a | ||||
|   <a href="http://www.sgi.com/tech/stl/Generator.html">Generator</a> and | ||||
|   creates a model of <a href= | ||||
|   "http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>. Each | ||||
|   increment retrieves an item from the generator and makes it available to be | ||||
|   retrieved by dereferencing. The motivation for this iterator is that some | ||||
|   concepts can be more naturally expressed as a generator, while most STL | ||||
|   algorithms expect an iterator. An example is the <a href= | ||||
|   "../random/index.html">Random Number</a> library.</p> | ||||
|  | ||||
|   <h2>Synopsis</h2> | ||||
|  | ||||
|   <blockquote> | ||||
|     <pre> | ||||
| <blockquote> | ||||
| <pre> | ||||
| namespace boost { | ||||
|   template <class Generator> | ||||
|   class generator_iterator_policies; | ||||
| @@ -44,19 +40,21 @@ namespace boost { | ||||
|   make_generator_iterator(Generator & gen); | ||||
| } | ||||
| </pre> | ||||
|   </blockquote> | ||||
|   <hr> | ||||
| </blockquote> | ||||
|  | ||||
|   <h2>The Generator Iterator Generator Class</h2> | ||||
| <hr> | ||||
|  | ||||
|   <p>The class generator_iterator_generator is a helper class whose purpose | ||||
|   is to construct a generator iterator type. The template parameter for this | ||||
|   class is the Generator function object type that is being wrapped. The | ||||
|   generator iterator adaptor only holds a reference (or pointer) to the | ||||
|   function object, therefore the function object must outlive the generator | ||||
|   iterator adaptor constructed from it.</p> | ||||
|   <pre> | ||||
| template <class Generator> | ||||
| <h2>The Generator Iterator Generator Class</h2> | ||||
|  | ||||
| The class generator_iterator_generator is a helper class whose purpose | ||||
| is to construct a generator iterator type. The template parameter for | ||||
| this class is the Generator function object type that is being | ||||
| wrapped.  The generator iterator adaptor only holds a reference (or | ||||
| pointer) to the function object, therefore the function object must | ||||
| outlive the generator iterator adaptor constructed from it. | ||||
|  | ||||
| <pre> | ||||
| template <class Generator> | ||||
| class generator_iterator_generator | ||||
| { | ||||
| public: | ||||
| @@ -64,65 +62,65 @@ public: | ||||
| } | ||||
| </pre> | ||||
|  | ||||
|   <h3>Template Parameters</h3> | ||||
|  | ||||
|   <table border summary=""> | ||||
|     <tr> | ||||
|       <th>Parameter</th> | ||||
| <h3>Template Parameters</h3> | ||||
|  | ||||
|       <th>Description</th> | ||||
|     </tr> | ||||
| <table border> | ||||
| <tr> | ||||
| <th>Parameter</th> | ||||
| <th>Description</th> | ||||
| </tr> | ||||
|  | ||||
|     <tr> | ||||
|       <td><tt><a href= | ||||
|       "http://www.sgi.com/tech/stl/Generator.html">Generator</a></tt></td> | ||||
| <tr> | ||||
| <td><tt><a href="http://www.sgi.com/tech/stl/Generator.html">Generator</a></tt>  | ||||
| <td>The generator (0-ary function object) type being | ||||
| wrapped.  The return type of the function must be defined as | ||||
| <tt>Generator::result_type</tt>.  The function object must be a model | ||||
| of | ||||
| <a href="http://www.sgi.com/tech/stl/Generator.html">Generator</a>. | ||||
| </td> | ||||
| </table> | ||||
|  | ||||
|       <td>The generator (0-ary function object) type being wrapped. The | ||||
|       return type of the function must be defined as | ||||
|       <tt>Generator::result_type</tt>. The function object must be a model of | ||||
|       <a href= | ||||
|       "http://www.sgi.com/tech/stl/Generator.html">Generator</a>.</td> | ||||
|     </tr> | ||||
|   </table> | ||||
| <h3>Concept Model</h3> | ||||
| The generator iterator class is a model of | ||||
| <a href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>. | ||||
|  | ||||
|   <h3>Concept Model</h3> | ||||
| <h3>Members</h3> | ||||
| The generator iterator implements the member functions | ||||
| and operators required of the | ||||
| <a href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a> | ||||
| concept. | ||||
|  | ||||
|   <p>The generator iterator class is a model of <a href= | ||||
|   "http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>.</p> | ||||
| <br> | ||||
|  | ||||
|   <h3>Members</h3> | ||||
| <hr> | ||||
| <h2><a name="make_generator_iterator">The Generator Iterator Object Generator</a></h2> | ||||
|  | ||||
|   <p>The generator iterator implements the member functions and operators | ||||
|   required of the <a href= | ||||
|   "http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a> | ||||
|   concept.<br></p> | ||||
|   <hr> | ||||
| The <tt>make_generator_iterator()</tt> function provides a | ||||
| convenient way to create generator iterator objects. The function | ||||
| saves the user the trouble of explicitly writing out the iterator | ||||
| types. | ||||
|  | ||||
|   <h2><a name="make_generator_iterator" id="make_generator_iterator">The | ||||
|   Generator Iterator Object Generator</a></h2> | ||||
|  | ||||
|   <p>The <tt>make_generator_iterator()</tt> function provides a convenient | ||||
|   way to create generator iterator objects. The function saves the user the | ||||
|   trouble of explicitly writing out the iterator types.</p> | ||||
|  | ||||
|   <blockquote> | ||||
|     <pre> | ||||
| <blockquote> | ||||
| <pre> | ||||
| template <class Generator> | ||||
| typename generator_iterator_generator<Generator>::type | ||||
| make_generator_iterator(Generator & gen); | ||||
| </pre> | ||||
|   </blockquote> | ||||
|   <hr> | ||||
| </blockquote> | ||||
|  | ||||
|   <h3>Example</h3> | ||||
| <hr> | ||||
|  | ||||
|   <p>The following program shows how <code>generator_iterator</code> | ||||
|   transforms a generator into an input iterator.</p> | ||||
|  | ||||
|   <blockquote> | ||||
|     <pre> | ||||
| #include <iostream> | ||||
| #include <boost/generator_iterator.hpp> | ||||
| <h3>Example</h3> | ||||
|  | ||||
| The following program shows how <code>generator_iterator</code> | ||||
| transforms a generator into an input iterator. | ||||
|  | ||||
| <blockquote> | ||||
| <pre> | ||||
| #include <iostream> | ||||
| #include <boost/generator_iterator.hpp> | ||||
|  | ||||
| class my_generator | ||||
| { | ||||
| @@ -142,22 +140,11 @@ int main() | ||||
|     std::cout << *it << std::endl; | ||||
| } | ||||
| </pre> | ||||
|   </blockquote> | ||||
|   <hr> | ||||
| </blockquote> | ||||
|  | ||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | ||||
|   "http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" | ||||
|   height="31" width="88"></a></p> | ||||
| <hr> | ||||
|  | ||||
|   <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> | ||||
| Written by Jens Maurer. | ||||
|  | ||||
|   <p><i>Copyright © 2001 <a href= | ||||
|   "http://www.boost.org/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 | ||||
|   copy at <a href= | ||||
|   "http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>)</i></p> | ||||
| </body> | ||||
| </html> | ||||
|   | ||||
| @@ -3,8 +3,9 @@ | ||||
| <HTML> | ||||
|  | ||||
| <HEAD> | ||||
| <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=windows-1252"> | ||||
| <TITLE>In_place_factory Documentation</TITLE> | ||||
| <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1"> | ||||
| <LINK REL="stylesheet" TYPE="text/css" HREF="../../boost.css"> | ||||
| <TITLE>Header </TITLE> | ||||
| </HEAD> | ||||
|  | ||||
| <BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#800080"> | ||||
| @@ -76,7 +77,7 @@ object is likely to be temporary and serve no purpose besides being the source</ | ||||
| </pre> | ||||
| <p>A solution to this problem is to support direct construction of the contained | ||||
| object right in the container's storage.<br> | ||||
| In this scheme, the user supplies the arguments for the X constructor | ||||
| In this shceme, the user supplies the arguments for the X constructor | ||||
| directly to the container:</p> | ||||
| <pre>struct C | ||||
| { | ||||
| @@ -137,7 +138,7 @@ The following simplified example shows the basic idea. A complete example follow | ||||
|  | ||||
| void foo() | ||||
| { | ||||
|   C c( in_place(123,"hello") ) ; | ||||
|   C c( in_place(123,"hello" ) ; | ||||
| } | ||||
| </pre> | ||||
|  | ||||
|   | ||||
| @@ -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 | ||||
|   | ||||
| @@ -32,10 +32,6 @@ inline void current_function_helper() | ||||
|  | ||||
| # define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__ | ||||
|  | ||||
| #elif defined(__DMC__) && (__DMC__ >= 0x810) | ||||
|  | ||||
| # define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__ | ||||
|  | ||||
| #elif defined(__FUNCSIG__) | ||||
|  | ||||
| # define BOOST_CURRENT_FUNCTION __FUNCSIG__ | ||||
|   | ||||
| @@ -58,7 +58,7 @@ struct ct_imp<T, isp, true> | ||||
| template <typename T, bool b1> | ||||
| struct ct_imp<T, true, b1> | ||||
| { | ||||
|    typedef const T param_type; | ||||
|    typedef T const param_type; | ||||
| }; | ||||
|  | ||||
| } | ||||
| @@ -76,7 +76,7 @@ public: | ||||
|    // however compiler bugs prevent this - instead pass three bool's to | ||||
|    // ct_imp<T,bool,bool,bool> and add an extra partial specialisation | ||||
|    // of ct_imp to handle the logic. (JM) | ||||
|    typedef typename boost::detail::ct_imp< | ||||
|    typedef typename detail::ct_imp< | ||||
|       T, | ||||
|       ::boost::is_pointer<T>::value, | ||||
|       ::boost::is_arithmetic<T>::value | ||||
| @@ -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( 0x570 ) ) | ||||
| // 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 | ||||
| @@ -121,15 +121,6 @@ struct call_traits<T&const volatile> | ||||
|    typedef const T& const_reference; | ||||
|    typedef T& param_type;  // hh removed const | ||||
| }; | ||||
|  | ||||
| template <typename T> | ||||
| struct call_traits< T * > | ||||
| { | ||||
|    typedef T * value_type; | ||||
|    typedef T * & reference; | ||||
|    typedef T * const & const_reference; | ||||
|    typedef T * const param_type;  // hh removed const | ||||
| }; | ||||
| #endif | ||||
| #if !defined(BOOST_NO_ARRAY_TYPE_SPECIALIZATIONS) | ||||
| template <typename T, std::size_t N> | ||||
|   | ||||
| @@ -27,10 +27,6 @@ | ||||
| #include <boost/type_traits/is_same.hpp> | ||||
| #include <boost/call_traits.hpp> | ||||
|  | ||||
| #ifdef BOOST_MSVC | ||||
| # pragma warning(push) | ||||
| # pragma warning(disable:4512) | ||||
| #endif  | ||||
| namespace boost | ||||
| { | ||||
|  | ||||
| @@ -136,7 +132,7 @@ namespace details | ||||
|  | ||||
|    template <class T1, class T2> | ||||
|    class compressed_pair_imp<T1, T2, 1> | ||||
|       : protected ::boost::remove_cv<T1>::type | ||||
|       : private ::boost::remove_cv<T1>::type | ||||
|    { | ||||
|    public: | ||||
|       typedef T1                                                 first_type; | ||||
| @@ -178,7 +174,7 @@ namespace details | ||||
|  | ||||
|    template <class T1, class T2> | ||||
|    class compressed_pair_imp<T1, T2, 2> | ||||
|       : protected ::boost::remove_cv<T2>::type | ||||
|       : private ::boost::remove_cv<T2>::type | ||||
|    { | ||||
|    public: | ||||
|       typedef T1                                                 first_type; | ||||
| @@ -221,8 +217,8 @@ namespace details | ||||
|  | ||||
|    template <class T1, class T2> | ||||
|    class compressed_pair_imp<T1, T2, 3> | ||||
|       : protected ::boost::remove_cv<T1>::type, | ||||
|         protected ::boost::remove_cv<T2>::type | ||||
|       : private ::boost::remove_cv<T1>::type, | ||||
|         private ::boost::remove_cv<T2>::type | ||||
|    { | ||||
|    public: | ||||
|       typedef T1                                                 first_type; | ||||
| @@ -257,14 +253,11 @@ namespace details | ||||
|  | ||||
|    // JM | ||||
|    // 4    T1 == T2, T1 and T2 both empty | ||||
|    //      Originally this did not store an instance of T2 at all | ||||
|    //      but that led to problems beause it meant &x.first() == &x.second() | ||||
|    //      which is not true for any other kind of pair, so now we store an instance | ||||
|    //      of T2 just in case the user is relying on first() and second() returning | ||||
|    //      different objects (albeit both empty). | ||||
|    //      Note does not actually store an instance of T2 at all - | ||||
|    //      but reuses T1 base class for both first() and second(). | ||||
|    template <class T1, class T2> | ||||
|    class compressed_pair_imp<T1, T2, 4> | ||||
|       : protected ::boost::remove_cv<T1>::type | ||||
|       : private ::boost::remove_cv<T1>::type | ||||
|    { | ||||
|    public: | ||||
|       typedef T1                                                 first_type; | ||||
| @@ -435,9 +428,5 @@ swap(compressed_pair<T1, T2>& x, compressed_pair<T1, T2>& y) | ||||
|  | ||||
| } // boost | ||||
|  | ||||
| #ifdef BOOST_MSVC | ||||
| # pragma warning(pop) | ||||
| #endif  | ||||
|  | ||||
| #endif // BOOST_DETAIL_COMPRESSED_PAIR_HPP | ||||
|  | ||||
|   | ||||
| @@ -1,17 +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 | ||||
|  | ||||
| #include <boost/exception/diagnostic_information.hpp> | ||||
| #include <boost/exception/error_info.hpp> | ||||
| #include <boost/exception/exception.hpp> | ||||
| #include <boost/exception/get_error_info.hpp> | ||||
| #include <boost/exception/info.hpp> | ||||
| #include <boost/exception/info_tuple.hpp> | ||||
| #include <boost/exception_ptr.hpp> | ||||
|  | ||||
| #endif | ||||
| @@ -8,11 +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 | ||||
| //            correct named return value optimization (NRVO) to produce optimal | ||||
| //            code.  (Daniel Frey) | ||||
| @@ -95,14 +90,14 @@ | ||||
| namespace boost { | ||||
| namespace detail { | ||||
|  | ||||
| template <typename T> class empty_base { | ||||
|  | ||||
| // Helmut Zeisel, empty base class optimization bug with GCC 3.0.0 | ||||
| #if defined(__GNUC__) && __GNUC__==3 && __GNUC_MINOR__==0 && __GNU_PATCHLEVEL__==0 | ||||
| class empty_base { | ||||
|   bool dummy;  | ||||
| #endif | ||||
|  | ||||
| }; | ||||
| #else | ||||
| class empty_base {}; | ||||
| #endif | ||||
|  | ||||
| } // namespace detail | ||||
| } // namespace boost | ||||
| @@ -124,37 +119,37 @@ namespace boost | ||||
| //  Note that friend functions defined in a class are implicitly inline. | ||||
| //  See the C++ std, 11.4 [class.friend] paragraph 5 | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| 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> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| 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> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| 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> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| 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". | ||||
| @@ -170,7 +165,7 @@ struct equality_comparable1 : B | ||||
| // implementation available. | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>            \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||
| @@ -179,33 +174,33 @@ struct NAME##2 : B                                                            \ | ||||
|     { T nrv( rhs ); nrv OP##= lhs; return nrv; }                              \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| template <class T, class B = ::boost::detail::empty_base>                     \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| }; | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )               \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct BOOST_OPERATOR2_LEFT(NAME) : B                                   \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )           \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>  \ | ||||
| struct NAME##2 : B                                                  \ | ||||
| {                                                                   \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                    \ | ||||
| };                                                                  \ | ||||
|                                                                     \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>  \ | ||||
| struct BOOST_OPERATOR2_LEFT(NAME) : B                               \ | ||||
| {                                                                   \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                    \ | ||||
| };                                                                  \ | ||||
|                                                                     \ | ||||
| template <class T, class B = ::boost::detail::empty_base>           \ | ||||
| struct NAME##1 : B                                                  \ | ||||
| {                                                                   \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                    \ | ||||
| }; | ||||
|  | ||||
| #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
| @@ -215,35 +210,35 @@ struct NAME##1 : B                                                      \ | ||||
| // BOOST_OPERATOR2_LEFT(NAME) only looks cool, but doesn't provide | ||||
| // optimization opportunities to the compiler :) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                   \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; } \ | ||||
|   friend T operator OP( const U& lhs, T rhs ) { return rhs OP##= lhs; } \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; } \ | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>            \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; }       \ | ||||
|   friend T operator OP( const U& lhs, T rhs ) { return rhs OP##= lhs; }       \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base>                     \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ | ||||
| }; | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )               \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>      \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; } \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>      \ | ||||
| struct BOOST_OPERATOR2_LEFT(NAME) : B                                   \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                    \ | ||||
|     { return T( lhs ) OP##= rhs; }                                      \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| template <class T, class B = ::boost::detail::empty_base>               \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; } \ | ||||
| @@ -266,7 +261,7 @@ BOOST_BINARY_OPERATOR_COMMUTATIVE( orable, | ) | ||||
|  | ||||
| //  incrementable and decrementable contributed by Jeremy Siek | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct incrementable : B | ||||
| { | ||||
|   friend T operator++(T& x, int) | ||||
| @@ -279,7 +274,7 @@ private: // The use of this typedef works around a Borland bug | ||||
|   typedef T incrementable_type; | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct decrementable : B | ||||
| { | ||||
|   friend T operator--(T& x, int) | ||||
| @@ -294,7 +289,7 @@ private: // The use of this typedef works around a Borland bug | ||||
|  | ||||
| //  Iterator operator classes (contributed by Jeremy Siek) ------------------// | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class B = ::boost::detail::empty_base> | ||||
| struct dereferenceable : B | ||||
| { | ||||
|   P operator->() const | ||||
| @@ -303,7 +298,7 @@ struct dereferenceable : B | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class I, class R, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class I, class R, class B = ::boost::detail::empty_base> | ||||
| struct indexable : B | ||||
| { | ||||
|   R operator[](I n) const | ||||
| @@ -318,14 +313,14 @@ struct indexable : B | ||||
| #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>            \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| template <class T, class B = ::boost::detail::empty_base>                     \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||
| @@ -335,13 +330,13 @@ struct NAME##1 : B                                                            \ | ||||
| #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base>            \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; }       \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| template <class T, class B = ::boost::detail::empty_base>                     \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ | ||||
| @@ -354,209 +349,209 @@ BOOST_BINARY_OPERATOR( right_shiftable, >> ) | ||||
|  | ||||
| #undef BOOST_BINARY_OPERATOR | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| 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); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| 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); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| 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> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| 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) ----------------// | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct totally_ordered2 | ||||
|     : less_than_comparable2<T, U | ||||
|     , equality_comparable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct totally_ordered1 | ||||
|     : less_than_comparable1<T | ||||
|     , equality_comparable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct additive2 | ||||
|     : addable2<T, U | ||||
|     , subtractable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct additive1 | ||||
|     : addable1<T | ||||
|     , subtractable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct multiplicative2 | ||||
|     : multipliable2<T, U | ||||
|     , dividable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct multiplicative1 | ||||
|     : multipliable1<T | ||||
|     , dividable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct integer_multiplicative2 | ||||
|     : multiplicative2<T, U | ||||
|     , modable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct integer_multiplicative1 | ||||
|     : multiplicative1<T | ||||
|     , modable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct arithmetic2 | ||||
|     : additive2<T, U | ||||
|     , multiplicative2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct arithmetic1 | ||||
|     : additive1<T | ||||
|     , multiplicative1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct integer_arithmetic2 | ||||
|     : additive2<T, U | ||||
|     , integer_multiplicative2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct integer_arithmetic1 | ||||
|     : additive1<T | ||||
|     , integer_multiplicative1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct bitwise2 | ||||
|     : xorable2<T, U | ||||
|     , andable2<T, U | ||||
|     , orable2<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct bitwise1 | ||||
|     : xorable1<T | ||||
|     , andable1<T | ||||
|     , orable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct unit_steppable | ||||
|     : incrementable<T | ||||
|     , decrementable<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct shiftable2 | ||||
|     : left_shiftable2<T, U | ||||
|     , right_shiftable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct shiftable1 | ||||
|     : left_shiftable1<T | ||||
|     , right_shiftable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct ring_operators2 | ||||
|     : additive2<T, U | ||||
|     , subtractable2_left<T, U | ||||
|     , multipliable2<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct ring_operators1 | ||||
|     : additive1<T | ||||
|     , multipliable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct ordered_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , totally_ordered2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct ordered_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , totally_ordered1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct field_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
|     , dividable2_left<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct field_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct ordered_field_operators2 | ||||
|     : field_operators2<T, U | ||||
|     , totally_ordered2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct ordered_field_operators1 | ||||
|     : field_operators1<T | ||||
|     , totally_ordered1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct euclidian_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
| @@ -565,71 +560,43 @@ struct euclidian_ring_operators2 | ||||
|     , modable2_left<T, U, B | ||||
|       > > > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct euclidian_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T | ||||
|     , modable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = ::boost::detail::empty_base> | ||||
| struct ordered_euclidian_ring_operators2 | ||||
|     : totally_ordered2<T, U | ||||
|     , euclidian_ring_operators2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| 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> > | ||||
|        | ||||
| template <class T, class P, class B = ::boost::detail::empty_base> | ||||
| struct input_iteratable | ||||
|     : equality_comparable1<T | ||||
|     , incrementable<T | ||||
|     , dereferenceable<T, P, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = ::boost::detail::empty_base> | ||||
| struct output_iteratable | ||||
|     : incrementable<T, B | ||||
|       > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class B = ::boost::detail::empty_base> | ||||
| struct forward_iteratable | ||||
|     : input_iteratable<T, P, B | ||||
|       > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class B = ::boost::detail::empty_base> | ||||
| struct bidirectional_iteratable | ||||
|     : forward_iteratable<T, P | ||||
|     , decrementable<T, B | ||||
| @@ -639,7 +606,7 @@ struct bidirectional_iteratable | ||||
| //  which is an indirect base class of bidirectional_iterable, | ||||
| //  random_access_iteratable must not be derived from totally_ordered1 | ||||
| //  but from less_than_comparable1 only. (Helmut Zeisel, 02-Dec-2001) | ||||
| template <class T, class P, class D, class R, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class D, class R, class B = ::boost::detail::empty_base> | ||||
| struct random_access_iteratable | ||||
|     : bidirectional_iteratable<T, P | ||||
|     , less_than_comparable1<T | ||||
| @@ -683,20 +650,20 @@ struct random_access_iteratable | ||||
|  | ||||
|      // Otherwise, because a Borland C++ 5.5 bug prevents a using declaration | ||||
|      // from working, we are forced to use inheritance for that compiler. | ||||
| #    define BOOST_IMPORT_TEMPLATE4(template_name)                                             \ | ||||
|      template <class T, class U, class V, class W, class B = ::boost::detail::empty_base<T> > \ | ||||
| #    define BOOST_IMPORT_TEMPLATE4(template_name)                                          \ | ||||
|      template <class T, class U, class V, class W, class B = ::boost::detail::empty_base>  \ | ||||
|      struct template_name : ::template_name<T, U, V, W, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE3(template_name)                                    \ | ||||
|      template <class T, class U, class V, class B = ::boost::detail::empty_base<T> > \ | ||||
| #    define BOOST_IMPORT_TEMPLATE3(template_name)                                 \ | ||||
|      template <class T, class U, class V, class B = ::boost::detail::empty_base>  \ | ||||
|      struct template_name : ::template_name<T, U, V, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE2(template_name)                           \ | ||||
|      template <class T, class U, class B = ::boost::detail::empty_base<T> > \ | ||||
| #    define BOOST_IMPORT_TEMPLATE2(template_name)                              \ | ||||
|      template <class T, class U, class B = ::boost::detail::empty_base>        \ | ||||
|      struct template_name : ::template_name<T, U, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE1(template_name)                  \ | ||||
|      template <class T, class B = ::boost::detail::empty_base<T> > \ | ||||
| #    define BOOST_IMPORT_TEMPLATE1(template_name)                              \ | ||||
|      template <class T, class B = ::boost::detail::empty_base>                 \ | ||||
|      struct template_name : ::template_name<T, B> {}; | ||||
|  | ||||
| #  endif // BOOST_NO_USING_TEMPLATE | ||||
| @@ -785,7 +752,7 @@ template<class T> struct is_chained_base { | ||||
| # define BOOST_OPERATOR_TEMPLATE(template_name)                    \ | ||||
| template <class T                                                  \ | ||||
|          ,class U = T                                              \ | ||||
|          ,class B = ::boost::detail::empty_base<T>                 \ | ||||
|          ,class B = ::boost::detail::empty_base                    \ | ||||
|          ,class O = typename is_chained_base<U>::value             \ | ||||
|          >                                                         \ | ||||
| struct template_name : template_name##2<T, U, B> {};               \ | ||||
| @@ -821,7 +788,7 @@ BOOST_OPERATOR_TEMPLATE1(template_name##1) | ||||
|    // In this case we can only assume that template_name<> is equivalent to the | ||||
|    // more commonly needed template_name1<> form. | ||||
| #  define BOOST_OPERATOR_TEMPLATE(template_name)                   \ | ||||
|    template <class T, class B = ::boost::detail::empty_base<T> >   \ | ||||
|    template <class T, class B = ::boost::detail::empty_base>       \ | ||||
|    struct template_name : template_name##1<T, B> {}; | ||||
|  | ||||
| #endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||
| @@ -868,8 +835,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) | ||||
|   | ||||
| @@ -10,12 +10,11 @@ | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/utility/addressof.hpp> | ||||
| #include <boost/mpl/bool.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
|  | ||||
| // | ||||
| //  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 | ||||
| // | ||||
| @@ -34,7 +33,7 @@ template<class T> class reference_wrapper | ||||
| public: | ||||
|     typedef T type; | ||||
|  | ||||
| #if defined( BOOST_MSVC ) && BOOST_WORKAROUND( BOOST_MSVC, < 1300 ) | ||||
| #if defined(BOOST_MSVC) && (BOOST_MSVC < 1300) | ||||
|  | ||||
|     explicit reference_wrapper(T& t): t_(&t) {} | ||||
|  | ||||
| @@ -55,7 +54,7 @@ private: | ||||
|     T* t_; | ||||
| }; | ||||
|  | ||||
| # if defined( __BORLANDC__ ) && BOOST_WORKAROUND( __BORLANDC__, BOOST_TESTED_AT(0x581) ) | ||||
| # if defined(__BORLANDC__) && (__BORLANDC__ <= 0x570) | ||||
| #  define BOOST_REF_CONST | ||||
| # else | ||||
| #  define BOOST_REF_CONST const | ||||
| @@ -173,12 +172,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; | ||||
| } | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| #endif // #ifndef BOOST_REF_HPP_INCLUDED | ||||
|   | ||||
| @@ -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,31 +14,27 @@ | ||||
| # 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 addressof_impl | ||||
| { | ||||
|     static inline T * f( T & v, long ) | ||||
|     { | ||||
|         return reinterpret_cast<T*>( | ||||
|             &const_cast<char&>(reinterpret_cast<const volatile char &>(v))); | ||||
|     } | ||||
| // VC7 strips const from nested classes unless we add indirection here | ||||
| # if BOOST_WORKAROUND(BOOST_MSVC, == 1300) | ||||
|  | ||||
|     static inline T * f( T * v, int ) | ||||
|     { | ||||
|         return v; | ||||
|     } | ||||
| template<class T> struct _addp | ||||
| { | ||||
|     typedef T * type; | ||||
| }; | ||||
|      | ||||
| template <typename T> typename _addp<T>::type | ||||
|  | ||||
| } // namespace detail | ||||
|  | ||||
| template<class T> T * addressof( T & v ) | ||||
| # else | ||||
| template <typename T> T* | ||||
| # endif | ||||
| addressof(T& v) | ||||
| { | ||||
|     return boost::detail::addressof_impl<T>::f( v, 0 ); | ||||
|   return reinterpret_cast<T*>( | ||||
|        &const_cast<char&>(reinterpret_cast<const volatile char &>(v))); | ||||
| } | ||||
|  | ||||
| // Borland doesn't like casting an array reference to a char reference | ||||
| @@ -58,6 +53,6 @@ const T (*addressof(const T (&t)[N]))[N] | ||||
| } | ||||
| # 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,5 +1,4 @@ | ||||
| // Copyright (C) 2003, Fernando Luis Cacciola Carballal. | ||||
| // Copyright (C) 2007, Tobias Schwinger. | ||||
| // | ||||
| // Use, modification, and distribution is subject to the Boost Software | ||||
| // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | ||||
| @@ -10,27 +9,25 @@ | ||||
| // You are welcome to contact the author at: | ||||
| //  fernando_cacciola@hotmail.com | ||||
| // | ||||
| #ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_04APR2007_HPP | ||||
| #define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_04APR2007_HPP | ||||
| #ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_25AGO2003_HPP | ||||
| #define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_25AGO2003_HPP | ||||
|  | ||||
| #include <new> | ||||
| #include <cstddef> | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/preprocessor/cat.hpp> | ||||
| #include <boost/preprocessor/punctuation/paren.hpp> | ||||
| #include <boost/preprocessor/iteration/iterate.hpp> | ||||
| #include <boost/preprocessor/repetition/repeat.hpp> | ||||
| #include <boost/preprocessor/repetition/enum.hpp> | ||||
| #include <boost/preprocessor/repetition/enum_params.hpp> | ||||
| #include <boost/preprocessor/repetition/enum_binary_params.hpp> | ||||
| #include <boost/preprocessor/repetition/enum_trailing_params.hpp> | ||||
| #include <boost/preprocessor/cat.hpp> | ||||
| #include <boost/preprocessor/arithmetic/inc.hpp> | ||||
| #include <boost/preprocessor/punctuation/paren.hpp> | ||||
| #include <boost/preprocessor/facilities/empty.hpp> | ||||
|  | ||||
| #define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT(z,n,_) BOOST_PP_CAT(m_a,n) BOOST_PP_LPAREN() BOOST_PP_CAT(a,n) BOOST_PP_RPAREN() | ||||
| #define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL(z,n,_) BOOST_PP_CAT(A,n) const& BOOST_PP_CAT(m_a,n); | ||||
| #define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_ARG(z,n,_)  BOOST_PP_CAT(m_a,n) | ||||
|  | ||||
| #define BOOST_MAX_INPLACE_FACTORY_ARITY 10 | ||||
|  | ||||
| #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_04APR2007_HPP | ||||
| #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_25AGO2003_HPP | ||||
|  | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| // Copyright (C) 2003, Fernando Luis Cacciola Carballal. | ||||
| // Copyright (C) 2007, Tobias Schwinger. | ||||
| // | ||||
| // Use, modification, and distribution is subject to the Boost Software | ||||
| // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | ||||
| @@ -10,14 +9,15 @@ | ||||
| // You are welcome to contact the author at: | ||||
| //  fernando_cacciola@hotmail.com | ||||
| // | ||||
| #ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_04APR2007_HPP | ||||
| #define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_04APR2007_HPP | ||||
| #ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_25AGO2003_HPP | ||||
| #define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_25AGO2003_HPP | ||||
|  | ||||
| #undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT | ||||
| #undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL | ||||
| #undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_ARG | ||||
| #undef BOOST_MAX_INPLACE_FACTORY_ARITY | ||||
|  | ||||
| #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_04APR2007_HPP | ||||
| #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_25AGO2003_HPP | ||||
|  | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -10,47 +10,6 @@ | ||||
| # error Boost result_of - do not include this file! | ||||
| #endif | ||||
|  | ||||
| #if defined(BOOST_HAS_DECLTYPE) | ||||
|  | ||||
| // As of N2588, C++0x result_of only supports function call | ||||
| // expressions of the form f(x). This precludes support for member | ||||
| // function pointers, which are invoked with expressions of the form | ||||
| // o->*f(x). This implementation supports both. | ||||
| template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of<F(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T))> | ||||
|     : mpl::if_< | ||||
|           mpl::or_< is_pointer<F>, is_member_function_pointer<F> > | ||||
|         , detail::result_of_impl< | ||||
|             typename remove_cv<F>::type,  | ||||
|             typename remove_cv<F>::type(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), false | ||||
|           > | ||||
|         , detail::result_of_decltype_impl< | ||||
|               F(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)) | ||||
|           > | ||||
|       >::type | ||||
| {}; | ||||
|  | ||||
| namespace detail { | ||||
|  | ||||
| # define BOOST_RESULT_OF_STATIC_MEMBERS(z, n, _) \ | ||||
|      static T ## n t ## n; \ | ||||
|   /**/ | ||||
|  | ||||
| template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| class result_of_decltype_impl<F(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T))> | ||||
| { | ||||
|   static F f; | ||||
|   BOOST_PP_REPEAT(BOOST_PP_ITERATION(), BOOST_RESULT_OF_STATIC_MEMBERS, _) | ||||
| public: | ||||
|   typedef decltype(f(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),t))) type; | ||||
| }; | ||||
|  | ||||
| } // namespace detail  | ||||
|  | ||||
| #else // defined(BOOST_HAS_DECLTYPE) | ||||
|  | ||||
| // CWPro8 requires an argument in a function type specialization | ||||
| #if BOOST_WORKAROUND(__MWERKS__, BOOST_TESTED_AT(0x3002)) && BOOST_PP_ITERATION() == 0 | ||||
| # define BOOST_RESULT_OF_ARGS void | ||||
| @@ -62,80 +21,66 @@ public: | ||||
| template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of<F(BOOST_RESULT_OF_ARGS)> | ||||
|     : mpl::if_< | ||||
|           mpl::or_< is_pointer<F>, is_member_function_pointer<F> > | ||||
|         , boost::detail::result_of_impl< | ||||
|             typename remove_cv<F>::type,  | ||||
|             typename remove_cv<F>::type(BOOST_RESULT_OF_ARGS),  | ||||
|             (boost::detail::has_result_type<F>::value)> | ||||
|         , boost::detail::result_of_impl< | ||||
|             F, | ||||
|             F(BOOST_RESULT_OF_ARGS),  | ||||
|             (boost::detail::has_result_type<F>::value)> >::type { }; | ||||
|     : detail::result_of<F, F(BOOST_RESULT_OF_ARGS)> {}; | ||||
| #endif | ||||
|  | ||||
| #undef BOOST_RESULT_OF_ARGS | ||||
|  | ||||
| #endif // defined(BOOST_HAS_DECLTYPE) | ||||
|  | ||||
| #if BOOST_PP_ITERATION() >= 1  | ||||
|  | ||||
| namespace detail { | ||||
|  | ||||
| template<typename R,  typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of_impl<R (*)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false> | ||||
| struct result_of<R (*)(BOOST_RESULT_OF_ARGS), FArgs> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
|  | ||||
| template<typename R,  typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of_impl<R (&)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false> | ||||
| struct result_of<R (&)(BOOST_RESULT_OF_ARGS), FArgs> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
|  | ||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551)) | ||||
| #undef BOOST_RESULT_OF_ARGS | ||||
|  | ||||
| #if BOOST_PP_ITERATION() > 1 && !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551)) | ||||
| template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of_impl<R (T0::*) | ||||
| struct result_of<R (T0::*) | ||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)), | ||||
|                  FArgs, false> | ||||
|                  FArgs> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
|  | ||||
| template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of_impl<R (T0::*) | ||||
| struct result_of<R (T0::*) | ||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) | ||||
|                      const, | ||||
|                  FArgs, false> | ||||
|                  FArgs> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
|  | ||||
| template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of_impl<R (T0::*) | ||||
| struct result_of<R (T0::*) | ||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) | ||||
|                      volatile, | ||||
|                  FArgs, false> | ||||
|                  FArgs> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
|  | ||||
| template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) | ||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of_impl<R (T0::*) | ||||
| struct result_of<R (T0::*) | ||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) | ||||
|                      const volatile, | ||||
|                  FArgs, false> | ||||
|                  FArgs> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| } | ||||
| #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) | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| // Copyright (C) 2003, Fernando Luis Cacciola Carballal. | ||||
| // Copyright (C) 2007, Tobias Schwinger. | ||||
| // | ||||
| // Use, modification, and distribution is subject to the Boost Software | ||||
| // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | ||||
| @@ -10,79 +9,50 @@ | ||||
| // You are welcome to contact the author at: | ||||
| //  fernando_cacciola@hotmail.com | ||||
| // | ||||
| #ifndef BOOST_UTILITY_INPLACE_FACTORY_04APR2007_HPP | ||||
| #ifndef BOOST_PP_IS_ITERATING | ||||
| #ifndef BOOST_UTILITY_INPLACE_FACTORY_25AGO2003_HPP | ||||
| #define BOOST_UTILITY_INPLACE_FACTORY_25AGO2003_HPP | ||||
|  | ||||
| #include <boost/utility/detail/in_place_factory_prefix.hpp> | ||||
|  | ||||
| #include <boost/type.hpp> | ||||
|  | ||||
| namespace boost { | ||||
|  | ||||
| class in_place_factory_base {} ; | ||||
|  | ||||
| #define  BOOST_PP_ITERATION_LIMITS (0, BOOST_MAX_INPLACE_FACTORY_ARITY) | ||||
| #define  BOOST_PP_FILENAME_1 <boost/utility/in_place_factory.hpp> | ||||
| #include BOOST_PP_ITERATE() | ||||
| #define BOOST_DEFINE_INPLACE_FACTORY_CLASS(z,n,_) \ | ||||
| template< BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \ | ||||
| class BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) : public in_place_factory_base \ | ||||
| { \ | ||||
| public: \ | ||||
| \ | ||||
|   BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A,const& a) ) \ | ||||
|     : \ | ||||
|     BOOST_PP_ENUM( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT, _ ) \ | ||||
|   {} \ | ||||
| \ | ||||
|   template<class T> \ | ||||
|   void apply ( void* address BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE(T) ) const \ | ||||
|   { \ | ||||
|     new ( address ) T ( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), m_a ) ) ; \ | ||||
|   } \ | ||||
| \ | ||||
|   BOOST_PP_REPEAT( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL, _) \ | ||||
| } ; \ | ||||
| \ | ||||
| template< BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \ | ||||
| BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) < BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \ | ||||
| in_place ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A, const& a) ) \ | ||||
| { \ | ||||
|   return BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) < BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \ | ||||
|            ( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), a ) ) ; \ | ||||
| } ; \ | ||||
|  | ||||
| BOOST_PP_REPEAT( BOOST_MAX_INPLACE_FACTORY_ARITY, BOOST_DEFINE_INPLACE_FACTORY_CLASS, BOOST_PP_EMPTY() ) | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| #include <boost/utility/detail/in_place_factory_suffix.hpp> | ||||
|  | ||||
| #define BOOST_UTILITY_INPLACE_FACTORY_04APR2007_HPP | ||||
| #else | ||||
| #define N BOOST_PP_ITERATION() | ||||
|  | ||||
| #if N | ||||
| template< BOOST_PP_ENUM_PARAMS(N, class A) > | ||||
| #endif | ||||
| class BOOST_PP_CAT(in_place_factory,N) | ||||
|   :  | ||||
|   public in_place_factory_base | ||||
| { | ||||
| public: | ||||
|  | ||||
|   explicit BOOST_PP_CAT(in_place_factory,N) | ||||
|       ( BOOST_PP_ENUM_BINARY_PARAMS(N,A,const& a) ) | ||||
| #if N > 0 | ||||
|     : BOOST_PP_ENUM(N, BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT, _) | ||||
| #endif | ||||
|   {} | ||||
|  | ||||
|   template<class T> | ||||
|   void* apply(void* address | ||||
|       BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE(T)) const | ||||
|   { | ||||
|     return new(address) T( BOOST_PP_ENUM_PARAMS(N, m_a) ); | ||||
|   } | ||||
|  | ||||
|   template<class T> | ||||
|   void* apply(void* address, std::size_t n | ||||
|       BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE(T)) const | ||||
|   { | ||||
|     for(char* next = address = this->BOOST_NESTED_TEMPLATE apply<T>(address); | ||||
|         !! --n;) | ||||
|       this->BOOST_NESTED_TEMPLATE apply<T>(next = next+sizeof(T)); | ||||
|     return address;  | ||||
|   } | ||||
|  | ||||
|   BOOST_PP_REPEAT(N, BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL, _) | ||||
| }; | ||||
|  | ||||
| #if N > 0 | ||||
| template< BOOST_PP_ENUM_PARAMS(N, class A) > | ||||
| inline BOOST_PP_CAT(in_place_factory,N)< BOOST_PP_ENUM_PARAMS(N, A) > | ||||
| in_place( BOOST_PP_ENUM_BINARY_PARAMS(N, A, const& a) ) | ||||
| { | ||||
|   return BOOST_PP_CAT(in_place_factory,N)< BOOST_PP_ENUM_PARAMS(N, A) > | ||||
|       ( BOOST_PP_ENUM_PARAMS(N, a) ); | ||||
| } | ||||
| #else | ||||
| inline in_place_factory0 in_place() | ||||
| { | ||||
|   return in_place_factory0(); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #undef N | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -10,18 +10,11 @@ | ||||
| #define BOOST_RESULT_OF_HPP | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/preprocessor/iteration/iterate.hpp>  | ||||
| #include <boost/preprocessor/punctuation/comma_if.hpp>  | ||||
| #include <boost/preprocessor/repetition/enum_params.hpp>  | ||||
| #include <boost/preprocessor/repetition/enum_shifted_params.hpp>  | ||||
| #include <boost/type_traits/ice.hpp> | ||||
| #include <boost/type.hpp> | ||||
| #include <boost/preprocessor.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
| #include <boost/mpl/has_xxx.hpp> | ||||
| #include <boost/mpl/if.hpp> | ||||
| #include <boost/mpl/bool.hpp> | ||||
| #include <boost/mpl/or.hpp> | ||||
| #include <boost/type_traits/is_pointer.hpp> | ||||
| #include <boost/type_traits/is_member_function_pointer.hpp> | ||||
| #include <boost/type_traits/remove_cv.hpp> | ||||
|  | ||||
| #ifndef BOOST_RESULT_OF_NUM_ARGS | ||||
| #  define BOOST_RESULT_OF_NUM_ARGS 10 | ||||
| @@ -36,54 +29,28 @@ namespace detail { | ||||
|  | ||||
| BOOST_MPL_HAS_XXX_TRAIT_DEF(result_type) | ||||
|  | ||||
| template<typename F, typename FArgs, bool HasResultType> struct result_of_impl; | ||||
| template<typename F> struct result_of_decltype_impl; | ||||
|  | ||||
| template<typename F> | ||||
| struct result_of_void_impl | ||||
| { | ||||
|   typedef void type; | ||||
| }; | ||||
|  | ||||
| template<typename R> | ||||
| struct result_of_void_impl<R (*)(void)> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
|  | ||||
| template<typename R> | ||||
| struct result_of_void_impl<R (&)(void)> | ||||
| { | ||||
|   typedef R type; | ||||
| }; | ||||
|  | ||||
| // Determine the return type of a function pointer or pointer to member. | ||||
| template<typename F, typename FArgs> | ||||
| struct result_of_pointer | ||||
|   : result_of_impl<typename remove_cv<F>::type, FArgs, false> { }; | ||||
| template<typename F, typename FArgs, bool HasResultType> struct get_result_of; | ||||
|  | ||||
| template<typename F, typename FArgs> | ||||
| struct result_of_impl<F, FArgs, true> | ||||
| struct get_result_of<F, FArgs, true> | ||||
| { | ||||
|   typedef typename F::result_type type; | ||||
| }; | ||||
|  | ||||
| template<typename FArgs> | ||||
| struct is_function_with_no_args : mpl::false_ {}; | ||||
| template<typename F, typename FArgs> | ||||
| struct get_result_of<F, FArgs, false> | ||||
| { | ||||
|   typedef typename F::template result<FArgs>::type type; | ||||
| }; | ||||
|  | ||||
| template<typename F> | ||||
| struct is_function_with_no_args<F(void)> : mpl::true_ {}; | ||||
| struct get_result_of<F, F(void), false> | ||||
| { | ||||
|   typedef void type; | ||||
| }; | ||||
|  | ||||
| template<typename F, typename FArgs> | ||||
| 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 | ||||
| {}; | ||||
| struct result_of : get_result_of<F, FArgs, (has_result_type<F>::value)> {}; | ||||
|  | ||||
| } // end namespace detail | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| // Copyright (C) 2003, Fernando Luis Cacciola Carballal. | ||||
| // Copyright (C) 2007, Tobias Schwinger. | ||||
| // | ||||
| // Use, modification, and distribution is subject to the Boost Software | ||||
| // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | ||||
| @@ -10,8 +9,8 @@ | ||||
| // You are welcome to contact the author at: | ||||
| //  fernando_cacciola@hotmail.com | ||||
| // | ||||
| #ifndef BOOST_UTILITY_TYPED_INPLACE_FACTORY_04APR2007_HPP | ||||
| #ifndef BOOST_PP_IS_ITERATING | ||||
| #ifndef BOOST_UTILITY_TYPED_INPLACE_FACTORY_25AGO2003_HPP | ||||
| #define BOOST_UTILITY_TYPED_INPLACE_FACTORY_25AGO2003_HPP | ||||
|  | ||||
| #include <boost/utility/detail/in_place_factory_prefix.hpp> | ||||
|  | ||||
| @@ -19,59 +18,40 @@ namespace boost { | ||||
|  | ||||
| class typed_in_place_factory_base {} ; | ||||
|  | ||||
| #define  BOOST_PP_ITERATION_LIMITS (0, BOOST_MAX_INPLACE_FACTORY_ARITY) | ||||
| #define  BOOST_PP_FILENAME_1 <boost/utility/typed_in_place_factory.hpp> | ||||
| #include BOOST_PP_ITERATE() | ||||
| #define BOOST_DEFINE_TYPED_INPLACE_FACTORY_CLASS(z,n,_) \ | ||||
| template< class T, BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \ | ||||
| class BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) : public typed_in_place_factory_base \ | ||||
| { \ | ||||
| public: \ | ||||
| \ | ||||
|   typedef T value_type ; \ | ||||
| \ | ||||
|   BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A,const& a) ) \ | ||||
|     : \ | ||||
|     BOOST_PP_ENUM( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT, _ ) \ | ||||
|   {} \ | ||||
| \ | ||||
|   void apply ( void* address ) const \ | ||||
|   { \ | ||||
|     new ( address ) T ( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), m_a ) ) ; \ | ||||
|   } \ | ||||
| \ | ||||
|   BOOST_PP_REPEAT( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL, _) \ | ||||
| } ; \ | ||||
| \ | ||||
| template< class T, BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \ | ||||
| BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) < T , BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \ | ||||
| in_place ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A, const& a) ) \ | ||||
| { \ | ||||
|   return BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) < T, BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \ | ||||
|            ( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), a ) ) ; \ | ||||
| } ; \ | ||||
|  | ||||
| BOOST_PP_REPEAT( BOOST_MAX_INPLACE_FACTORY_ARITY, BOOST_DEFINE_TYPED_INPLACE_FACTORY_CLASS, BOOST_PP_EMPTY() ) | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| #include <boost/utility/detail/in_place_factory_suffix.hpp> | ||||
|  | ||||
| #define BOOST_UTILITY_TYPED_INPLACE_FACTORY_04APR2007_HPP | ||||
| #else  | ||||
| #define N BOOST_PP_ITERATION() | ||||
|  | ||||
| template< class T BOOST_PP_ENUM_TRAILING_PARAMS(N,class A) > | ||||
| class BOOST_PP_CAT(typed_in_place_factory,N)  | ||||
|   :  | ||||
|   public typed_in_place_factory_base | ||||
| { | ||||
| public: | ||||
|  | ||||
|   typedef T value_type; | ||||
|  | ||||
|   explicit BOOST_PP_CAT(typed_in_place_factory,N)  | ||||
|       ( BOOST_PP_ENUM_BINARY_PARAMS(N, A, const& a) ) | ||||
| #if N > 0 | ||||
|     : BOOST_PP_ENUM(N, BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT, _) | ||||
| #endif | ||||
|   {} | ||||
|  | ||||
|   void* apply (void* address) const | ||||
|   { | ||||
|     return new(address) T( BOOST_PP_ENUM_PARAMS(N, m_a) ); | ||||
|   } | ||||
|  | ||||
|   void* apply (void* address, std::size_t n) const | ||||
|   { | ||||
|     for(void* next = address = this->apply(address); !! --n;) | ||||
|       this->apply(next = static_cast<char *>(next) + sizeof(T)); | ||||
|     return address;  | ||||
|   } | ||||
|  | ||||
|   BOOST_PP_REPEAT(N, BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL, _) | ||||
| }; | ||||
|  | ||||
| template< class T BOOST_PP_ENUM_TRAILING_PARAMS(N, class A) > | ||||
| inline BOOST_PP_CAT(typed_in_place_factory,N)< | ||||
|     T BOOST_PP_ENUM_TRAILING_PARAMS(N, A) > | ||||
| in_place( BOOST_PP_ENUM_BINARY_PARAMS(N, A, const& a) ) | ||||
| { | ||||
|   return BOOST_PP_CAT(typed_in_place_factory,N)<  | ||||
|       T BOOST_PP_ENUM_TRAILING_PARAMS(N, A) >( BOOST_PP_ENUM_PARAMS(N, a) ); | ||||
| } | ||||
|  | ||||
| #undef N | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -1,110 +1,63 @@ | ||||
| // (C) 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 | ||||
| // 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 | ||||
| // | ||||
| #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/type_traits/cv_traits.hpp> | ||||
| #include <boost/type_traits/alignment_of.hpp> | ||||
| #include <boost/swap.hpp> | ||||
| #include <cstring> | ||||
| #include <new> | ||||
| #include "boost/detail/select_type.hpp" | ||||
| #include "boost/type_traits/cv_traits.hpp" | ||||
|  | ||||
| namespace boost { | ||||
|  | ||||
| namespace vinit_detail { | ||||
|  | ||||
| template<class T> | ||||
| class value_initialized | ||||
| class const_T_base | ||||
| { | ||||
|   private : | ||||
|     struct wrapper | ||||
|     { | ||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x592)) | ||||
|       typename | ||||
| #endif  | ||||
|       remove_const<T>::type data; | ||||
|     }; | ||||
|   protected : | ||||
|  | ||||
|     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: | ||||
| // "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. | ||||
| #pragma warning(disable: 4345) | ||||
| #endif | ||||
| #endif | ||||
|       new (wrapper_address()) wrapper(); | ||||
| #ifdef BOOST_MSVC | ||||
| #pragma warning(pop) | ||||
| #endif | ||||
|     } | ||||
|  | ||||
|     value_initialized(value_initialized const & arg) | ||||
|     { | ||||
|       new (wrapper_address()) wrapper( static_cast<wrapper const &>(*(arg.wrapper_address()))); | ||||
|     } | ||||
|  | ||||
|     value_initialized & operator=(value_initialized const & arg) | ||||
|     { | ||||
|       // 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; | ||||
|     } | ||||
|  | ||||
|     ~value_initialized() | ||||
|     { | ||||
|       wrapper_address()->wrapper::~wrapper(); | ||||
|     } | ||||
|  | ||||
|     T& data() const | ||||
|     { | ||||
|       return wrapper_address()->data; | ||||
|     } | ||||
|  | ||||
|     void swap(value_initialized & arg) | ||||
|     { | ||||
|       ::boost::swap( this->data(), arg.data() ); | ||||
|     } | ||||
|  | ||||
|     operator T&() const { return this->data(); } | ||||
|    const_T_base() : x() {} | ||||
|  | ||||
|    T x ; | ||||
| } ; | ||||
|  | ||||
| template<class T> | ||||
| struct non_const_T_base | ||||
| { | ||||
|   protected : | ||||
|  | ||||
|    non_const_T_base() : x() {} | ||||
|  | ||||
|    mutable T x ; | ||||
| } ; | ||||
|  | ||||
| template<class T> | ||||
| struct select_base | ||||
| { | ||||
|   typedef typename | ||||
|     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->x ; } | ||||
|  | ||||
|     T& data() const { return this->x ; } | ||||
|  | ||||
| } ; | ||||
|  | ||||
| template<class T> | ||||
| T const& get ( value_initialized<T> const& x ) | ||||
| @@ -117,27 +70,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 | ||||
|  | ||||
|   | ||||
							
								
								
									
										16
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								index.html
									
									
									
									
									
								
							| @@ -19,24 +19,16 @@ | ||||
| 				<a href="call_traits.htm">call_traits</a><br> | ||||
| 				<a href="checked_delete.html">checked_delete</a><br> | ||||
| 				<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="swap.html">swap</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>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> | ||||
| 		<p>Revised  | ||||
| 			<!--webbot bot="Timestamp" S-Type="EDITED" S-Format="%d %B, %Y" startspan -->07 November, 2006<!--webbot bot="Timestamp" endspan i-checksum="39368" --></p> | ||||
| 		</body> | ||||
| 			<!--webbot bot="Timestamp" S-Type="EDITED" S-Format="%d %B, %Y" startspan -->01 September, 2003<!--webbot bot="Timestamp" endspan i-checksum="38582" --></p> | ||||
| 		<p> </p> | ||||
| 	</body> | ||||
| </html> | ||||
|   | ||||
| @@ -1 +0,0 @@ | ||||
| boost_module(utility DEPENDS iterator exception detail ) | ||||
| @@ -60,19 +60,11 @@ struct complement | ||||
|         // indirection through complement_traits_aux necessary to keep MSVC happy | ||||
|         typedef complement_traits_aux<Number, size - 1> prev; | ||||
|      public: | ||||
| #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ == 0 && __GNUC_PATCHLEVEL__ == 2 | ||||
|       // GCC 4.0.2 ICEs on these C-style casts | ||||
|         BOOST_STATIC_CONSTANT(Number, max = | ||||
|                             Number((prev::max) << CHAR_BIT) | ||||
|                             + Number(UCHAR_MAX)); | ||||
|         BOOST_STATIC_CONSTANT(Number, min = Number((prev::min) << CHAR_BIT)); | ||||
| #else | ||||
|         BOOST_STATIC_CONSTANT(Number, max = | ||||
|                             Number(Number(prev::max) << CHAR_BIT) | ||||
|                             + Number(UCHAR_MAX)); | ||||
|          | ||||
|         BOOST_STATIC_CONSTANT(Number, min = Number(Number(prev::min) << CHAR_BIT)); | ||||
| #endif | ||||
|     | ||||
|     }; | ||||
| }; | ||||
|  | ||||
| @@ -229,16 +221,10 @@ void test_aux(unsigned_tag, Number*) | ||||
|         (sizeof(Number) < sizeof(boost::intmax_t)) | ||||
|         | (boost::is_same<difference_type, boost::intmax_t>::value)); | ||||
|  | ||||
| #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ == 0 && __GNUC_PATCHLEVEL__ == 2 | ||||
|     // GCC 4.0.2 ICEs on this C-style cases | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::min) == Number(0)); | ||||
| #else | ||||
|     // Force casting to Number here to work around the fact that it's an enum on MSVC | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) == Number(0)); | ||||
| #endif | ||||
|  | ||||
|      | ||||
|     const Number max = complement_traits<Number>::max; | ||||
|     const Number min = complement_traits<Number>::min; | ||||
|      | ||||
| @@ -322,15 +308,10 @@ void test_aux(signed_tag, Number*) | ||||
|         (sizeof(Number) < sizeof(boost::intmax_t)) | ||||
|         | (boost::is_same<difference_type, Number>::value)); | ||||
|  | ||||
| #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ == 0 && __GNUC_PATCHLEVEL__ == 2 | ||||
|     // GCC 4.0.2 ICEs on this cast | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::min) < Number(0)); | ||||
| #else | ||||
|     // Force casting to Number here to work around the fact that it's an enum on MSVC | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) < Number(0)); | ||||
| #endif     | ||||
|      | ||||
|     const Number max = complement_traits<Number>::max; | ||||
|     const Number min = complement_traits<Number>::min; | ||||
|      | ||||
|   | ||||
| @@ -1420,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> | ||||
| @@ -1439,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> | ||||
| @@ -1464,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> | ||||
| @@ -1481,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, | ||||
| @@ -1498,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= | ||||
| @@ -1585,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> | ||||
|  | ||||
| @@ -2030,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= | ||||
| @@ -2051,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 | ||||
| @@ -2127,10 +2119,10 @@ 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-2008.</p> | ||||
|     <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 | ||||
|   | ||||
| @@ -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> | ||||
| @@ -580,7 +536,7 @@ namespace | ||||
| // inherited operator templates at the moment it must, so the following | ||||
| // explicit instantiations force it to do that. | ||||
|  | ||||
| #if defined(BOOST_MSVC) && (_MSC_VER < 1300) | ||||
| #if defined(BOOST_MSVC) && (_MSC_VER <= 1200) | ||||
| template Wrapped1<int>; | ||||
| template Wrapped1<long>; | ||||
| template Wrapped1<unsigned int>; | ||||
| @@ -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"; | ||||
|  | ||||
|   | ||||
							
								
								
									
										43
									
								
								ref_test.cpp
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								ref_test.cpp
									
									
									
									
									
								
							| @@ -68,54 +68,11 @@ struct ref_wrapper | ||||
|     } | ||||
| }; | ||||
|  | ||||
| struct copy_counter { | ||||
|   static int count_; | ||||
|   copy_counter(copy_counter const& other) { | ||||
|     ++count_; | ||||
|   } | ||||
|   copy_counter() {} | ||||
|   static void reset() { count_ = 0; } | ||||
|   static int count() { return copy_counter::count_;  } | ||||
| }; | ||||
|  | ||||
| int copy_counter::count_ = 0; | ||||
|  | ||||
| } // namespace unnamed | ||||
|  | ||||
| template <class T> | ||||
| void do_unwrap(T t) { | ||||
|  | ||||
|   /* typename unwrap_reference<T>::type& lt = */ | ||||
|   unwrap_ref(t); | ||||
|  | ||||
| } | ||||
|  | ||||
| void unwrap_test() { | ||||
|  | ||||
|   int i = 3; | ||||
|   const int ci = 2; | ||||
|  | ||||
|   do_unwrap(i); | ||||
|   do_unwrap(ci); | ||||
|   do_unwrap(ref(i)); | ||||
|   do_unwrap(cref(ci)); | ||||
|   do_unwrap(ref(ci)); | ||||
|  | ||||
|   copy_counter cc; | ||||
|   BOOST_CHECK(cc.count() == 0); | ||||
|  | ||||
|   do_unwrap(cc); | ||||
|   do_unwrap(ref(cc)); | ||||
|   do_unwrap(cref(cc)); | ||||
|  | ||||
|   BOOST_CHECK(cc.count() == 1); | ||||
|   BOOST_CHECK(unwrap_ref(ref(cc)).count() == 1);  | ||||
| } | ||||
|  | ||||
| int test_main(int, char * []) | ||||
| { | ||||
|     ref_wrapper<int>::test(1); | ||||
|     ref_wrapper<int const>::test(1); | ||||
|     unwrap_test(); | ||||
|     return 0; | ||||
| } | ||||
|   | ||||
| @@ -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> | ||||
|  | ||||
|   | ||||
							
								
								
									
										1
									
								
								sublibs
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								sublibs
									
									
									
									
									
								
							| @@ -1 +0,0 @@ | ||||
| The existance of this file tells the regression reporting programs that the directory contains sub-directories which are libraries. | ||||
| @@ -1,33 +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 swap_arrays.cpp ../../../test/build//boost_test_exec_monitor/<link>static                    ] | ||||
|     ; | ||||
| @@ -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,37 +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*[]) | ||||
| { | ||||
|   boost::swap_test_class object1; | ||||
|   boost::swap_test_class object2; | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   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,37 +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*[]) | ||||
| { | ||||
|   boost::swap_test_class object1; | ||||
|   boost::swap_test_class object2; | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(boost::swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(boost::swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,56 +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*[]) | ||||
| { | ||||
|   other::swap_test_class object1; | ||||
|   other::swap_test_class object2; | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,31 +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*[]) | ||||
| { | ||||
|   swap_test_class object1; | ||||
|   swap_test_class object2; | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,37 +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*[]) | ||||
| { | ||||
|   other::swap_test_class object1; | ||||
|   other::swap_test_class object2; | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::swap_count(),1); | ||||
|   BOOST_CHECK_EQUAL(other::swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,36 +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*[]) | ||||
| { | ||||
|   swap_test_class object1; | ||||
|   swap_test_class object2; | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   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,54 +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; | ||||
|  | ||||
|   vector_type object1(initial_size1); | ||||
|   vector_type object2(initial_size2); | ||||
|  | ||||
|   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_EQUAL(swap_test_class_type::swap_count(),0); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class_type::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,47 +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; | ||||
|  | ||||
|   vector_type object1(initial_size1); | ||||
|   vector_type object2(initial_size2); | ||||
|  | ||||
|   swap_test_class::reset(); | ||||
|    | ||||
|   boost::swap(object1,object2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(object1.size(),initial_size2); | ||||
|   BOOST_CHECK_EQUAL(object2.size(),initial_size1); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(),0); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,54 +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; | ||||
|  | ||||
|   vector_type object1(initial_size1); | ||||
|   vector_type object2(initial_size2); | ||||
|  | ||||
|   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_EQUAL(swap_test_class_type::swap_count(),0); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class_type::copy_count(),0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,59 +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) | ||||
|  | ||||
| #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 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 dimension = 7; | ||||
|  | ||||
|   swap_test_class array1[dimension]; | ||||
|   swap_test_class array2[dimension]; | ||||
|   boost::swap(array1, array2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(), dimension); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(), 0); | ||||
|  | ||||
|   swap_test_class::reset(); | ||||
|  | ||||
|   const std::size_t firstDimension = 3; | ||||
|   const std::size_t secondDimension = 4; | ||||
|  | ||||
|   swap_test_class two_d_array1[firstDimension][secondDimension]; | ||||
|   swap_test_class two_d_array2[firstDimension][secondDimension]; | ||||
|   boost::swap(two_d_array1, two_d_array2); | ||||
|  | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::swap_count(), firstDimension*secondDimension); | ||||
|   BOOST_CHECK_EQUAL(swap_test_class::copy_count(), 0); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| @@ -1,84 +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 | ||||
| { | ||||
| public: | ||||
|   swap_test_class() | ||||
|   { | ||||
|     ++constructCount(); | ||||
|   } | ||||
|  | ||||
|   ~swap_test_class() | ||||
|   { | ||||
|     ++destructCount(); | ||||
|   } | ||||
|  | ||||
|   swap_test_class(const swap_test_class&) | ||||
|   { | ||||
|     ++copyCount(); | ||||
|     ++destructCount(); | ||||
|   } | ||||
|  | ||||
|   swap_test_class& operator=(const swap_test_class&) | ||||
|   { | ||||
|     ++copyCount(); | ||||
|     return *this; | ||||
|   } | ||||
|  | ||||
|   void swap(swap_test_class& other) | ||||
|   { | ||||
|     ++swapCount(); | ||||
|   } | ||||
|  | ||||
|  | ||||
|   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; | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| #endif | ||||
| @@ -1,36 +0,0 @@ | ||||
| boost_test_run(addressof_test ../addressof_test.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) | ||||
							
								
								
									
										43
									
								
								test/Jamfile
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										43
									
								
								test/Jamfile
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| # 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/ | ||||
|  | ||||
| subproject libs/utility/test ; | ||||
|  | ||||
| # bring in rules for testing | ||||
| import testing ; | ||||
|  | ||||
| # Make tests run by default. | ||||
| DEPENDS all : test ; | ||||
|  | ||||
| local test_monitor = <lib>@boost/libs/test/build/boost_test_exec_monitor ; | ||||
|  | ||||
| # Please keep the tests ordered by filename | ||||
| test-suite utility | ||||
|     : | ||||
|         [ run ../addressof_test.cpp ] | ||||
|         [ run ../assert_test.cpp ] | ||||
|         [ run ../base_from_member_test.cpp ] | ||||
|         [ run ../binary_search_test.cpp ] | ||||
|         [ run ../call_traits_test.cpp : -u ] | ||||
|         [ compile-fail ../checked_delete_test.cpp ] | ||||
|         [ run ../compressed_pair_test.cpp $(test_monitor) : -u ] | ||||
|         [ run ../current_function_test.cpp : : : <test-info>always_show_run_output ] | ||||
|         [ run ../iterators_test.cpp $(test_monitor) ] | ||||
|         [ run next_prior_test.cpp $(test_monitor) ] | ||||
|         [ compile-fail ../noncopyable_test.cpp ] | ||||
|         [ run ../numeric_traits_test.cpp ] | ||||
|         [ run ../operators_test.cpp $(test_monitor) ] | ||||
|         [ compile ../ref_ct_test.cpp  ] | ||||
|         [ run ../ref_test.cpp $(test_monitor) ] | ||||
|         [ compile result_of_test.cpp ] | ||||
|         [ run ../shared_iterator_test.cpp ] | ||||
|         [ run ../value_init_test.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail1.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail2.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail3.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/ | ||||
|  | ||||
| @@ -15,24 +16,21 @@ test-suite utility | ||||
|         [ 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 ] | ||||
|         [ run ../compressed_pair_test.cpp ../../test/build//boost_test_exec_monitor : -u ] | ||||
|         [ run ../current_function_test.cpp : : : <test-info>always_show_run_output ] | ||||
|         [ run ../iterators_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|         [ run next_prior_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|         [ run ../iterators_test.cpp ../../test/build//boost_test_exec_monitor ] | ||||
|         [ run next_prior_test.cpp ../../test/build//boost_test_exec_monitor ] | ||||
|         [ compile-fail ../noncopyable_test.cpp ] | ||||
|         [ run ../numeric_traits_test.cpp ] | ||||
|         [ run ../operators_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|         [ run ../operators_test.cpp ../../test/build//boost_test_exec_monitor ] | ||||
|         [ compile ../ref_ct_test.cpp  ] | ||||
|         [ run ../ref_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|         [ run ../ref_test.cpp ../../test/build//boost_test_exec_monitor ] | ||||
|         [ compile result_of_test.cpp ] | ||||
|         [ run ../shared_iterator_test.cpp ] | ||||
|         [ run ../value_init_test.cpp ] | ||||
|         [ 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
									
								
							| @@ -11,101 +11,17 @@ | ||||
| #include <boost/static_assert.hpp> | ||||
| #include <boost/type_traits/is_same.hpp> | ||||
|  | ||||
| struct int_result_type | ||||
| { | ||||
|   typedef int result_type; | ||||
|   result_type operator()(float); | ||||
| }; | ||||
| struct int_result_type { typedef int result_type; }; | ||||
|  | ||||
| struct int_result_of | ||||
| { | ||||
|   template<typename F> struct result { typedef int type; }; | ||||
|   result<int_result_of(double)>::type operator()(double); | ||||
|   result<const int_result_of(double)>::type operator()(double) const; | ||||
|   result<int_result_of()>::type operator()(); | ||||
|   result<volatile int_result_of()>::type operator()() volatile; | ||||
| }; | ||||
|  | ||||
| struct int_result_type_and_float_result_of_and_char_return | ||||
| struct int_result_type_and_float_result_of | ||||
| { | ||||
|   typedef int result_type; | ||||
|   template<typename F> struct result { typedef float type; }; | ||||
|   char operator()(char); | ||||
| }; | ||||
|  | ||||
| template<typename T> | ||||
| struct int_result_type_template | ||||
| { | ||||
|   typedef int result_type; | ||||
|   result_type operator()(float); | ||||
| }; | ||||
|  | ||||
| template<typename T> | ||||
| struct int_result_of_template | ||||
| { | ||||
|   template<typename F> struct result; | ||||
|   template<typename This, typename That> struct result<This(That)> { typedef int type; }; | ||||
|   typename result<int_result_of_template<T>(double)>::type operator()(double); | ||||
|   typename result<const int_result_of_template<T>(double)>::type operator()(double) const; | ||||
|   typename result<int_result_of_template<T>(double)>::type operator()(); | ||||
|   typename result<volatile int_result_of_template<T>(double)>::type operator()() volatile; | ||||
| }; | ||||
|  | ||||
| template<typename T> | ||||
| struct int_result_type_and_float_result_of_and_char_return_template | ||||
| { | ||||
|   typedef int result_type; | ||||
|   template<typename F> struct result; | ||||
|   template<typename This, typename That> struct result<This(That)> { typedef float type; }; | ||||
|   char operator()(char); | ||||
| }; | ||||
|  | ||||
| struct result_of_member_function_template | ||||
| { | ||||
|   template<typename F> struct result; | ||||
|  | ||||
|   template<typename This, typename That> struct result<This(That)> { typedef That type; }; | ||||
|   template<class T> typename result<result_of_member_function_template(T)>::type operator()(T); | ||||
|  | ||||
|   template<typename This, typename That> struct result<const This(That)> { typedef const That type; }; | ||||
|   template<class T> typename result<const result_of_member_function_template(T)>::type operator()(T) const; | ||||
|  | ||||
|   template<typename This, typename That> struct result<volatile This(That)> { typedef volatile That type; }; | ||||
|   template<class T> typename result<volatile result_of_member_function_template(T)>::type operator()(T) volatile; | ||||
|  | ||||
|   template<typename This, typename That> struct result<const volatile This(That)> { typedef const volatile That type; }; | ||||
|   template<class T> typename result<const volatile result_of_member_function_template(T)>::type operator()(T) const volatile; | ||||
|  | ||||
|   template<typename This, typename That> struct result<This(That &, That)> { typedef That & type; }; | ||||
|   template<class T> typename result<result_of_member_function_template(T &, T)>::type operator()(T &, T); | ||||
|  | ||||
|   template<typename This, typename That> struct result<This(That const &, That)> { typedef That const & type; }; | ||||
|   template<class T> typename result<result_of_member_function_template(T const &, T)>::type operator()(T const &, T); | ||||
|  | ||||
|   template<typename This, typename That> struct result<This(That volatile &, That)> { typedef That volatile & type; }; | ||||
|   template<class T> typename result<result_of_member_function_template(T volatile &, T)>::type operator()(T volatile &, T); | ||||
|  | ||||
|   template<typename This, typename That> struct result<This(That const volatile &, That)> { typedef That const volatile & type; }; | ||||
|   template<class T> typename result<result_of_member_function_template(T const volatile &, T)>::type operator()(T const volatile &, T); | ||||
| }; | ||||
|  | ||||
| struct no_result_type_or_result_of | ||||
| { | ||||
|   int operator()(double); | ||||
|   short operator()(double) const; | ||||
|   unsigned int operator()(); | ||||
|   unsigned short operator()() volatile; | ||||
|   const unsigned short operator()() const volatile; | ||||
| }; | ||||
|  | ||||
| template<typename T> | ||||
| struct no_result_type_or_result_of_template | ||||
| { | ||||
|   int operator()(double); | ||||
|   short operator()(double) const; | ||||
|   unsigned int operator()(); | ||||
|   unsigned short operator()() volatile; | ||||
|   const unsigned short operator()() const volatile; | ||||
| }; | ||||
|  | ||||
| struct X {}; | ||||
| @@ -116,83 +32,22 @@ int main() | ||||
|  | ||||
|   typedef int (*func_ptr)(float, double); | ||||
|   typedef int (&func_ref)(float, double); | ||||
|   typedef int (*func_ptr_0)(); | ||||
|   typedef int (&func_ref_0)(); | ||||
|   typedef int (X::*mem_func_ptr)(float); | ||||
|   typedef int (X::*mem_func_ptr_c)(float) const; | ||||
|   typedef int (X::*mem_func_ptr_v)(float) volatile; | ||||
|   typedef int (X::*mem_func_ptr_cv)(float) const volatile; | ||||
|   typedef int (X::*mem_func_ptr_0)(); | ||||
|  | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_type(float)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of(double)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const int_result_of(double)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_template<void>(float)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of_template<void>(double)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const int_result_of_template<void>(double)>::type, int>::value)); | ||||
|  | ||||
|   // Prior to decltype, result_of could not deduce the return type | ||||
|   // nullary function objects unless they exposed a result_type. | ||||
| #if defined(BOOST_HAS_DECLTYPE) | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of(void)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile int_result_of(void)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of_template<void>(void)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile int_result_of_template<void>(void)>::type, int>::value)); | ||||
| #else | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of(void)>::type, void>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const int_result_of(double)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile int_result_of(void)>::type, void>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of_template<void>(void)>::type, void>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile int_result_of_template<void>(void)>::type, void>::value)); | ||||
| #endif | ||||
|  | ||||
|   // Prior to decltype, result_of ignored a nested result<> if | ||||
|   // result_type was defined. After decltype, result_of deduces the | ||||
|   // actual return type of the function object, ignoring both | ||||
|   // result<> and result_type. | ||||
| #if defined(BOOST_HAS_DECLTYPE) | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of_and_char_return(char)>::type, char>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of_and_char_return_template<void>(char)>::type, char>::value)); | ||||
| #else | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of_and_char_return(char)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of_and_char_return_template<void>(char)>::type, int>::value)); | ||||
| #endif | ||||
|  | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of(char)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<func_ptr(char, float)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<func_ref(char, float)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<func_ptr_0()>::type, int>::value));  | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<func_ref_0()>::type, int>::value));  | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr(X,char)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_c(X,char)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_v(X,char)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_cv(X,char)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_0(X)>::type, int>::value));  | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<func_ptr(void)>::type, int>::value)); | ||||
|  | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<result_of_member_function_template(double)>::type, double>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const result_of_member_function_template(double)>::type, const double>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile result_of_member_function_template(double)>::type, volatile double>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const volatile result_of_member_function_template(double)>::type, const volatile double>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<result_of_member_function_template(int &, int)>::type, int &>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<result_of_member_function_template(int const &, int)>::type, int const &>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<result_of_member_function_template(int volatile &, int)>::type, int volatile &>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<result_of_member_function_template(int const volatile &, int)>::type, int const volatile &>::value)); | ||||
|  | ||||
|   typedef int (*pf_t)(int); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<pf_t(int)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<pf_t const(int)>::type,int>::value)); | ||||
|  | ||||
| #if defined(BOOST_HAS_DECLTYPE) | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<no_result_type_or_result_of(double)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<no_result_type_or_result_of(void)>::type, unsigned int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const no_result_type_or_result_of(double)>::type, short>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile no_result_type_or_result_of(void)>::type, unsigned short>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const volatile no_result_type_or_result_of(void)>::type, const unsigned short>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<no_result_type_or_result_of_template<void>(double)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<no_result_type_or_result_of_template<void>(void)>::type, unsigned int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const no_result_type_or_result_of_template<void>(double)>::type, short>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile no_result_type_or_result_of_template<void>(void)>::type, unsigned short>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const volatile no_result_type_or_result_of_template<void>(void)>::type, const unsigned short>::value)); | ||||
| #endif | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|   | ||||
| @@ -7,9 +7,10 @@ | ||||
| 	<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 width="277"> | ||||
| 					<img src="../../boost.png" alt="boost.png (6897 bytes)" width="277" height="86"> | ||||
| 				</td> | ||||
| 				<td align="center"> | ||||
| 				<td align="middle"> | ||||
| 					<h1>throw_exception.hpp</h1> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| @@ -51,8 +52,9 @@ template<class E> void throw_exception(E const & e) | ||||
| } | ||||
| </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> | ||||
| 			<small>Copyright <20> 2002 by Peter Dimov. 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.</small></p> | ||||
| 	</body> | ||||
| </html> | ||||
|   | ||||
							
								
								
									
										85
									
								
								utility.htm
									
									
									
									
									
								
							
							
						
						
									
										85
									
								
								utility.htm
									
									
									
									
									
								
							| @@ -23,9 +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> | ||||
| 			Function templates <a name="checked_delete">checked_delete</a>() and  | ||||
| @@ -70,7 +67,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 +88,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 ... | ||||
| @@ -154,22 +151,20 @@ void f() { | ||||
|                 ...,t<em>N</em>)</code>. The implementation permits | ||||
|                 the type <code>F</code> to be a function pointer, | ||||
|                 function reference, member function pointer, or class | ||||
|                 type.</p> <p>If your compiler does not support | ||||
|                 <code>decltype</code>, then when <code>F</code> is a | ||||
|                 class type with a member type <code>result_type</code>, | ||||
|                 type. When <code>F</code> is a class type with a | ||||
|                 member type <code>result_type</code>, | ||||
|                 <code>result_of<F(T1, T2, ..., | ||||
|                 T<em>N</em>)></code> is | ||||
|                 <code>F::result_type</code>. When <code>F</code> | ||||
|                 does not contain <code>result_type</code>,  | ||||
|                 <code>F::result_type</code>. Otherwise, | ||||
|                 <code>result_of<F(T1, T2, ..., | ||||
|                 T<em>N</em>)></code> is <code>F::result<F(T1, | ||||
|                 T2, ..., T<em>N</em>)>::type</code> when | ||||
|                 <code><em>N</em> > 0</code> or <code>void</code> | ||||
|                 when <code><em>N</em> = 0</code>. For additional | ||||
|                 information about <code>result_of</code>, see the | ||||
|                 C++ Library Technical Report, <a | ||||
|                 href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2005/n1836.pdf">N1836</a>, | ||||
|                 or, for motivation and design rationale, the <code>result_of</code> <a | ||||
|                 current draft of the C++ Library TR, <a | ||||
|                 href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2004/n1647.pdf">N1647</a>, | ||||
|                 or the <code>result_of</code> <a | ||||
|                 href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1454.html">proposal</a>.</p> | ||||
|  | ||||
|                 <p>Class template <code>result_of</code> resides in | ||||
| @@ -185,68 +180,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 << ')' ; } | ||||
| @@ -65,194 +60,12 @@ struct NonPOD : NonPODBase | ||||
|   std::string id ; | ||||
| } ; | ||||
|  | ||||
| // | ||||
| // 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 | ||||
| { | ||||
|   float f; | ||||
|   char  c; | ||||
|   int   i; | ||||
| }; | ||||
|  | ||||
| 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 +77,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 +86,14 @@ 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") ) ) ) ; | ||||
|  | ||||
|   NonPOD NonPOD_object( std::string("NonPOD_object") ); | ||||
|   BOOST_CHECK ( 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( 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") ) ) ; | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -370,3 +102,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