mirror of
				https://github.com/boostorg/utility.git
				synced 2025-10-23 05:21:40 +02:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			svn-branch
			...
			boost-1.30
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | bf30692a73 | ||
|  | dc294f7225 | ||
|  | 3dffb91af6 | 
							
								
								
									
										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="../../c++boost.gif"  | ||||||
|  |      ALT="C++ Boost" width="277" height="86">  | ||||||
|  | <!--end header--> | ||||||
|  | <BR Clear> | ||||||
|  | <H1>Assignable</H1> | ||||||
|  |  | ||||||
| <html> | <h3>Description</h3> | ||||||
| <head> | A type is Assignable if it is possible to assign one object of the type | ||||||
|   <meta http-equiv="Content-Language" content="en-us"> | to another object of that type. | ||||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> |  | ||||||
|  |  | ||||||
|   <title>Assignable</title> |  | ||||||
| </head> |  | ||||||
|  |  | ||||||
| <body bgcolor="#FFFFFF" link="#0000EE" text="#000000" vlink="#551A8B" alink= | <h3>Notation</h3> | ||||||
| "#FF0000"> | <Table> | ||||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | <TR> | ||||||
|   "86"><br clear="none"> | <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 | </table> | ||||||
|   to another object of that type.</p> | <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> | </table> | ||||||
|     </tr> | <h3>Models</h3> | ||||||
|  |  | ||||||
|     <tr> | <UL> | ||||||
|       <td valign="top"><tt>t</tt></td> | <LI><tt>int</tt> | ||||||
|  | <LI><tt>std::pair</tt> | ||||||
|  | </UL> | ||||||
|  |  | ||||||
|       <td valign="top">is an object of type <tt>T</tt></td> | <h3>See also</h3> | ||||||
|     </tr> | <a href="http://www.sgi.com/tech/stl/DefaultConstructible.html">DefaultConstructible</A> | ||||||
|  | and  | ||||||
|  | <A href="./CopyConstructible.html">CopyConstructible</A> | ||||||
|  |  | ||||||
|     <tr> | <br> | ||||||
|       <td valign="top"><tt>u</tt></td> | <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 | </BODY> | ||||||
|       T</tt></td> | </HTML>  | ||||||
|     </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= |  | ||||||
|   "../../doc/images/valid-html401.png" 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> |  | ||||||
|   | |||||||
							
								
								
									
										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="../../c++boost.gif"  | ||||||
|  |      ALT="C++ Boost" width="277" height="86">  | ||||||
|  | <!--end header--> | ||||||
|  | <BR Clear> | ||||||
|  | <H1>Copy Constructible</H1> | ||||||
|  |  | ||||||
| <html> | <h3>Description</h3> | ||||||
| <head> | A type is Copy Constructible if it is possible to copy objects of that | ||||||
|   <meta http-equiv="Content-Language" content="en-us"> | type. | ||||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> |  | ||||||
|  |  | ||||||
|   <title>Copy Constructible</title> | <h3>Notation</h3> | ||||||
| </head> | <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= | <TR> | ||||||
| "#FF0000"> | <TD VAlign=top> | ||||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | <tt>t</tt> | ||||||
|   "86"><br clear="none"> | </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> | <TR> | ||||||
|  | <TD VAlign=top> | ||||||
|   <table summary=""> | Copy constructor | ||||||
|     <tr> | </TD> | ||||||
|       <td valign="top"><tt>T</tt></td> | <TD VAlign=top> | ||||||
|  | <pre> | ||||||
|       <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> |  | ||||||
| T(u) | T(u) | ||||||
| </pre> | </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 | ||||||
|     <tr> | </TD> | ||||||
|       <td valign="top">Destructor</td> | <TD VAlign=top> | ||||||
|  | <pre> | ||||||
|       <td valign="top"> |  | ||||||
|         <pre> |  | ||||||
| t.~T() | t.~T() | ||||||
| </pre> | </pre> | ||||||
|       </td> | </TD> | ||||||
|  | <TD VAlign=top> | ||||||
|  | <tt>T</tt> | ||||||
|  | </TD> | ||||||
|  | <TD VAlign=top> | ||||||
|  |   | ||||||
|  | </TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|       <td valign="top"><tt>T</tt></td> | <TR> | ||||||
|  | <TD VAlign=top> | ||||||
|       <td valign="top"> </td> | Address Operator | ||||||
|     </tr> | </TD> | ||||||
|  | <TD VAlign=top> | ||||||
|     <tr> | <pre> | ||||||
|       <td valign="top">Address Operator</td> |  | ||||||
|  |  | ||||||
|       <td valign="top"> |  | ||||||
|         <pre> |  | ||||||
| &t | &t | ||||||
| </pre> | </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> | <TR> | ||||||
|  | <TD VAlign=top> | ||||||
|       <td valign="top">denotes the address of <tt>t</tt></td> | Address Operator | ||||||
|     </tr> | </TD> | ||||||
|  | <TD VAlign=top> | ||||||
|     <tr> | <pre> | ||||||
|       <td valign="top">Address Operator</td> |  | ||||||
|  |  | ||||||
|       <td valign="top"> |  | ||||||
|         <pre> |  | ||||||
| &u | &u | ||||||
| </pre> | </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> | </table> | ||||||
|   </ul> | <h3>Models</h3> | ||||||
|  |  | ||||||
|   <h3>Concept Checking Class</h3> | <UL> | ||||||
|   <pre> | <LI><tt>int</tt> | ||||||
|  | <LI><tt>std::pair</tt> | ||||||
|  | </UL> | ||||||
|  |  | ||||||
|  | <h3>Concept Checking Class</h3> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|   template <class T> |   template <class T> | ||||||
|   struct CopyConstructibleConcept |   struct CopyConstructibleConcept | ||||||
|   { |   { | ||||||
| @@ -153,33 +192,19 @@ t.~T() | |||||||
|   }; |   }; | ||||||
| </pre> | </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 | <br> | ||||||
|   Constructible</a> and <a href="./Assignable.html">Assignable</a><br></p> | <HR> | ||||||
|   <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= | </BODY> | ||||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | </HTML>  | ||||||
|   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> |  | ||||||
|   | |||||||
| @@ -1,210 +1,212 @@ | |||||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | <HTML> | ||||||
|  |  | ||||||
| <html> |  | ||||||
| <!-- | <!-- | ||||||
|   == Copyright (c) 1996-1999 |   -- Copyright (c) Jeremy Siek 2000 | ||||||
|   == Silicon Graphics Computer Systems, Inc. |   -- | ||||||
|   == |   -- Permission to use, copy, modify, distribute and sell this software | ||||||
|   == Permission to use, copy, modify, distribute and sell this software |   -- and its documentation for any purpose is hereby granted without fee, | ||||||
|   == and its documentation for any purpose is hereby granted without fee, |   -- provided that the above copyright notice appears in all copies and | ||||||
|   == provided that the above copyright notice appears in all copies and |   -- that both that copyright notice and this permission notice appear | ||||||
|   == that both that copyright notice and this permission notice appear |   -- in supporting documentation.  Silicon Graphics makes no | ||||||
|   == in supporting documentation.  Silicon Graphics makes no |   -- representations about the suitability of this software for any | ||||||
|   == representations about the suitability of this software for any |   -- purpose.  It is provided "as is" without express or implied warranty. | ||||||
|   == 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) 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="../../c++boost.gif"  | ||||||
|  |      ALT="C++ Boost" width="277" height="86">  | ||||||
|  | <!--end header--> | ||||||
|  | <BR Clear> | ||||||
|  | <H1>LessThanComparable</H1> | ||||||
|  |  | ||||||
| <head> | <h3>Description</h3> | ||||||
|   <meta http-equiv="Content-Language" content="en-us"> | A type is LessThanComparable if it is ordered: it must | ||||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> | 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= | <h3>Refinement of</h3> | ||||||
| "#FF0000"> | <h3>Associated types</h3> | ||||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | <h3>Notation</h3> | ||||||
|   "86"><br clear="none"> | <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 | <h3>Expression semantics</h3> | ||||||
|   compare two objects of that type using <tt>operator<</tt>, and | <Table border> | ||||||
|   <tt>operator<</tt> must be a strict weak ordering relation.</p> | <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> | <br> | ||||||
|     </tr> | <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> | </BODY> | ||||||
|       <td valign="top"><tt>x</tt>, <tt>y</tt>, <tt>z</tt></td> | </HTML>  | ||||||
|  |  | ||||||
|       <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= |  | ||||||
|   "../../doc/images/valid-html401.png" 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> |  | ||||||
|   | |||||||
| @@ -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="../../c++boost.gif"  | ||||||
|  |      ALT="C++ Boost" width="277" height="86">  | ||||||
|  |  | ||||||
| <html> | <BR Clear> | ||||||
| <head> |  | ||||||
|   <meta http-equiv="Content-Language" content="en-us"> |  | ||||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> |  | ||||||
|  |  | ||||||
|   <title>MultiPassInputIterator</title> | <H2> | ||||||
| </head> | <A NAME="concept:MultiPassInputIterator"></A> | ||||||
|  | Multi-Pass Input Iterator | ||||||
|  | </H2> | ||||||
|  |  | ||||||
| <body bgcolor="#FFFFFF" link="#0000EE" text="#000000" vlink="#551A8B" alink= | This concept is a refinement of <a | ||||||
| "#FF0000"> | href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>, | ||||||
|   <img src="../../boost.png" alt="C++ Boost" width="277" height= | adding the requirements that the iterator can be used to make multiple | ||||||
|   "86"><br clear="none"> | 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.hmtl">Forward Iterator</a>. The | ||||||
|  | only difference is that a <a | ||||||
|  | href="http://www.sgi.com/tech/stl/ForwardIterator.hmtl">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= | <h3>Design Notes</h3> | ||||||
|   "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> | 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 | <p> The terms Forward, Bidirectionnal and Random Access are about | ||||||
|   solution. Do you also want to define Multi-Pass Bidirectionnal Iterator and | movabillity and shouldn't be used to mean anything else.  In a | ||||||
|   Multi-Pass Random Access Iterator ? I don't, definitly. It only confuses | completly orthogonal way, iterators can be immutable, mutable, or | ||||||
|   the issue. The problem lies into the existing hierarchy of iterators, which | neither.  Lvalueness of iterators is also orthogonal with | ||||||
|   mixes movabillity, modifiabillity and lvalue-ness, and these are clearly | immutabillity.  With these clean concepts, your Multi-Pass Input Iterator | ||||||
|   independant.</p> | is just called a Forward Iterator. | ||||||
|  |  | ||||||
|   <p>The terms Forward, Bidirectionnal and Random Access are about | <p>                 | ||||||
|   movabillity and shouldn't be used to mean anything else. In a completly | Other translations are:<br> | ||||||
|   orthogonal way, iterators can be immutable, mutable, or neither. Lvalueness | std::Forward Iterator -> ForwardIterator & Lvalue Iterator<br> | ||||||
|   of iterators is also orthogonal with immutabillity. With these clean | std::Bidirectionnal Iterator -> Bidirectionnal Iterator & Lvalue Iterator<br> | ||||||
|   concepts, your Multi-Pass Input Iterator is just called a Forward | std::Random Access Iterator -> Random Access Iterator & Lvalue Iterator<br> | ||||||
|   Iterator.</p> |  | ||||||
|  |  | ||||||
|   <p>Other translations are:<br> | <p> | ||||||
|   std::Forward Iterator -> ForwardIterator & Lvalue Iterator<br> | Note that in practice the only operation not allowed on my  | ||||||
|   std::Bidirectionnal Iterator -> Bidirectionnal Iterator & Lvalue | Forward Iterator which is allowed on std::Forward Iterator is  | ||||||
|   Iterator<br> | <tt>&*it</tt>. I think that <tt>&*</tt> is rarely needed in generic code. | ||||||
|   std::Random Access Iterator -> Random Access Iterator & Lvalue |  | ||||||
|   Iterator<br></p> |  | ||||||
|  |  | ||||||
|   <p>Note that in practice the only operation not allowed on my Forward | <p> | ||||||
|   Iterator which is allowed on std::Forward Iterator is <tt>&*it</tt>. I | reply by Jeremy Siek: | ||||||
|   think that <tt>&*</tt> is rarely needed in generic code.</p> |  | ||||||
|  |  | ||||||
|   <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= | <br> | ||||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" | <HR> | ||||||
|   height="31" width="88"></a></p> | <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  | </BODY> | ||||||
|   <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %B, %Y" startspan -->05 | </HTML>  | ||||||
|   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> |  | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
| </HEAD> | </HEAD> | ||||||
| <BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"  | <BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"  | ||||||
|         ALINK="#ff0000">  |         ALINK="#ff0000">  | ||||||
| <IMG SRC="../../boost.png"  | <IMG SRC="../../c++boost.gif"  | ||||||
|      ALT="C++ Boost" width="277" height="86">  |      ALT="C++ Boost" width="277" height="86">  | ||||||
| <!--end header--> | <!--end header--> | ||||||
| <BR Clear> | <BR Clear> | ||||||
| @@ -97,68 +97,34 @@ But boost::optional<T>, on the other hand, which is also a model of Option | |||||||
| deep-copy and deep-relational semantics.<br> | deep-copy and deep-relational semantics.<br> | ||||||
| If generic code is written for this concept, it is important not to use relational | If generic code is written for this concept, it is important not to use relational | ||||||
| operators directly because the semantics might be different depending on the actual type.<br> | operators directly because the semantics might be different depending on the actual type.<br> | ||||||
| Still, the concept itsef can be used to define <i>deep</i> relational tests that can | Still, the concept itsef can be used to define a <i>deep</i> equality-test that can | ||||||
| be used in generic code with any type which models OptionalPointee:</p> | be used in generic code with any type which models OptionalPointee:</p> | ||||||
| <a name="equal"></a> | <a name="equal"></a> | ||||||
| <p><u>Equivalence relation:</u></p> | <pre> | ||||||
| <pre>template<class OptionalPointee> | template<class OptionalPointee> | ||||||
| inline | inline | ||||||
| bool equal_pointees ( OptionalPointee const& x, OptionalPointee const& y ) | bool equal_pointees ( OptionalPointee const& x, OptionalPointee const& y ) | ||||||
| { | { | ||||||
|   return (!x) != (!y) ? false : ( !x ? true : (*x) == (*y) ) ; |   return (!x) != (!y) ? false : ( !x ? true : (*x) == (*y) ) ; | ||||||
| } | } | ||||||
| template<class OptionalPointee> |  | ||||||
| struct equal_pointees_t : std::binary_function<OptionalPointee,OptionalPointee,bool> |  | ||||||
| { |  | ||||||
|   bool operator() ( OptionalPointee const& x, OptionalPointee const& y ) const |  | ||||||
|     { return equal_pointees(x,y) ; } |  | ||||||
| } ; |  | ||||||
| </pre> | </pre> | ||||||
| <p>The preceding generic function and function object have the following semantics:<br> | <p>The preceding generic function has the following semantics:<br> | ||||||
| If both <b>x</b> and <b>y</b> have valid pointees, it compares values via <code>(*x == *y)</code>.<br> | If both x and y have valid pointees, it compares pointee's values via (*x == *y).<br> | ||||||
| If only one has a valid pointee, returns <code>false</code>.<br> | If only one has a valid pointee, returns false.<br> | ||||||
| If both have invalid pointees, returns <code>true</code>.</p> | If both have invalid pointees, returns true.</p> | ||||||
| <a name="less"></a> | <p><code>equal_pointees()</code> is implemented in <a href="../../boost/optional.hpp">optional.hpp</a></p> | ||||||
| <p><u>Less-than relation:</u></p> |  | ||||||
| <pre>template<class OptionalPointee> |  | ||||||
| inline |  | ||||||
| bool less_pointees ( OptionalPointee const& x, OptionalPointee const& y ) |  | ||||||
| { |  | ||||||
|   return !y ? false : ( !x ? true : (*x) < (*y) ) ; |  | ||||||
| } |  | ||||||
| template<class OptionalPointee> |  | ||||||
| struct less_pointees_t : std::binary_function<OptionalPointee,OptionalPointee,bool> |  | ||||||
| { |  | ||||||
|   bool operator() ( OptionalPointee const& x, OptionalPointee const& y ) const |  | ||||||
|     { return less_pointees(x,y) ; } |  | ||||||
| } ; |  | ||||||
| </pre> |  | ||||||
| <p>The preceding generic function and function object have the following semantics:<br> |  | ||||||
| If <b>y</b> has an invalid pointee, returns <code>false</code>.<br> |  | ||||||
| Else, if <b>x</b> has an invalid pointee, returns <code>true</code>.<br> |  | ||||||
| Else, ( <b>x</b> and <b>y</b> have valid pointees), compares values via <code>(*x <  |  | ||||||
| *y).</code></p> |  | ||||||
| <p><br> |  | ||||||
| All these functions and function  |  | ||||||
| objects are is implemented in <a href="../../boost/utility/compare_pointees.hpp">compare_pointees.hpp</a></p> |  | ||||||
| <p>Notice that OptionalPointee does not imply aliasing (and optional<> for instance does not alias); | <p>Notice that OptionalPointee does not imply aliasing (and optional<> for instance does not alias); | ||||||
| so direct usage of relational operators with the implied aliasing of shallow semantics | 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> | -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> | <br> | ||||||
| </p> |  | ||||||
| <HR> | <HR> | ||||||
| <TABLE> | <TABLE> | ||||||
| <TR valign=top> | <TR valign=top> | ||||||
| <TD nowrap>Copyright © 2003</TD><TD> | <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> | </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> | </BODY> | ||||||
| </HTML> | </HTML> | ||||||
| @@ -1,76 +0,0 @@ | |||||||
| #include <boost/config.hpp> |  | ||||||
|  |  | ||||||
| #if defined(BOOST_MSVC) |  | ||||||
| #pragma warning(disable: 4786)  // identifier truncated in debug info |  | ||||||
| #pragma warning(disable: 4710)  // function not inlined |  | ||||||
| #pragma warning(disable: 4711)  // function selected for automatic inline expansion |  | ||||||
| #pragma warning(disable: 4514)  // unreferenced inline removed |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| //  addressof_fn_test.cpp: addressof( f ) |  | ||||||
| // |  | ||||||
| //  Copyright (c) 2008, 2009 Peter Dimov |  | ||||||
| // |  | ||||||
| //  Distributed under the Boost Software License, Version 1.0. |  | ||||||
| //  See accompanying file LICENSE_1_0.txt or copy at |  | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt |  | ||||||
|  |  | ||||||
| #include <boost/utility/addressof.hpp> |  | ||||||
| #include <boost/detail/lightweight_test.hpp> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void f0() |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f1(int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f2(int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f3(int, int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f4(int, int, int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f5(int, int, int, int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f6(int, int, int, int, int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f7(int, int, int, int, int, int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f8(int, int, int, int, int, int, int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void f9(int, int, int, int, int, int, int, int, int) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int main() |  | ||||||
| { |  | ||||||
|     BOOST_TEST( boost::addressof( f0 ) == &f0 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f1 ) == &f1 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f2 ) == &f2 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f3 ) == &f3 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f4 ) == &f4 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f5 ) == &f5 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f6 ) == &f6 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f7 ) == &f7 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f8 ) == &f8 ); |  | ||||||
|     BOOST_TEST( boost::addressof( f9 ) == &f9 ); |  | ||||||
|  |  | ||||||
|     return boost::report_errors(); |  | ||||||
| } |  | ||||||
| @@ -1,94 +1,46 @@ | |||||||
| // Copyright (C) 2002 Brad King (brad.king@kitware.com)  | // Copyright (C) 2002 Brad King (brad.king@kitware.com)  | ||||||
| //                    Douglas Gregor (gregod@cs.rpi.edu) | //                    Doug Gregor (gregod@cs.rpi.edu) | ||||||
| // | // | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | // Permission to copy, use, sell and distribute this software is granted | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | // provided this copyright notice appears in all copies. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | // Permission to modify the code and to distribute modified code is granted | ||||||
|  | // provided this copyright notice appears in all copies, and a notice | ||||||
|  | // that the code was modified is included with the copyright notice. | ||||||
|  | // | ||||||
|  | // 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 | // For more information, see http://www.boost.org | ||||||
|  |  | ||||||
|  | #define BOOST_INCLUDE_MAIN | ||||||
| #include <boost/utility/addressof.hpp> | #include <boost/test/test_tools.hpp> | ||||||
|  | #include <boost/utility.hpp> | ||||||
| #if defined(BOOST_MSVC) && (BOOST_MSVC < 1300) |  | ||||||
| #pragma warning(push, 3) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include <iostream> |  | ||||||
|  |  | ||||||
| #if defined(BOOST_MSVC) && (BOOST_MSVC < 1300) |  | ||||||
| #pragma warning(pop) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include <boost/detail/lightweight_test.hpp> |  | ||||||
|  |  | ||||||
| template<class T> void scalar_test( T * = 0 ) |  | ||||||
| { |  | ||||||
|     T* px = new T(); |  | ||||||
|  |  | ||||||
|     T& x = *px; |  | ||||||
|     BOOST_TEST( boost::addressof(x) == px ); |  | ||||||
|  |  | ||||||
|     const T& cx = *px; |  | ||||||
|     const T* pcx = boost::addressof(cx); |  | ||||||
|     BOOST_TEST( pcx == px ); |  | ||||||
|  |  | ||||||
|     volatile T& vx = *px; |  | ||||||
|     volatile T* pvx = boost::addressof(vx); |  | ||||||
|     BOOST_TEST( pvx == px ); |  | ||||||
|  |  | ||||||
|     const volatile T& cvx = *px; |  | ||||||
|     const volatile T* pcvx = boost::addressof(cvx); |  | ||||||
|     BOOST_TEST( pcvx == px ); |  | ||||||
|  |  | ||||||
|     delete px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template<class T> void array_test( T * = 0 ) |  | ||||||
| { |  | ||||||
|     T nrg[3] = {1,2,3}; |  | ||||||
|     T (*pnrg)[3] = &nrg; |  | ||||||
|     BOOST_TEST( boost::addressof(nrg) == pnrg ); |  | ||||||
|  |  | ||||||
|     T const cnrg[3] = {1,2,3}; |  | ||||||
|     T const (*pcnrg)[3] = &cnrg; |  | ||||||
|     BOOST_TEST( boost::addressof(cnrg) == pcnrg ); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| struct addressable |  | ||||||
| { |  | ||||||
|     addressable( int = 0 ) |  | ||||||
|     { |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| struct useless_type {}; | struct useless_type {}; | ||||||
|  |  | ||||||
| class nonaddressable { | class nonaddressable { | ||||||
| public: | public: | ||||||
|  |  | ||||||
|     nonaddressable( int = 0 ) |  | ||||||
|     { |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|   void dummy(); // Silence GCC warning: all member of class are private |   void dummy(); // Silence GCC warning: all member of class are private | ||||||
|  |  | ||||||
| private: | private: | ||||||
|  |  | ||||||
|   useless_type operator&() const; |   useless_type operator&() const; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| int main() | int test_main(int, char*[]) | ||||||
| { | { | ||||||
|     scalar_test<char>(); |   nonaddressable* px = new nonaddressable(); | ||||||
|     scalar_test<int>(); |  | ||||||
|     scalar_test<addressable>(); |  | ||||||
|     scalar_test<nonaddressable>(); |  | ||||||
|  |  | ||||||
|     array_test<char>(); |   nonaddressable& x = *px; | ||||||
|     array_test<int>(); |   BOOST_TEST(boost::addressof(x) == px); | ||||||
|     array_test<addressable>(); |  | ||||||
|     array_test<nonaddressable>(); |  | ||||||
|  |  | ||||||
|     return boost::report_errors(); |   const nonaddressable& cx = *px; | ||||||
|  |   BOOST_TEST(boost::addressof(cx) == static_cast<const nonaddressable*>(px)); | ||||||
|  |  | ||||||
|  |   volatile nonaddressable& vx = *px; | ||||||
|  |   BOOST_TEST(boost::addressof(vx) == static_cast<volatile nonaddressable*>(px)); | ||||||
|  |  | ||||||
|  |   const volatile nonaddressable& cvx = *px; | ||||||
|  |   BOOST_TEST(boost::addressof(cvx) == static_cast<const volatile nonaddressable*>(px)); | ||||||
|  |    | ||||||
|  |   return 0; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,95 +0,0 @@ | |||||||
| // Copyright (C) 2002 Brad King (brad.king@kitware.com)  |  | ||||||
| //                    Douglas Gregor (gregod@cs.rpi.edu) |  | ||||||
| // |  | ||||||
| // Copyright 2009 Peter Dimov |  | ||||||
| // |  | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See |  | ||||||
| // accompanying file LICENSE_1_0.txt or copy at |  | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
|  |  | ||||||
| // For more information, see http://www.boost.org |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #include <boost/utility/addressof.hpp> |  | ||||||
|  |  | ||||||
| #if defined(BOOST_MSVC) && (BOOST_MSVC < 1300) |  | ||||||
| #pragma warning(push, 3) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include <iostream> |  | ||||||
|  |  | ||||||
| #if defined(BOOST_MSVC) && (BOOST_MSVC < 1300) |  | ||||||
| #pragma warning(pop) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include <boost/detail/lightweight_test.hpp> |  | ||||||
|  |  | ||||||
| template<class T> void scalar_test( T * = 0 ) |  | ||||||
| { |  | ||||||
|     T* px = new T(); |  | ||||||
|  |  | ||||||
|     T& x = *px; |  | ||||||
|     BOOST_TEST( boost::addressof(x) == px ); |  | ||||||
|  |  | ||||||
|     const T& cx = *px; |  | ||||||
|     const T* pcx = boost::addressof(cx); |  | ||||||
|     BOOST_TEST( pcx == px ); |  | ||||||
|  |  | ||||||
|     volatile T& vx = *px; |  | ||||||
|     volatile T* pvx = boost::addressof(vx); |  | ||||||
|     BOOST_TEST( pvx == px ); |  | ||||||
|  |  | ||||||
|     const volatile T& cvx = *px; |  | ||||||
|     const volatile T* pcvx = boost::addressof(cvx); |  | ||||||
|     BOOST_TEST( pcvx == px ); |  | ||||||
|  |  | ||||||
|     delete px; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template<class T> void array_test( T * = 0 ) |  | ||||||
| { |  | ||||||
|     T nrg[3] = {1,2,3}; |  | ||||||
|     T (*pnrg)[3] = &nrg; |  | ||||||
|     BOOST_TEST( boost::addressof(nrg) == pnrg ); |  | ||||||
|  |  | ||||||
|     T const cnrg[3] = {1,2,3}; |  | ||||||
|     T const (*pcnrg)[3] = &cnrg; |  | ||||||
|     BOOST_TEST( boost::addressof(cnrg) == pcnrg ); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| class convertible { |  | ||||||
| public: |  | ||||||
|  |  | ||||||
|     convertible( int = 0 ) |  | ||||||
|     { |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     template<class U> operator U () const |  | ||||||
|     { |  | ||||||
|         return U(); |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| class convertible2 { |  | ||||||
| public: |  | ||||||
|  |  | ||||||
|     convertible2( int = 0 ) |  | ||||||
|     { |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     operator convertible2* () const |  | ||||||
|     { |  | ||||||
|         return 0; |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| int main() |  | ||||||
| { |  | ||||||
|     scalar_test<convertible>(); |  | ||||||
|     scalar_test<convertible2>(); |  | ||||||
|  |  | ||||||
|     array_test<convertible>(); |  | ||||||
|     array_test<convertible2>(); |  | ||||||
|  |  | ||||||
|     return boost::report_errors(); |  | ||||||
| } |  | ||||||
							
								
								
									
										18
									
								
								assert.html
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								assert.html
									
									
									
									
									
								
							| @@ -7,9 +7,10 @@ | |||||||
| 	<body bgcolor="white" style="MARGIN-LEFT: 5%; MARGIN-RIGHT: 5%"> | 	<body bgcolor="white" style="MARGIN-LEFT: 5%; MARGIN-RIGHT: 5%"> | ||||||
| 		<table border="0" width="100%"> | 		<table border="0" width="100%"> | ||||||
| 			<tr> | 			<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="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" width="277" height="86"> | ||||||
| 				</td> | 				</td> | ||||||
| 				<td align="center"> | 				<td align="middle"> | ||||||
| 					<h1>assert.hpp</h1> | 					<h1>assert.hpp</h1> | ||||||
| 				</td> | 				</td> | ||||||
| 			</tr> | 			</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> | 		<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> | 			can be included multiple times in a single translation unit. <STRONG>BOOST_ASSERT</STRONG> | ||||||
| 			will be redefined each time as specified above.</P> | 			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> | 		<p><br> | ||||||
| 			<small>Copyright <20> 2002, 2007 by Peter Dimov. Distributed under the Boost Software  | 			<small>Copyright <20> 2002 by Peter Dimov. Permission to copy, use, modify, sell and  | ||||||
| 				License, Version 1.0. See accompanying file <A href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</A> | 				distribute this document is granted provided this copyright notice appears in  | ||||||
| 				or copy at <A href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</A>.</small></p> | 				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> | 	</body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -3,9 +3,10 @@ | |||||||
| // | // | ||||||
| //  Copyright (c) 2002 Peter Dimov and Multi Media Ltd. | //  Copyright (c) 2002 Peter Dimov and Multi Media Ltd. | ||||||
| // | // | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | //  Permission to copy, use, modify, sell and distribute this software | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | //  is granted provided this copyright notice appears in all copies. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | //  This software is provided "as is" without express or implied | ||||||
|  | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include <boost/detail/lightweight_test.hpp> | #include <boost/detail/lightweight_test.hpp> | ||||||
| @@ -51,18 +52,13 @@ void test_disabled() | |||||||
|  |  | ||||||
| #define BOOST_ENABLE_ASSERT_HANDLER | #define BOOST_ENABLE_ASSERT_HANDLER | ||||||
| #include <boost/assert.hpp> | #include <boost/assert.hpp> | ||||||
| #include <boost/config.hpp> |  | ||||||
| #include <cstdio> | #include <cstdio> | ||||||
|  |  | ||||||
| int handler_invoked = 0; | int handler_invoked = 0; | ||||||
|  |  | ||||||
| void boost::assertion_failed(char const * expr, char const * function, char const * file, long line) | void boost::assertion_failed(char const * expr, char const * function, char const * file, long line) | ||||||
| { | { | ||||||
| #if !defined(BOOST_NO_STDC_NAMESPACE) |     std::printf("Expression: %s\nFunction: %s\nFile: %s\nLine: %ld\n\n", expr, function, file, line); | ||||||
|     using std::printf; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|     printf("Expression: %s\nFunction: %s\nFile: %s\nLine: %ld\n\n", expr, function, file, line); |  | ||||||
|     ++handler_invoked; |     ++handler_invoked; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,14 +5,15 @@ | |||||||
| </head> | </head> | ||||||
|  |  | ||||||
| <body bgcolor="white" link="blue" text="black" vlink="purple" alink="red">  | <body bgcolor="white" link="blue" text="black" vlink="purple" alink="red">  | ||||||
| <h1><img src="../../boost.png" alt="C++ Boost" align="middle" | <h1><img src="../../c++boost.gif" alt="C++ Boost" align="middle" | ||||||
| width="277" height="86">Base-from-Member Idiom</h1> | width="277" height="86">Base-from-Member Idiom</h1> | ||||||
|  |  | ||||||
| <p>The class template <code>boost::base_from_member</code> provides | <p>The class template <code>boost::base_from_member</code> provides | ||||||
| a workaround for a class that needs to initialize a base class with a | a workaround for a class that needs to initialize a base class with a | ||||||
| member.  The class template is in <cite><a | member.  The class template is in <cite><a | ||||||
| href="../../boost/utility/base_from_member.hpp">boost/utility/base_from_member.hpp</a></cite> | href="../../boost/utility/base_from_member.hpp">boost/utility/base_from_member.hpp</a></cite> | ||||||
| which is included in <i><a href="../../boost/utility.hpp">boost/utility.hpp</a></i>.</p> | which is included in <i><a href="../../boost/utility.hpp">boost/utility.hpp</a></i>. | ||||||
|  | The class template is forward declared in <i><a href="../../boost/utility_fwd.hpp">boost/utility_fwd.hpp</a></i>.</p> | ||||||
|  |  | ||||||
| <p>There is test/example code in <cite><a | <p>There is test/example code in <cite><a | ||||||
| href="base_from_member_test.cpp">base_from_member_test.cpp</a></cite>.</p> | href="base_from_member_test.cpp">base_from_member_test.cpp</a></cite>.</p> | ||||||
| @@ -63,12 +64,11 @@ public: | |||||||
| </pre></blockquote> | </pre></blockquote> | ||||||
|  |  | ||||||
| <p>This is undefined because C++'s initialization order mandates that | <p>This is undefined because C++'s initialization order mandates that | ||||||
| the base class is initialized before the member it uses.  <a | the base class is initialized before the member it uses.  Ron Klatchko | ||||||
| href="http://www.moocat.org">R. Samuel Klatchko</a> developed a way | developed a way around this by using the initialization order in his | ||||||
| around this by using the initialization order in his favor.  Base | favor.  Base classes are intialized in order of declaration, so moving | ||||||
| classes are intialized in order of declaration, so moving the desired | the desired member to another base class, that is initialized before the | ||||||
| member to another base class, that is initialized before the desired | desired base class, can ensure proper initialization.</p> | ||||||
| base class, can ensure proper initialization.</p> |  | ||||||
|  |  | ||||||
| <p>A custom base class can be made for this idiom:</p> | <p>A custom base class can be made for this idiom:</p> | ||||||
|  |  | ||||||
| @@ -108,13 +108,7 @@ public: | |||||||
| }; | }; | ||||||
| </pre></blockquote> | </pre></blockquote> | ||||||
|  |  | ||||||
| <p>Other projects can use similar custom base classes.  The technique | <p>Other projects can use similar custom base classes.  The technique is basic enough to make a template, with a sample template class in this library.  The main template parameter is the type of the enclosed member.  The template class has several (explicit) constructor member templates, which implicitly type the constructor arguments and pass them to the member.  The template class uses implicit copy construction and assignment, cancelling them if the enclosed member is non-copyable.</p> | ||||||
| is basic enough to make a template, with a sample template class in |  | ||||||
| this library.  The main template parameter is the type of the enclosed |  | ||||||
| member.  The template class has several (explicit) constructor member |  | ||||||
| templates, which implicitly type the constructor arguments and pass them |  | ||||||
| to the member.  The template class uses implicit copy construction and |  | ||||||
| assignment, cancelling them if the enclosed member is non-copyable.</p> |  | ||||||
|  |  | ||||||
| <p>Manually coding a base class may be better if the construction | <p>Manually coding a base class may be better if the construction | ||||||
| and/or copying needs are too complex for the supplied template class, | and/or copying needs are too complex for the supplied template class, | ||||||
| @@ -129,31 +123,21 @@ particular member type does not need to concern itself with the integer.</p> | |||||||
| <h2><a name="synopsis">Synopsis</a></h2> | <h2><a name="synopsis">Synopsis</a></h2> | ||||||
|  |  | ||||||
| <blockquote><pre> | <blockquote><pre> | ||||||
| #ifndef BOOST_BASE_FROM_MEMBER_MAX_ARITY |  | ||||||
| #define BOOST_BASE_FROM_MEMBER_MAX_ARITY  10 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| template < typename MemberType, int UniqueID = 0 > | template < typename MemberType, int UniqueID = 0 > | ||||||
| class boost::base_from_member | class boost::base_from_member | ||||||
| { | { | ||||||
| protected: | protected: | ||||||
|     MemberType  member; |     MemberType  member; | ||||||
|  |  | ||||||
|     base_from_member(); |     explicit  base_from_member(); | ||||||
|  |  | ||||||
|     template< typename T1 > |     template< typename T1 > | ||||||
|     explicit  base_from_member( T1 x1 ); |     explicit  base_from_member( T1 x1 ); | ||||||
|  |  | ||||||
|     template< typename T1, typename T2 > |  | ||||||
|     base_from_member( T1 x1, T2 x2 ); |  | ||||||
|  |  | ||||||
|     //... |     //... | ||||||
|  |  | ||||||
|     template< typename T1, typename T2, typename T3, typename T4, |     template< typename T1, typename T2, typename T3 > | ||||||
|      typename T5, typename T6, typename T7, typename T8, typename T9, |     explicit  base_from_member( T1 x1, T2 x2, T3 x3 ); | ||||||
|      typename T10 > |  | ||||||
|     base_from_member( T1 x1, T2 x2, T3 x3, T4 x4, T5 x5, T6 x6, T7 x7, |  | ||||||
|      T8 x8, T9 x9, T10 x10 ); |  | ||||||
| }; | }; | ||||||
| </pre></blockquote> | </pre></blockquote> | ||||||
|  |  | ||||||
| @@ -168,20 +152,12 @@ for later base classes (or itself).</p> | |||||||
|  |  | ||||||
| <p>There is a default constructor and several constructor member | <p>There is a default constructor and several constructor member | ||||||
| templates.  These constructor templates can take as many arguments | templates.  These constructor templates can take as many arguments | ||||||
| (currently up to ten) as possible and pass them to a constructor of | (currently up to three) as possible and pass them to a constructor of | ||||||
| the data member.  Since C++ does not allow any way to explicitly state | the data member.  Since C++ does not allow any way to explicitly state | ||||||
| the template parameters of a templated constructor, make sure that | the template parameters of a templated constructor, make sure that | ||||||
| the arguments are already close as possible to the actual type used in | the arguments are already close as possible to the actual type used in | ||||||
| the data member's desired constructor.</p> | the data member's desired constructor.</p> | ||||||
|  |  | ||||||
| <p>The <var>BOOST_BASE_FROM_MEMBER_MAX_ARITY</var> macro constant specifies |  | ||||||
| the maximum argument length for the constructor templates.  The constant |  | ||||||
| may be overridden if more (or less) argument configurations are needed.  The |  | ||||||
| constant may be read for code that is expandable like the class template and |  | ||||||
| needs to maintain the same maximum size.  (Example code would be a class that |  | ||||||
| uses this class template as a base class for a member with a flexible set of |  | ||||||
| constructors.)</p> |  | ||||||
|  |  | ||||||
| <h2><a name="usage">Usage</a></h2> | <h2><a name="usage">Usage</a></h2> | ||||||
|  |  | ||||||
| <p>With the starting example, the <code>fdoutbuf</code> sub-object needs | <p>With the starting example, the <code>fdoutbuf</code> sub-object needs | ||||||
| @@ -334,38 +310,32 @@ with the exact pointer type used in <code>switcher</code>'s constructor.</p> | |||||||
| <h3><a name="contributors">Contributors</a></h3> | <h3><a name="contributors">Contributors</a></h3> | ||||||
|  |  | ||||||
| <dl> | <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. | 	<dd>Suggested some interface changes. | ||||||
|  |  | ||||||
| 	<dt><a href="http://www.moocat.org">R. Samuel Klatchko</a> (<a | 	<dt>Ron Klatchko (<a href="mailto:ron@crl.com">ron@crl.com</a>) | ||||||
| 	href="mailto:rsk@moocat.org">rsk@moocat.org</a>, <a |  | ||||||
| 	href="mailto:rsk@brightmail.com">rsk@brightmail.com</a>) |  | ||||||
| 	<dd>Invented the idiom of how to use a class member for initializing | 	<dd>Invented the idiom of how to use a class member for initializing | ||||||
| 		a base class. | 		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 | 	<dd>Popularized the base-from-member idiom in his | ||||||
| 		<a href="http://www.informatik.uni-konstanz.de/~kuehl/c++/iostream/">IOStream | 		<a href="http://www.informatik.uni-konstanz.de/~kuehl/c++/iostream/">IOStream | ||||||
| 		example classes</a>. | 		example classes</a>. | ||||||
|  |  | ||||||
| 	<dt>Jonathan Turkanis | 	<dt><a href="../../people/daryle_walker.html">Daryle Walker</a> | ||||||
| 	<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>. |  | ||||||
|  |  | ||||||
| 	<dt><a href="http://www.boost.org/people/daryle_walker.html">Daryle Walker</a> |  | ||||||
| 	<dd>Started the library.  Contributed the test file <cite><a | 	<dd>Started the library.  Contributed the test file <cite><a | ||||||
| 		href="base_from_member_test.cpp">base_from_member_test.cpp</a></cite>. | 		href="base_from_member_test.cpp">base_from_member_test.cpp</a></cite>. | ||||||
| </dl> | </dl> | ||||||
|  |  | ||||||
| <hr> | <hr> | ||||||
|  |  | ||||||
| <p>Revised: 28 August 2004</p> | <p>Revised: 22 August 2001</p> | ||||||
|  |  | ||||||
| <p>Copyright 2001, 2003, 2004 Daryle Walker.  Use, modification, and distribution | <p>Copyright © boost.org 2001.  Permission to copy, use, modify, | ||||||
| are subject to the Boost Software License, Version 1.0.  (See accompanying | sell and distribute this document is granted provided this copyright | ||||||
| file <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or a copy at <<a | notice appears in all copies.  This document is provided "as | ||||||
| href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>>.)</p> | is" without express or implied warranty, and with no claim as to | ||||||
|  | its suitability for any purpose.</p> | ||||||
|  |  | ||||||
| </body> | </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -1,16 +1,18 @@ | |||||||
| //  Boost test program for base-from-member class templates  -----------------// | //  Boost test program for base-from-member class templates  -----------------// | ||||||
|  |  | ||||||
| //  Copyright 2001, 2003 Daryle Walker.  Use, modification, and distribution are | //  (C) Copyright Daryle Walker 2001.  Permission to copy, use, modify, sell | ||||||
| //  subject to the Boost Software License, Version 1.0.  (See accompanying file | //  and distribute this software is granted provided this copyright | ||||||
| //  LICENSE_1_0.txt or a copy at <http://www.boost.org/LICENSE_1_0.txt>.) | //  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. | ||||||
|  |  | ||||||
| //  See <http://www.boost.org/libs/utility/> for the library's home page. | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| //  Revision History | //  Revision History | ||||||
| //  14 Jun 2003  Adjusted code for Boost.Test changes (Daryle Walker) |  | ||||||
| //  29 Aug 2001  Initial Version (Daryle Walker) | //  29 Aug 2001  Initial Version (Daryle Walker) | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp>  // for BOOST_CHECK, main | #define  BOOST_INCLUDE_MAIN | ||||||
|  | #include <boost/test/test_tools.hpp>  // for BOOST_TEST, main | ||||||
|  |  | ||||||
| #include <boost/config.hpp>   // for BOOST_NO_MEMBER_TEMPLATES | #include <boost/config.hpp>   // for BOOST_NO_MEMBER_TEMPLATES | ||||||
| #include <boost/cstdlib.hpp>  // for boost::exit_success | #include <boost/cstdlib.hpp>  // for boost::exit_success | ||||||
| @@ -175,11 +177,11 @@ object_registrar  obj_reg; | |||||||
| int | int | ||||||
| test_main( int , char * [] ) | test_main( int , char * [] ) | ||||||
| { | { | ||||||
|     BOOST_CHECK( obj_reg.db_.empty() ); |     BOOST_TEST( obj_reg.db_.empty() ); | ||||||
|     BOOST_CHECK( obj_reg.defrauders_in_.empty() ); |     BOOST_TEST( obj_reg.defrauders_in_.empty() ); | ||||||
|     BOOST_CHECK( obj_reg.defrauders_out_.empty() ); |     BOOST_TEST( obj_reg.defrauders_out_.empty() ); | ||||||
|     BOOST_CHECK( obj_reg.overeager_.empty() ); |     BOOST_TEST( obj_reg.overeager_.empty() ); | ||||||
|     BOOST_CHECK( obj_reg.overkilled_.empty() ); |     BOOST_TEST( obj_reg.overkilled_.empty() ); | ||||||
|  |  | ||||||
|     // Make a separate block to examine pre- and post-effects |     // Make a separate block to examine pre- and post-effects | ||||||
|     { |     { | ||||||
| @@ -187,20 +189,20 @@ test_main( int , char * [] ) | |||||||
|         using std::endl; |         using std::endl; | ||||||
|  |  | ||||||
|         bad_class  bc; |         bad_class  bc; | ||||||
|         BOOST_CHECK( obj_reg.db_.size() == 3 ); |         BOOST_TEST( obj_reg.db_.size() == 3 ); | ||||||
|         BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); |         BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||||
|  |  | ||||||
|         good_class_1  gc1; |         good_class_1  gc1; | ||||||
|         BOOST_CHECK( obj_reg.db_.size() == 6 ); |         BOOST_TEST( obj_reg.db_.size() == 6 ); | ||||||
|         BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); |         BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||||
|  |  | ||||||
|         good_class_2  gc2; |         good_class_2  gc2; | ||||||
|         BOOST_CHECK( obj_reg.db_.size() == 11 ); |         BOOST_TEST( obj_reg.db_.size() == 11 ); | ||||||
|         BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); |         BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||||
|  |  | ||||||
|         BOOST_CHECK( obj_reg.defrauders_out_.empty() ); |         BOOST_TEST( obj_reg.defrauders_out_.empty() ); | ||||||
|         BOOST_CHECK( obj_reg.overeager_.empty() ); |         BOOST_TEST( obj_reg.overeager_.empty() ); | ||||||
|         BOOST_CHECK( obj_reg.overkilled_.empty() ); |         BOOST_TEST( obj_reg.overkilled_.empty() ); | ||||||
|  |  | ||||||
|         // Getting the addresses of the objects ensure |         // Getting the addresses of the objects ensure | ||||||
|         // that they're used, and not optimized away. |         // that they're used, and not optimized away. | ||||||
| @@ -209,11 +211,11 @@ test_main( int , char * [] ) | |||||||
|         cout << "Object 'gc2' is at " << &gc2 << '.' << endl; |         cout << "Object 'gc2' is at " << &gc2 << '.' << endl; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( obj_reg.db_.empty() ); |     BOOST_TEST( obj_reg.db_.empty() ); | ||||||
|     BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); |     BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||||
|     BOOST_CHECK( obj_reg.defrauders_out_.size() == 1 ); |     BOOST_TEST( obj_reg.defrauders_out_.size() == 1 ); | ||||||
|     BOOST_CHECK( obj_reg.overeager_.empty() ); |     BOOST_TEST( obj_reg.overeager_.empty() ); | ||||||
|     BOOST_CHECK( obj_reg.overkilled_.empty() ); |     BOOST_TEST( obj_reg.overkilled_.empty() ); | ||||||
|  |  | ||||||
|     return boost::exit_success; |     return boost::exit_success; | ||||||
| } | } | ||||||
| @@ -281,7 +283,7 @@ object_id_compare::operator () | |||||||
|         } |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             return a.second->before( *b.second ) != 0; |             return a.second->before( *b.second ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,8 @@ | |||||||
| // (C) Copyright David Abrahams 2000. | // (C) Copyright David Abrahams 2000. Permission to copy, use, modify, | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | // sell and distribute this software is granted provided this | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | // copyright notice appears in all copies. This software is provided | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | // "as is" without express or implied warranty, and with no claim as | ||||||
|  | // to its suitability for any purpose. | ||||||
|  |  | ||||||
| #include <vector> | #include <vector> | ||||||
| #include <string> | #include <string> | ||||||
| @@ -13,8 +14,6 @@ | |||||||
| #include <list> | #include <list> | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
| #include <boost/detail/binary_search.hpp> | #include <boost/detail/binary_search.hpp> | ||||||
| #include <boost/detail/workaround.hpp> |  | ||||||
| #include <cstddef> |  | ||||||
|  |  | ||||||
| #if defined(__SGI_STL_PORT) ? defined(__SGI_STL_OWN_IOSTREAMS) : (!defined(__GNUC__) || __GNUC__ > 2) | #if defined(__SGI_STL_PORT) ? defined(__SGI_STL_OWN_IOSTREAMS) : (!defined(__GNUC__) || __GNUC__ > 2) | ||||||
| # define USE_SSTREAM | # define USE_SSTREAM | ||||||
| @@ -28,16 +27,7 @@ | |||||||
|  |  | ||||||
| namespace { | namespace { | ||||||
|  |  | ||||||
| // In order to get ADL to find the comparison operators defined below, they have | typedef std::vector<std::string> string_vector; | ||||||
| struct mystring : std::string |  | ||||||
| { |  | ||||||
|     typedef std::string base; |  | ||||||
|      |  | ||||||
|     mystring(std::string const& x) |  | ||||||
|         : base(x) {} |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| typedef std::vector<mystring> string_vector; |  | ||||||
|  |  | ||||||
| const std::size_t sequence_length = 1000; | const std::size_t sequence_length = 1000; | ||||||
|  |  | ||||||
| @@ -84,21 +74,20 @@ struct cmp | |||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| inline bool operator<(const mystring& x, const unsigned y) | inline bool operator<(const std::string& x, const unsigned y) | ||||||
| { | { | ||||||
|     return to_int(x) < y; |     return to_int(x) < y; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline bool operator<(const unsigned y, const mystring& x) | inline bool operator<(const unsigned y, const std::string& x) | ||||||
| { | { | ||||||
|     return y < to_int(x); |     return y < to_int(x); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class T> | template <class T> void sort_by_value(T&); | ||||||
| void sort_by_value(T& x); |  | ||||||
|  |  | ||||||
| template <class T> | template <> | ||||||
| void sort_by_value_(T& v, long) | void sort_by_value(std::vector<std::string>& v) | ||||||
| { | { | ||||||
|     std::sort(v.begin(), v.end(), cmp()); |     std::sort(v.begin(), v.end(), cmp()); | ||||||
| } | } | ||||||
| @@ -114,26 +103,28 @@ void random_sorted_sequence(T& seq) | |||||||
|     sort_by_value(seq); |     sort_by_value(seq); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class T, class A> | # if defined(BOOST_MSVC) && BOOST_MSVC < 1300 && !defined(__SGI_STL_PORT) | ||||||
| void sort_by_value_(std::list<T,A>& l, int) |  | ||||||
| { |  | ||||||
| # if BOOST_WORKAROUND(BOOST_DINKUMWARE_STDLIB, == 1) && !defined(__SGI_STL_PORT) |  | ||||||
| // VC6's standard lib doesn't have a template member function for list::sort() | // VC6's standard lib doesn't have a template member function for list::sort() | ||||||
|     std::vector<T> seq; | template <> | ||||||
|     seq.reserve(sequence_length); | void random_sorted_sequence(std::list<std::string>& result) | ||||||
|     std::copy(l.begin(), l.end(), std::back_inserter(seq)); |  | ||||||
|     sort_by_value(seq); |  | ||||||
|     std::copy(seq.begin(), seq.end(), l.begin()); |  | ||||||
| # else |  | ||||||
|     l.sort(cmp()); |  | ||||||
| # endif |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| void sort_by_value(T& x) |  | ||||||
| { | { | ||||||
|     (sort_by_value_)(x, 1); |     std::vector<std::string> seq; | ||||||
|  |     seq.reserve(sequence_length); | ||||||
|  |     for (std::size_t i = 0; i < sequence_length; ++i) | ||||||
|  |     { | ||||||
|  |         push_back_random_number_string(seq); | ||||||
|  |     } | ||||||
|  |     sort_by_value(seq); | ||||||
|  |     result.resize(seq.size()); | ||||||
|  |     std::copy(seq.begin(), seq.end(), result.begin()); | ||||||
| } | } | ||||||
|  | #else | ||||||
|  | template <> | ||||||
|  | void sort_by_value(std::list<std::string>& l) | ||||||
|  | { | ||||||
|  |     l.sort(cmp()); | ||||||
|  | } | ||||||
|  | # endif | ||||||
|  |  | ||||||
| // A way to select the comparisons with/without a Compare parameter for testing. | // A way to select the comparisons with/without a Compare parameter for testing. | ||||||
| template <class Compare> struct searches | template <class Compare> struct searches | ||||||
| @@ -242,13 +233,13 @@ void test_loop(Sequence& x, Compare cmp, unsigned long test_count) | |||||||
|  |  | ||||||
| int main() | int main() | ||||||
| { | { | ||||||
|     string_vector x; |     std::vector<std::string> x; | ||||||
|     std::cout << "=== testing random-access iterators with <: ===\n"; |     std::cout << "=== testing random-access iterators with <: ===\n"; | ||||||
|     test_loop(x, no_compare(), 25); |     test_loop(x, no_compare(), 25); | ||||||
|     std::cout << "=== testing random-access iterators with compare: ===\n"; |     std::cout << "=== testing random-access iterators with compare: ===\n"; | ||||||
|     test_loop(x, cmp(), 25); |     test_loop(x, cmp(), 25); | ||||||
|      |      | ||||||
|     std::list<mystring> y; |     std::list<std::string> y; | ||||||
|     std::cout << "=== testing bidirectional iterators with <: ===\n"; |     std::cout << "=== testing bidirectional iterators with <: ===\n"; | ||||||
|     test_loop(y, no_compare(), 25); |     test_loop(y, no_compare(), 25); | ||||||
|     std::cout << "=== testing bidirectional iterators with compare: ===\n"; |     std::cout << "=== testing bidirectional iterators with compare: ===\n"; | ||||||
|   | |||||||
							
								
								
									
										647
									
								
								binary_test.cpp
									
									
									
									
									
								
							
							
						
						
									
										647
									
								
								binary_test.cpp
									
									
									
									
									
								
							| @@ -1,647 +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> |  | ||||||
|  |  | ||||||
| #ifdef BOOST_MSVC |  | ||||||
| #pragma warning(disable:4996) // warning C4996: 'std::equal': Function call with parameters that may be unsafe - this call relies on the caller to check that the passed values are correct. To disable this warning, use -D_SCL_SECURE_NO_WARNINGS. See documentation on how to use Visual C++ 'Checked Iterators' |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| 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; |  | ||||||
| } |  | ||||||
| @@ -12,7 +12,7 @@ content="C:\PROGRAM FILES\MICROSOFT OFFICE\OFFICE\html.dot"> | |||||||
| <body bgcolor="#FFFFFF" text="#000000" link="#0000FF" | <body bgcolor="#FFFFFF" text="#000000" link="#0000FF" | ||||||
| vlink="#800080"> | vlink="#800080"> | ||||||
|  |  | ||||||
| <h1><img src="../../boost.png" width="276" height="86">Header | <h1><img src="../../c++boost.gif" width="276" height="86">Header | ||||||
| <<a href="../../boost/detail/call_traits.hpp">boost/call_traits.hpp</a>></h1> | <<a href="../../boost/detail/call_traits.hpp">boost/call_traits.hpp</a>></h1> | ||||||
|  |  | ||||||
| <p>All of the contents of <boost/call_traits.hpp> are | <p>All of the contents of <boost/call_traits.hpp> are | ||||||
| @@ -606,7 +606,7 @@ template <bool opt> | |||||||
| struct filler | struct filler | ||||||
| { | { | ||||||
|    template <typename I, typename T> |    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) |       while(first != last) | ||||||
|       { |       { | ||||||
| @@ -740,16 +740,25 @@ specialisation).</p> | |||||||
|  |  | ||||||
| <p>Revised 01 September 2000</p> | <p>Revised 01 September 2000</p> | ||||||
|  |  | ||||||
|    <p> | <p><EFBFBD> Copyright boost.org 2000. Permission to copy, use, modify, | ||||||
|       Copyright 2000 Steve Cleary, Beman Dawes, Howard | sell and distribute this document is granted provided this | ||||||
|       Hinnant and John Maddock. <br/> | copyright notice appears in all copies. This document is provided | ||||||
|       Use, modification and distribution are subject to the | "as is" without express or implied warranty, and with | ||||||
|       Boost Software License, Version 1.0. | no claim as to its suitability for any purpose.</p> | ||||||
|       (See accompanying file LICENSE_1_0.txt |  | ||||||
|       or copy at <a href="http://www.boost.org/LICENSE_1_0.txt"> | <p>Based on contributions by Steve Cleary, Beman Dawes, Howard | ||||||
|          http://www.boost.org/LICENSE_1_0.txt | Hinnant and John Maddock.</p> | ||||||
|       </a>). |  | ||||||
|    </p> | <p>Maintained by <a href="mailto:John_Maddock@compuserve.com">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> | </body> | ||||||
| </html> | </html> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,10 +1,9 @@ | |||||||
| //  boost::compressed_pair test program    |  // boost::compressed_pair test program    | ||||||
|      |  | ||||||
| //  (C) Copyright John Maddock 2000.  |  | ||||||
| //  Use, modification and distribution are 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). |  | ||||||
|      |      | ||||||
|  |  //  (C) Copyright John Maddock 2000. 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.    | ||||||
|  |  | ||||||
| // standalone test program for <boost/call_traits.hpp> | // standalone test program for <boost/call_traits.hpp> | ||||||
| // 18 Mar 2002: | // 18 Mar 2002: | ||||||
| @@ -12,18 +11,14 @@ | |||||||
| // 03 Oct 2000: | // 03 Oct 2000: | ||||||
| //    Enabled extra tests for VC6. | //    Enabled extra tests for VC6. | ||||||
|  |  | ||||||
|  | #include <cassert> | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <iomanip> | #include <iomanip> | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
| #include <typeinfo> | #include <typeinfo> | ||||||
| #include <boost/call_traits.hpp> | #include <boost/call_traits.hpp> | ||||||
|  |  | ||||||
| #include <libs/type_traits/test/test.hpp> | #include <boost/type_traits/type_traits_test.hpp> | ||||||
| #include <libs/type_traits/test/check_type.hpp> |  | ||||||
|  |  | ||||||
| #ifdef BOOST_MSVC |  | ||||||
| #pragma warning(disable:4181) // : warning C4181: qualifier applied to reference type; ignored |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| // a way prevent warnings for unused variables | // a way prevent warnings for unused variables | ||||||
| template<class T> inline void unused_variable(const T&) {} | template<class T> inline void unused_variable(const T&) {} | ||||||
| @@ -56,8 +51,7 @@ struct contained | |||||||
|    const_reference const_get()const { return v_; } |    const_reference const_get()const { return v_; } | ||||||
|    // pass value: |    // pass value: | ||||||
|    void call(param_type){} |    void call(param_type){} | ||||||
| private: |  | ||||||
|    contained& operator=(const contained&); |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | #ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||||
| @@ -82,8 +76,6 @@ struct contained<T[N]> | |||||||
|    reference get() { return v_; } |    reference get() { return v_; } | ||||||
|    const_reference const_get()const { return v_; } |    const_reference const_get()const { return v_; } | ||||||
|    void call(param_type){} |    void call(param_type){} | ||||||
| private: |  | ||||||
|    contained& operator=(const contained&); |  | ||||||
| }; | }; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @@ -128,9 +120,9 @@ void call_traits_checker<T>::operator()(param_type p) | |||||||
|    T t(p); |    T t(p); | ||||||
|    contained<T> c(t); |    contained<T> c(t); | ||||||
|    cout << "checking contained<" << typeid(T).name() << ">..." << endl; |    cout << "checking contained<" << typeid(T).name() << ">..." << endl; | ||||||
|    BOOST_CHECK(t == c.value()); |    assert(t == c.value()); | ||||||
|    BOOST_CHECK(t == c.get()); |    assert(t == c.get()); | ||||||
|    BOOST_CHECK(t == c.const_get()); |    assert(t == c.const_get()); | ||||||
| #ifndef __ICL | #ifndef __ICL | ||||||
|    //cout << "typeof contained<" << typeid(T).name() << ">::v_ is:           " << typeid(&contained<T>::v_).name() << endl; |    //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; |    cout << "typeof contained<" << typeid(T).name() << ">::value() is:      " << typeid(&contained<T>::value).name() << endl; | ||||||
| @@ -152,11 +144,11 @@ struct call_traits_checker<T[N]> | |||||||
|       cout << "checking contained<" << typeid(T[N]).name() << ">..." << endl; |       cout << "checking contained<" << typeid(T[N]).name() << ">..." << endl; | ||||||
|       unsigned int i = 0; |       unsigned int i = 0; | ||||||
|       for(i = 0; i < N; ++i) |       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) |       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) |       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() << ">::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; |       cout << "typeof contained<" << typeid(T[N]).name() << ">::value is:      " << typeid(&contained<T[N]>::value).name() << endl; | ||||||
| @@ -174,7 +166,7 @@ template <class W, class U> | |||||||
| void check_wrap(const W& w, const U& u) | void check_wrap(const W& w, const U& u) | ||||||
| { | { | ||||||
|    cout << "checking " << typeid(W).name() << "..." << endl; |    cout << "checking " << typeid(W).name() << "..." << endl; | ||||||
|    BOOST_CHECK(w.value() == u); |    assert(w.value() == u); | ||||||
| } | } | ||||||
|  |  | ||||||
| // | // | ||||||
| @@ -185,8 +177,8 @@ template <class T, class U, class V> | |||||||
| void check_make_pair(T c, U u, V v) | void check_make_pair(T c, U u, V v) | ||||||
| { | { | ||||||
|    cout << "checking std::pair<" << typeid(c.first).name() << ", " << typeid(c.second).name() << ">..." << endl; |    cout << "checking std::pair<" << typeid(c.first).name() << ", " << typeid(c.second).name() << ">..." << endl; | ||||||
|    BOOST_CHECK(c.first == u); |    assert(c.first == u); | ||||||
|    BOOST_CHECK(c.second == v); |    assert(c.second == v); | ||||||
|    cout << endl; |    cout << endl; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -204,7 +196,7 @@ struct comparible_UDT | |||||||
|    bool operator == (const comparible_UDT& v){ return v.i_ == i_; } |    bool operator == (const comparible_UDT& v){ return v.i_ == i_; } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| int main() | int main(int argc, char *argv[ ]) | ||||||
| { | { | ||||||
|    call_traits_checker<comparible_UDT> c1; |    call_traits_checker<comparible_UDT> c1; | ||||||
|    comparible_UDT u; |    comparible_UDT u; | ||||||
| @@ -238,67 +230,73 @@ int main() | |||||||
|    typedef int& r_type; |    typedef int& r_type; | ||||||
|    typedef const r_type cr_type; |    typedef const r_type cr_type; | ||||||
|  |  | ||||||
|    BOOST_CHECK_TYPE(comparible_UDT, boost::call_traits<comparible_UDT>::value_type); |    type_test(comparible_UDT, boost::call_traits<comparible_UDT>::value_type) | ||||||
|    BOOST_CHECK_TYPE(comparible_UDT&, boost::call_traits<comparible_UDT>::reference); |    type_test(comparible_UDT&, boost::call_traits<comparible_UDT>::reference) | ||||||
|    BOOST_CHECK_TYPE(const comparible_UDT&, boost::call_traits<comparible_UDT>::const_reference); |    type_test(const comparible_UDT&, boost::call_traits<comparible_UDT>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(const comparible_UDT&, boost::call_traits<comparible_UDT>::param_type); |    type_test(const comparible_UDT&, boost::call_traits<comparible_UDT>::param_type) | ||||||
|    BOOST_CHECK_TYPE(int, boost::call_traits<int>::value_type); |    type_test(int, boost::call_traits<int>::value_type) | ||||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<int>::reference); |    type_test(int&, boost::call_traits<int>::reference) | ||||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<int>::const_reference); |    type_test(const int&, boost::call_traits<int>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(const int, boost::call_traits<int>::param_type); |    type_test(const int, boost::call_traits<int>::param_type) | ||||||
|    BOOST_CHECK_TYPE(int*, boost::call_traits<int*>::value_type); |    type_test(int*, boost::call_traits<int*>::value_type) | ||||||
|    BOOST_CHECK_TYPE(int*&, boost::call_traits<int*>::reference); |    type_test(int*&, boost::call_traits<int*>::reference) | ||||||
|    BOOST_CHECK_TYPE(int*const&, boost::call_traits<int*>::const_reference); |    type_test(int*const&, boost::call_traits<int*>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(int*const, boost::call_traits<int*>::param_type); |    type_test(int*const, boost::call_traits<int*>::param_type) | ||||||
| #if defined(BOOST_MSVC6_MEMBER_TEMPLATES) | #if defined(BOOST_MSVC6_MEMBER_TEMPLATES) | ||||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<int&>::value_type); |    type_test(int&, boost::call_traits<int&>::value_type) | ||||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<int&>::reference); |    type_test(int&, boost::call_traits<int&>::reference) | ||||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<int&>::const_reference); |    type_test(const int&, boost::call_traits<int&>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<int&>::param_type); |    type_test(int&, boost::call_traits<int&>::param_type) | ||||||
| #if !(defined(__GNUC__) && ((__GNUC__ < 3) || (__GNUC__ == 3) && (__GNUC_MINOR__ < 1))) | #if !(defined(__GNUC__) && ((__GNUC__ < 3) || (__GNUC__ == 3) && (__GNUC_MINOR__ < 1))) | ||||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<cr_type>::value_type); |    type_test(int&, boost::call_traits<cr_type>::value_type) | ||||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<cr_type>::reference); |    type_test(int&, boost::call_traits<cr_type>::reference) | ||||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<cr_type>::const_reference); |    type_test(const int&, boost::call_traits<cr_type>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(int&, boost::call_traits<cr_type>::param_type); |    type_test(int&, boost::call_traits<cr_type>::param_type) | ||||||
| #else | #else | ||||||
|    std::cout << "Your compiler cannot instantiate call_traits<int&const>, skipping four tests (4 errors)" << std::endl; |    std::cout << "Your compiler cannot instantiate call_traits<int&const>, skipping four tests (4 errors)" << std::endl; | ||||||
|  |    failures += 4; | ||||||
|  |    test_count += 4; | ||||||
| #endif | #endif | ||||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<const int&>::value_type); |    type_test(const int&, boost::call_traits<const int&>::value_type) | ||||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<const int&>::reference); |    type_test(const int&, boost::call_traits<const int&>::reference) | ||||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<const int&>::const_reference); |    type_test(const int&, boost::call_traits<const int&>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(const int&, boost::call_traits<const int&>::param_type); |    type_test(const int&, boost::call_traits<const int&>::param_type) | ||||||
| #ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | #ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||||
|    BOOST_CHECK_TYPE(const int*, boost::call_traits<int[3]>::value_type); |    type_test(const int*, boost::call_traits<int[3]>::value_type) | ||||||
|    BOOST_CHECK_TYPE(int(&)[3], boost::call_traits<int[3]>::reference); |    type_test(int(&)[3], boost::call_traits<int[3]>::reference) | ||||||
|    BOOST_CHECK_TYPE(const int(&)[3], boost::call_traits<int[3]>::const_reference); |    type_test(const int(&)[3], boost::call_traits<int[3]>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(const int*const, boost::call_traits<int[3]>::param_type); |    type_test(const int*const, boost::call_traits<int[3]>::param_type) | ||||||
|    BOOST_CHECK_TYPE(const int*, boost::call_traits<const int[3]>::value_type); |    type_test(const int*, boost::call_traits<const int[3]>::value_type) | ||||||
|    BOOST_CHECK_TYPE(const int(&)[3], boost::call_traits<const int[3]>::reference); |    type_test(const int(&)[3], boost::call_traits<const int[3]>::reference) | ||||||
|    BOOST_CHECK_TYPE(const int(&)[3], boost::call_traits<const int[3]>::const_reference); |    type_test(const int(&)[3], boost::call_traits<const int[3]>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(const int*const, boost::call_traits<const int[3]>::param_type); |    type_test(const int*const, boost::call_traits<const int[3]>::param_type) | ||||||
|    // test with abstract base class: |    // test with abstract base class: | ||||||
|    BOOST_CHECK_TYPE(test_abc1, boost::call_traits<test_abc1>::value_type); |    type_test(test_abc1, boost::call_traits<test_abc1>::value_type) | ||||||
|    BOOST_CHECK_TYPE(test_abc1&, boost::call_traits<test_abc1>::reference); |    type_test(test_abc1&, boost::call_traits<test_abc1>::reference) | ||||||
|    BOOST_CHECK_TYPE(const test_abc1&, boost::call_traits<test_abc1>::const_reference); |    type_test(const test_abc1&, boost::call_traits<test_abc1>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(const test_abc1&, boost::call_traits<test_abc1>::param_type); |    type_test(const test_abc1&, boost::call_traits<test_abc1>::param_type) | ||||||
| #else | #else | ||||||
|    std::cout << "You're compiler does not support partial template specialiation, skipping 8 tests (8 errors)" << std::endl; |    std::cout << "You're compiler does not support partial template specialiation, skipping 8 tests (8 errors)" << std::endl; | ||||||
|  |    failures += 12; | ||||||
|  |    test_count += 12; | ||||||
| #endif | #endif | ||||||
| #else | #else | ||||||
|    std::cout << "You're compiler does not support partial template specialiation, skipping 20 tests (20 errors)" << std::endl; |    std::cout << "You're compiler does not support partial template specialiation, skipping 20 tests (20 errors)" << std::endl; | ||||||
|  |    failures += 24; | ||||||
|  |    test_count += 24; | ||||||
| #endif | #endif | ||||||
|    // test with an incomplete type: |    // test with an incomplete type: | ||||||
|    BOOST_CHECK_TYPE(incomplete_type, boost::call_traits<incomplete_type>::value_type); |    type_test(incomplete_type, boost::call_traits<incomplete_type>::value_type) | ||||||
|    BOOST_CHECK_TYPE(incomplete_type&, boost::call_traits<incomplete_type>::reference); |    type_test(incomplete_type&, boost::call_traits<incomplete_type>::reference) | ||||||
|    BOOST_CHECK_TYPE(const incomplete_type&, boost::call_traits<incomplete_type>::const_reference); |    type_test(const incomplete_type&, boost::call_traits<incomplete_type>::const_reference) | ||||||
|    BOOST_CHECK_TYPE(const incomplete_type&, boost::call_traits<incomplete_type>::param_type); |    type_test(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 | // 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> | template <typename T, bool isarray = false> | ||||||
| struct call_traits_test | struct call_traits_test | ||||||
| @@ -410,3 +408,23 @@ template struct call_traits_test<int[2], true>; | |||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if defined(BOOST_MSVC) && _MSC_VER <= 1300 | ||||||
|  | unsigned int expected_failures = 14; | ||||||
|  | #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%"> | 	<body bgcolor="white" style="MARGIN-LEFT: 5%; MARGIN-RIGHT: 5%"> | ||||||
| 		<table border="0" width="100%"> | 		<table border="0" width="100%"> | ||||||
| 			<tr> | 			<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="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" width="277" height="86"> | ||||||
| 				</td> | 				</td> | ||||||
| 				<td align="center"> | 				<td align="middle"> | ||||||
| 					<h1>checked_delete.hpp</h1> | 					<h1>checked_delete.hpp</h1> | ||||||
| 				</td> | 				</td> | ||||||
| 			</tr> | 			</tr> | ||||||
| @@ -115,8 +116,9 @@ template<class T> struct checked_array_deleter | |||||||
| 		</p> | 		</p> | ||||||
| 		<p> | 		<p> | ||||||
| 			<br> | 			<br> | ||||||
| 			<small>Copyright <20> 2002 by Peter Dimov. Distributed under the Boost Software License, Version  | 			<small>Copyright <20> 2002 by Peter Dimov. Permission to copy, use, modify, sell and  | ||||||
| 				1.0. See accompanying file <A href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</A> or  | 				distribute this document is granted provided this copyright notice appears in  | ||||||
| 				copy at <A href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</A>.</small></p> | 				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> | 	</body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -1,10 +1,12 @@ | |||||||
| //  Boost checked_delete test program  ---------------------------------------// | //  Boost checked_delete test program  ---------------------------------------// | ||||||
|  |  | ||||||
| //  Copyright Beman Dawes 2001.  Distributed under the Boost | //  (C) Copyright Beman Dawes 2001. Permission to copy, use, modify, sell | ||||||
| //  Software License, Version 1.0. (See accompanying file | //  and distribute this software is granted provided this copyright | ||||||
| //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | //  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. | ||||||
|  |  | ||||||
| //  See http://www.boost.org/libs/utility for documentation. | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| //  Revision History | //  Revision History | ||||||
| //  21 May 01  Initial version (Beman Dawes) | //  21 May 01  Initial version (Beman Dawes) | ||||||
| @@ -21,8 +23,9 @@ namespace | |||||||
|  |  | ||||||
| int main() | int main() | ||||||
| { | { | ||||||
|     Incomplete * p = 0; |     Incomplete * p; | ||||||
|     boost::checked_delete(p);          // should cause compile time error |     boost::checked_delete(p);          // should cause compile time error | ||||||
|     boost::checked_array_delete(p);    // should cause compile time error |     Incomplete ** pa; | ||||||
|  |     boost::checked_array_delete(pa);   // should cause compile time error | ||||||
|     return 0; |     return 0; | ||||||
| }   // main | }   // main | ||||||
|   | |||||||
| @@ -1,19 +1,30 @@ | |||||||
| <html> | <html> | ||||||
|    <head> |  | ||||||
|       <title>Header </title> | <head> | ||||||
|       <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> | <meta http-equiv="Content-Type" | ||||||
|       <meta name="Template" content="C:\PROGRAM FILES\MICROSOFT OFFICE\OFFICE\html.dot"> | content="text/html; charset=iso-8859-1"> | ||||||
|       <meta name="GENERATOR" content="Microsoft FrontPage 5.0"> | <meta name="Template" | ||||||
|       <boostcompressed_pair.hpp> | content="C:\PROGRAM FILES\MICROSOFT OFFICE\OFFICE\html.dot"> | ||||||
|    </head> | <meta name="GENERATOR" content="Microsoft FrontPage Express 2.0"> | ||||||
|    <body bgcolor="#ffffff" text="#000000" link="#0000ff" vlink="#800080"> | <title>Header </title> | ||||||
|       <h2><img src="../../boost.png" width="276" height="86">Header <<a href="../../boost/detail/compressed_pair.hpp">boost/compressed_pair.hpp</a>></h2> | <boost/compressed_pair.hpp> | ||||||
|       <p>All of the contents of <boost/compressed_pair.hpp> are defined inside  | </head> | ||||||
|          namespace boost.</p> |  | ||||||
|       <p>The class compressed pair is very similar to std::pair, but if either of the  | <body bgcolor="#FFFFFF" text="#000000" link="#0000FF" | ||||||
|          template arguments are empty classes, then the "empty base-class optimisation"  | vlink="#800080"> | ||||||
|          is applied to compress the size of the pair.</p> |  | ||||||
|       <pre>template <class T1, class T2> | <h2><img src="../../c++boost.gif" width="276" height="86">Header | ||||||
|  | <<a href="../../boost/detail/compressed_pair.hpp">boost/compressed_pair.hpp</a>></h2> | ||||||
|  |  | ||||||
|  | <p>All of the contents of <boost/compressed_pair.hpp> are | ||||||
|  | defined inside namespace boost.</p> | ||||||
|  |  | ||||||
|  | <p>The class compressed pair is very similar to std::pair, but if | ||||||
|  | either of the template arguments are empty classes, then the | ||||||
|  | "empty base-class optimisation" is applied to compress | ||||||
|  | the size of the pair.</p> | ||||||
|  |  | ||||||
|  | <pre>template <class T1, class T2> | ||||||
| class compressed_pair | class compressed_pair | ||||||
| { | { | ||||||
| public: | public: | ||||||
| @@ -41,36 +52,47 @@ public: | |||||||
|  |  | ||||||
| 	void swap(compressed_pair& y); | 	void swap(compressed_pair& y); | ||||||
| };</pre> | };</pre> | ||||||
|       <p>The two members of the pair can be accessed using the member functions first()  |  | ||||||
|          and second(). Note that not all member functions can be instantiated for all  |  | ||||||
|          template parameter types. In particular compressed_pair can be instantiated for  |  | ||||||
|          reference and array types, however in these cases the range of constructors  |  | ||||||
|          that can be used are limited. If types T1 and T2 are the same type, then there  |  | ||||||
|          is only one version of the single-argument constructor, and this constructor  |  | ||||||
|          initialises both values in the pair to the passed value.</p> |  | ||||||
|       <P>Note that if either member is a POD type, then that member is not  |  | ||||||
|          zero-initialized by the compressed_pair default constructor: it's up to you to  |  | ||||||
|          supply an initial value for these types if you want them to have a default  |  | ||||||
|          value.</P> |  | ||||||
|       <p>Note that compressed_pair can not be instantiated if either of the template  |  | ||||||
|          arguments is a union type, unless there is compiler support for  |  | ||||||
|          boost::is_union, or if boost::is_union is specialised for the union type.</p> |  | ||||||
|       <p>Finally, a word of caution for Visual C++ 6 users: if either argument is an  |  | ||||||
|          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> |  | ||||||
|       <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> |  | ||||||
|  |  | ||||||
|    </body> | <p>The two members of the pair can be accessed using the member | ||||||
|  | functions first() and second(). Note that not all member | ||||||
|  | functions can be instantiated for all template parameter types. | ||||||
|  | In particular compressed_pair can be instantiated for reference | ||||||
|  | and array types, however in these cases the range of constructors | ||||||
|  | that can be used are limited. If types T1 and T2 are the same | ||||||
|  | type, then there is only one version of the single-argument | ||||||
|  | constructor, and this constructor initialises both values in the | ||||||
|  | pair to the passed value.</p> | ||||||
|  |  | ||||||
|  | <p>Note that compressed_pair can not be instantiated if either of | ||||||
|  | the template arguments is a union type, unless there is compiler | ||||||
|  | support for boost::is_union, or if boost::is_union is specialised | ||||||
|  | for the union type.</p> | ||||||
|  |  | ||||||
|  | <p>Finally, a word of caution for Visual C++ 6 users: if either | ||||||
|  | argument is an 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> | ||||||
|  |  | ||||||
|  | <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_Maddock@compuserve.com">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> | ||||||
|  | </body> | ||||||
| </html> | </html> | ||||||
| @@ -1,9 +1,9 @@ | |||||||
| //  boost::compressed_pair test program    |  // boost::compressed_pair test program    | ||||||
|      |      | ||||||
| //  (C) Copyright John Maddock 2000.  |  //  (C) Copyright John Maddock 2000. Permission to copy, use, modify, sell and    | ||||||
| //  Use, modification and distribution are subject to the Boost Software License, |  //  distribute this software is granted provided this copyright notice appears    | ||||||
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at |  //  in all copies. This software is provided "as is" without express or implied    | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt). |  //  warranty, and with no claim as to its suitability for any purpose.    | ||||||
|  |  | ||||||
| // standalone test program for <boost/compressed_pair.hpp> | // standalone test program for <boost/compressed_pair.hpp> | ||||||
| // Revised 03 Oct 2000:  | // Revised 03 Oct 2000:  | ||||||
| @@ -14,23 +14,29 @@ | |||||||
| #include <cassert> | #include <cassert> | ||||||
|  |  | ||||||
| #include <boost/compressed_pair.hpp> | #include <boost/compressed_pair.hpp> | ||||||
|  | #include <boost/type_traits/type_traits_test.hpp> | ||||||
|  | #define BOOST_INCLUDE_MAIN | ||||||
| #include <boost/test/test_tools.hpp> | #include <boost/test/test_tools.hpp> | ||||||
|  |  | ||||||
| using namespace boost; | using namespace boost; | ||||||
|  |  | ||||||
| struct empty_UDT | namespace boost { | ||||||
| { | #ifndef BOOST_NO_INCLASS_MEMBER_INITIALIZATION | ||||||
|    ~empty_UDT(){}; | template <> struct is_empty<empty_UDT> | ||||||
|    empty_UDT& operator=(const empty_UDT&){ return *this; } | { static const bool value = true; }; | ||||||
|    bool operator==(const empty_UDT&)const | template <> struct is_empty<empty_POD_UDT> | ||||||
|    { return true; } | { static const bool value = true; }; | ||||||
| }; | template <> struct is_POD<empty_POD_UDT> | ||||||
| struct empty_POD_UDT | { static const bool value = true; }; | ||||||
| { | #else | ||||||
|    empty_POD_UDT& operator=(const empty_POD_UDT&){ return *this; } | template <> struct is_empty<empty_UDT> | ||||||
|    bool operator==(const empty_POD_UDT&)const | { enum{ value = true }; }; | ||||||
|    { return true; } | template <> struct is_empty<empty_POD_UDT> | ||||||
| }; | { enum{ value = true }; }; | ||||||
|  | template <> struct is_POD<empty_POD_UDT> | ||||||
|  | { enum{ value = true }; }; | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
| struct non_empty1 | struct non_empty1 | ||||||
| {  | {  | ||||||
| @@ -79,47 +85,47 @@ void compressed_pair_tester<T1, T2>::test(first_param_type p1, second_param_type | |||||||
|    // first param construct: |    // first param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp2(p1); |    boost::compressed_pair<T1,T2> cp2(p1); | ||||||
|    cp2.second() = p2; |    cp2.second() = p2; | ||||||
|    BOOST_CHECK(cp2.first() == p1); |    BOOST_TEST(cp2.first() == p1); | ||||||
|    BOOST_CHECK(cp2.second() == p2); |    BOOST_TEST(cp2.second() == p2); | ||||||
|    // second param construct: |    // second param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp3(p2); |    boost::compressed_pair<T1,T2> cp3(p2); | ||||||
|    cp3.first() = p1; |    cp3.first() = p1; | ||||||
|    BOOST_CHECK(cp3.second() == p2); |    BOOST_TEST(cp3.second() == p2); | ||||||
|    BOOST_CHECK(cp3.first() == p1); |    BOOST_TEST(cp3.first() == p1); | ||||||
|    // both param construct: |    // both param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp4(p1, p2); |    boost::compressed_pair<T1,T2> cp4(p1, p2); | ||||||
|    BOOST_CHECK(cp4.first() == p1); |    BOOST_TEST(cp4.first() == p1); | ||||||
|    BOOST_CHECK(cp4.second() == p2); |    BOOST_TEST(cp4.second() == p2); | ||||||
|    boost::compressed_pair<T1,T2> cp5(p3, p4); |    boost::compressed_pair<T1,T2> cp5(p3, p4); | ||||||
|    BOOST_CHECK(cp5.first() == p3); |    BOOST_TEST(cp5.first() == p3); | ||||||
|    BOOST_CHECK(cp5.second() == p4); |    BOOST_TEST(cp5.second() == p4); | ||||||
|    // check const members: |    // check const members: | ||||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp4; |    const boost::compressed_pair<T1,T2>& cpr1 = cp4; | ||||||
|    BOOST_CHECK(cpr1.first() == p1); |    BOOST_TEST(cpr1.first() == p1); | ||||||
|    BOOST_CHECK(cpr1.second() == p2); |    BOOST_TEST(cpr1.second() == p2); | ||||||
|  |  | ||||||
|    // copy construct: |    // copy construct: | ||||||
|    boost::compressed_pair<T1,T2> cp6(cp4); |    boost::compressed_pair<T1,T2> cp6(cp4); | ||||||
|    BOOST_CHECK(cp6.first() == p1); |    BOOST_TEST(cp6.first() == p1); | ||||||
|    BOOST_CHECK(cp6.second() == p2); |    BOOST_TEST(cp6.second() == p2); | ||||||
|    // assignment: |    // assignment: | ||||||
|    cp1 = cp4; |    cp1 = cp4; | ||||||
|    BOOST_CHECK(cp1.first() == p1); |    BOOST_TEST(cp1.first() == p1); | ||||||
|    BOOST_CHECK(cp1.second() == p2); |    BOOST_TEST(cp1.second() == p2); | ||||||
|    cp1 = cp5; |    cp1 = cp5; | ||||||
|    BOOST_CHECK(cp1.first() == p3); |    BOOST_TEST(cp1.first() == p3); | ||||||
|    BOOST_CHECK(cp1.second() == p4); |    BOOST_TEST(cp1.second() == p4); | ||||||
|    // swap: |    // swap: | ||||||
|    cp4.swap(cp5); |    cp4.swap(cp5); | ||||||
|    BOOST_CHECK(cp4.first() == p3); |    BOOST_TEST(cp4.first() == p3); | ||||||
|    BOOST_CHECK(cp4.second() == p4); |    BOOST_TEST(cp4.second() == p4); | ||||||
|    BOOST_CHECK(cp5.first() == p1); |    BOOST_TEST(cp5.first() == p1); | ||||||
|    BOOST_CHECK(cp5.second() == p2); |    BOOST_TEST(cp5.second() == p2); | ||||||
|    swap(cp4,cp5); |    swap(cp4,cp5); | ||||||
|    BOOST_CHECK(cp4.first() == p1); |    BOOST_TEST(cp4.first() == p1); | ||||||
|    BOOST_CHECK(cp4.second() == p2); |    BOOST_TEST(cp4.second() == p2); | ||||||
|    BOOST_CHECK(cp5.first() == p3); |    BOOST_TEST(cp5.first() == p3); | ||||||
|    BOOST_CHECK(cp5.second() == p4); |    BOOST_TEST(cp5.second() == p4); | ||||||
| } | } | ||||||
|  |  | ||||||
| // | // | ||||||
| @@ -148,20 +154,20 @@ void compressed_pair_reference_tester<T1, T2>::test(first_param_type p1, second_ | |||||||
| #endif | #endif | ||||||
|    // both param construct: |    // both param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp4(p1, p2); |    boost::compressed_pair<T1,T2> cp4(p1, p2); | ||||||
|    BOOST_CHECK(cp4.first() == p1); |    BOOST_TEST(cp4.first() == p1); | ||||||
|    BOOST_CHECK(cp4.second() == p2); |    BOOST_TEST(cp4.second() == p2); | ||||||
|    boost::compressed_pair<T1,T2> cp5(p3, p4); |    boost::compressed_pair<T1,T2> cp5(p3, p4); | ||||||
|    BOOST_CHECK(cp5.first() == p3); |    BOOST_TEST(cp5.first() == p3); | ||||||
|    BOOST_CHECK(cp5.second() == p4); |    BOOST_TEST(cp5.second() == p4); | ||||||
|    // check const members: |    // check const members: | ||||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp4; |    const boost::compressed_pair<T1,T2>& cpr1 = cp4; | ||||||
|    BOOST_CHECK(cpr1.first() == p1); |    BOOST_TEST(cpr1.first() == p1); | ||||||
|    BOOST_CHECK(cpr1.second() == p2); |    BOOST_TEST(cpr1.second() == p2); | ||||||
|  |  | ||||||
|    // copy construct: |    // copy construct: | ||||||
|    boost::compressed_pair<T1,T2> cp6(cp4); |    boost::compressed_pair<T1,T2> cp6(cp4); | ||||||
|    BOOST_CHECK(cp6.first() == p1); |    BOOST_TEST(cp6.first() == p1); | ||||||
|    BOOST_CHECK(cp6.second() == p2); |    BOOST_TEST(cp6.second() == p2); | ||||||
|    // assignment: |    // assignment: | ||||||
|    // VC6 bug: |    // VC6 bug: | ||||||
|    // When second() is an empty class, VC6 performs the |    // When second() is an empty class, VC6 performs the | ||||||
| @@ -174,8 +180,8 @@ void compressed_pair_reference_tester<T1, T2>::test(first_param_type p1, second_ | |||||||
|    // settings - some generate the problem others do not. |    // settings - some generate the problem others do not. | ||||||
|    cp4.first() = p3; |    cp4.first() = p3; | ||||||
|    cp4.second() = p4; |    cp4.second() = p4; | ||||||
|    BOOST_CHECK(cp4.first() == p3); |    BOOST_TEST(cp4.first() == p3); | ||||||
|    BOOST_CHECK(cp4.second() == p4); |    BOOST_TEST(cp4.second() == p4); | ||||||
| } | } | ||||||
| // | // | ||||||
| // supplimentary tests for case where first arg only is a reference type: | // supplimentary tests for case where first arg only is a reference type: | ||||||
| @@ -199,8 +205,8 @@ void compressed_pair_reference1_tester<T1, T2>::test(first_param_type p1, second | |||||||
|    // first param construct: |    // first param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp2(p1); |    boost::compressed_pair<T1,T2> cp2(p1); | ||||||
|    cp2.second() = p2; |    cp2.second() = p2; | ||||||
|    BOOST_CHECK(cp2.first() == p1); |    BOOST_TEST(cp2.first() == p1); | ||||||
|    BOOST_CHECK(cp2.second() == p2); |    BOOST_TEST(cp2.second() == p2); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
| // | // | ||||||
| @@ -225,8 +231,8 @@ void compressed_pair_reference2_tester<T1, T2>::test(first_param_type p1, second | |||||||
|    // second param construct: |    // second param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp3(p2); |    boost::compressed_pair<T1,T2> cp3(p2); | ||||||
|    cp3.first() = p1; |    cp3.first() = p1; | ||||||
|    BOOST_CHECK(cp3.second() == p2); |    BOOST_TEST(cp3.second() == p2); | ||||||
|    BOOST_CHECK(cp3.first() == p1); |    BOOST_TEST(cp3.first() == p1); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -253,14 +259,14 @@ void compressed_pair_array1_tester<T1, T2>::test(first_param_type p1, second_par | |||||||
|    // second param construct: |    // second param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp3(p2); |    boost::compressed_pair<T1,T2> cp3(p2); | ||||||
|    cp3.first()[0] = p1[0]; |    cp3.first()[0] = p1[0]; | ||||||
|    BOOST_CHECK(cp3.second() == p2); |    BOOST_TEST(cp3.second() == p2); | ||||||
|    BOOST_CHECK(cp3.first()[0] == p1[0]); |    BOOST_TEST(cp3.first()[0] == p1[0]); | ||||||
|    // check const members: |    // check const members: | ||||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp3; |    const boost::compressed_pair<T1,T2>& cpr1 = cp3; | ||||||
|    BOOST_CHECK(cpr1.first()[0] == p1[0]); |    BOOST_TEST(cpr1.first()[0] == p1[0]); | ||||||
|    BOOST_CHECK(cpr1.second() == p2); |    BOOST_TEST(cpr1.second() == p2); | ||||||
|  |  | ||||||
|    BOOST_CHECK(sizeof(T1) == sizeof(cp1.first())); |    BOOST_TEST(sizeof(T1) == sizeof(cp1.first())); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class T1, class T2> | template <class T1, class T2> | ||||||
| @@ -283,14 +289,14 @@ void compressed_pair_array2_tester<T1, T2>::test(first_param_type p1, second_par | |||||||
|    // first param construct: |    // first param construct: | ||||||
|    boost::compressed_pair<T1,T2> cp2(p1); |    boost::compressed_pair<T1,T2> cp2(p1); | ||||||
|    cp2.second()[0] = p2[0]; |    cp2.second()[0] = p2[0]; | ||||||
|    BOOST_CHECK(cp2.first() == p1); |    BOOST_TEST(cp2.first() == p1); | ||||||
|    BOOST_CHECK(cp2.second()[0] == p2[0]); |    BOOST_TEST(cp2.second()[0] == p2[0]); | ||||||
|    // check const members: |    // check const members: | ||||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp2; |    const boost::compressed_pair<T1,T2>& cpr1 = cp2; | ||||||
|    BOOST_CHECK(cpr1.first() == p1); |    BOOST_TEST(cpr1.first() == p1); | ||||||
|    BOOST_CHECK(cpr1.second()[0] == p2[0]); |    BOOST_TEST(cpr1.second()[0] == p2[0]); | ||||||
|  |  | ||||||
|    BOOST_CHECK(sizeof(T2) == sizeof(cp1.second())); |    BOOST_TEST(sizeof(T2) == sizeof(cp1.second())); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class T1, class T2> | template <class T1, class T2> | ||||||
| @@ -312,15 +318,15 @@ void compressed_pair_array_tester<T1, T2>::test(first_param_type p1, second_para | |||||||
|    boost::compressed_pair<T1,T2> cp1; |    boost::compressed_pair<T1,T2> cp1; | ||||||
|    cp1.first()[0] = p1[0]; |    cp1.first()[0] = p1[0]; | ||||||
|    cp1.second()[0] = p2[0]; |    cp1.second()[0] = p2[0]; | ||||||
|    BOOST_CHECK(cp1.first()[0] == p1[0]); |    BOOST_TEST(cp1.first()[0] == p1[0]); | ||||||
|    BOOST_CHECK(cp1.second()[0] == p2[0]); |    BOOST_TEST(cp1.second()[0] == p2[0]); | ||||||
|    // check const members: |    // check const members: | ||||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp1; |    const boost::compressed_pair<T1,T2>& cpr1 = cp1; | ||||||
|    BOOST_CHECK(cpr1.first()[0] == p1[0]); |    BOOST_TEST(cpr1.first()[0] == p1[0]); | ||||||
|    BOOST_CHECK(cpr1.second()[0] == p2[0]); |    BOOST_TEST(cpr1.second()[0] == p2[0]); | ||||||
|  |  | ||||||
|    BOOST_CHECK(sizeof(T1) == sizeof(cp1.first())); |    BOOST_TEST(sizeof(T1) == sizeof(cp1.first())); | ||||||
|    BOOST_CHECK(sizeof(T2) == sizeof(cp1.second())); |    BOOST_TEST(sizeof(T2) == sizeof(cp1.second())); | ||||||
| } | } | ||||||
|  |  | ||||||
| int test_main(int, char *[]) | int test_main(int, char *[]) | ||||||
|   | |||||||
							
								
								
									
										325
									
								
								counting_iterator.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										325
									
								
								counting_iterator.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,325 @@ | |||||||
|  | <html> | ||||||
|  |  | ||||||
|  | <head> | ||||||
|  | <meta http-equiv="Content-Type" content="text/html; charset=windows-1252"> | ||||||
|  | <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> | ||||||
|  | <meta name="ProgId" content="FrontPage.Editor.Document"> | ||||||
|  | <title>Counting Iterator Adaptor Documentation</title> | ||||||
|  | </head> | ||||||
|  |  | ||||||
|  | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  |  | ||||||
|  | <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" | ||||||
|  | align="center" width="277" height="86"> | ||||||
|  |  | ||||||
|  | <h1>Counting Iterator Adaptor</h1> | ||||||
|  |  | ||||||
|  | Defined in header | ||||||
|  | <a href="../../boost/counting_iterator.hpp">boost/counting_iterator.hpp</a> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | How would you fill up a vector with the numbers zero | ||||||
|  | through one hundred using <a | ||||||
|  | href="http://www.sgi.com/tech/stl/copy.html"><tt>std::copy()</tt></a>? The | ||||||
|  | only iterator operation missing from builtin integer types is an | ||||||
|  | <tt>operator*()</tt> that returns the current | ||||||
|  | value of the integer.  The counting iterator adaptor adds this crucial piece of | ||||||
|  | functionality to whatever type it wraps. One can use the | ||||||
|  | counting iterator adaptor not only with integer types, but with any | ||||||
|  | type that is <tt>Incrementable</tt> (see type requirements <a href="#requirements">below</a>).  The | ||||||
|  | following <b>pseudo-code</b> shows the general idea of how the | ||||||
|  | counting iterator is implemented. | ||||||
|  | </p> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  |   // inside a hypothetical counting_iterator class... | ||||||
|  |   typedef Incrementable value_type; | ||||||
|  |   value_type counting_iterator::operator*() const { | ||||||
|  |     return this->base; // no dereference! | ||||||
|  |   } | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | All of the other operators of the counting iterator behave in the same | ||||||
|  | fashion as the <tt>Incrementable</tt> base type. | ||||||
|  |  | ||||||
|  | <h2>Synopsis</h2> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | namespace boost { | ||||||
|  |   template <class Incrementable> | ||||||
|  |   struct <a href="#counting_iterator_traits">counting_iterator_traits</a>; | ||||||
|  |  | ||||||
|  |   template <class Incrementable> | ||||||
|  |   struct <a href="#counting_iterator_generator">counting_iterator_generator</a>; | ||||||
|  |  | ||||||
|  |   template <class Incrementable> | ||||||
|  |   typename counting_iterator_generator<Incrementable>::type | ||||||
|  |   <a href="#make_counting_iterator">make_counting_iterator</a>(Incrementable x); | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  |  | ||||||
|  | <h2><a name="counting_iterator_generator">The Counting Iterator Type | ||||||
|  | Generator</a></h2> | ||||||
|  |  | ||||||
|  | The class template <tt>counting_iterator_generator<Incrementable></tt> is a <a href="../../more/generic_programming.html#type_generator">type generator</a> for counting iterators. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class Incrementable> | ||||||
|  | class counting_iterator_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     typedef <a href="./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...> type; | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <h3>Example</h3> | ||||||
|  |  | ||||||
|  | In this example we use the counting iterator generator to create a | ||||||
|  | counting iterator, and count from zero to four. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <iostream> | ||||||
|  | #include <boost/counting_iterator.hpp> | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   // Example of using counting_iterator_generator | ||||||
|  |   std::cout << "counting from 0 to 4:" << std::endl; | ||||||
|  |   boost::counting_iterator_generator<int>::type first(0), last(4); | ||||||
|  |   std::copy(first, last, std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // to be continued... | ||||||
|  | </pre> | ||||||
|  | The output from this part is: | ||||||
|  | <pre> | ||||||
|  | counting from 0 to 4: | ||||||
|  | 0 1 2 3  | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  | <Table border> | ||||||
|  | <TR> | ||||||
|  | <TH>Parameter</TH><TH>Description</TH> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>Incrementable</tt></TD> | ||||||
|  | <TD>The type being wrapped by the adaptor.</TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | </Table> | ||||||
|  |  | ||||||
|  | <h3>Model of</h3> | ||||||
|  |  | ||||||
|  | If the <tt>Incrementable</tt> type has all of the functionality of a | ||||||
|  | <a href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  | Access Iterator</a> except the <tt>operator*()</tt>, then the counting | ||||||
|  | iterator will be a model of <a | ||||||
|  | href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  | Access Iterator</a>. If the <tt>Incrementable</tt> type has less | ||||||
|  | functionality, then the counting iterator will have correspondingly | ||||||
|  | less functionality. | ||||||
|  |  | ||||||
|  | <h3><a name="requirements">Type Requirements</a></h3> | ||||||
|  |  | ||||||
|  | The <tt>Incrementable</tt> type must be <a | ||||||
|  | href="http://www.sgi.com/tech/stl/DefaultConstructible.html">Default | ||||||
|  | Constructible</a>, <a href="./CopyConstructible.html">Copy | ||||||
|  | Constructible</a>, and <a href="./Assignable.html">Assignable</a>. | ||||||
|  | Also, the <tt>Incrementable</tt> type must provide access to an | ||||||
|  | associated <tt>difference_type</tt> and <tt>iterator_category</tt> | ||||||
|  | through the <a | ||||||
|  | href="#counting_iterator_traits"><tt>counting_iterator_traits</tt></a> | ||||||
|  | class. | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | Furthermore, if you wish to create a counting iterator that is a <a | ||||||
|  | href="http://www.sgi.com/tech/stl/ForwardIterator.html"> Forward | ||||||
|  | Iterator</a>, then the following expressions must be valid: | ||||||
|  | <pre> | ||||||
|  | Incrementable i, j; | ||||||
|  | ++i         // pre-increment | ||||||
|  | i == j      // operator equal | ||||||
|  | </pre> | ||||||
|  | If you wish to create a counting iterator that is a <a | ||||||
|  | href="http://www.sgi.com/tech/stl/BidirectionalIterator.html"> | ||||||
|  | Bidirectional Iterator</a>, then pre-decrement is also required: | ||||||
|  | <pre> | ||||||
|  | --i | ||||||
|  | </pre> | ||||||
|  | If you wish to create a counting iterator that is a <a | ||||||
|  | href="http://www.sgi.com/tech/stl/RandomAccessIterator.html"> Random | ||||||
|  | Access Iterator</a>, then these additional expressions are also required: | ||||||
|  | <pre> | ||||||
|  | <a href="#counting_iterator_traits">counting_iterator_traits</a><Incrementable>::difference_type n; | ||||||
|  | i += n | ||||||
|  | n = i - j | ||||||
|  | i < j | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Members</h3> | ||||||
|  |  | ||||||
|  | The counting iterator type implements the member functions and | ||||||
|  | operators required of the <a | ||||||
|  | href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  | Access Iterator</a> concept. In addition it has the following | ||||||
|  | constructor: | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | counting_iterator_generator::type(const Incrementable& i) | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | <hr> | ||||||
|  | <p> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h2><a name="make_counting_iterator">The Counting Iterator Object Generator</a></h2> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class Incrementable> | ||||||
|  | typename counting_iterator_generator<Incrementable>::type | ||||||
|  | make_counting_iterator(Incrementable base); | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | An <a href="../../more/generic_programming.html#object_generator">object | ||||||
|  | generator</a> function that provides a convenient way to create counting | ||||||
|  | iterators.<p> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Example</h3> | ||||||
|  |  | ||||||
|  | In this example we count from negative five to positive five, this | ||||||
|  | time using the <tt>make_counting_iterator()</tt> function to save some | ||||||
|  | typing. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  |   // continuing from previous example... | ||||||
|  |  | ||||||
|  |   std::cout << "counting from -5 to 4:" << std::endl; | ||||||
|  |   std::copy(boost::make_counting_iterator(-5), | ||||||
|  | 	    boost::make_counting_iterator(5), | ||||||
|  | 	    std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // to be continued... | ||||||
|  | </pre> | ||||||
|  | The output from this part is: | ||||||
|  | <pre> | ||||||
|  | counting from -5 to 4: | ||||||
|  | -5 -4 -3 -2 -1 0 1 2 3 4  | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | In the next example we create an array of numbers, and then create a | ||||||
|  | second array of pointers, where each pointer is the address of a | ||||||
|  | number in the first array. The counting iterator makes it easy to do | ||||||
|  | this since dereferencing a counting iterator that is wrapping an | ||||||
|  | iterator over the array of numbers just returns a pointer to the | ||||||
|  | current location in the array. We then use the <a | ||||||
|  | href="./indirect_iterator.htm">indirect iterator adaptor</a> to print | ||||||
|  | out the number in the array by accessing the numbers through the array | ||||||
|  | of pointers. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  |   // continuing from previous example... | ||||||
|  |  | ||||||
|  |   const int N = 7; | ||||||
|  |   std::vector<int> numbers; | ||||||
|  |   // Fill "numbers" array with [0,N) | ||||||
|  |   std::copy(boost::make_counting_iterator(0), boost::make_counting_iterator(N), | ||||||
|  | 	    std::back_inserter(numbers)); | ||||||
|  |  | ||||||
|  |   std::vector<std::vector<int>::iterator> pointers; | ||||||
|  |  | ||||||
|  |   // Use counting iterator to fill in the array of pointers. | ||||||
|  |   std::copy(boost::make_counting_iterator(numbers.begin()), | ||||||
|  | 	    boost::make_counting_iterator(numbers.end()), | ||||||
|  | 	    std::back_inserter(pointers)); | ||||||
|  |  | ||||||
|  |   // Use indirect iterator to print out numbers by accessing | ||||||
|  |   // them through the array of pointers. | ||||||
|  |   std::cout << "indirectly printing out the numbers from 0 to "  | ||||||
|  | 	    << N << std::endl; | ||||||
|  |   std::copy(boost::make_indirect_iterator(pointers.begin()), | ||||||
|  | 	    boost::make_indirect_iterator(pointers.end()), | ||||||
|  | 	    std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  | </pre> | ||||||
|  | The output is: | ||||||
|  | <pre> | ||||||
|  | indirectly printing out the numbers from 0 to 7 | ||||||
|  | 0 1 2 3 4 5 6  | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  |  | ||||||
|  | <h2><a name="counting_iterator_traits">Counting Iterator Traits</a></h2> | ||||||
|  |  | ||||||
|  | The counting iterator adaptor needs to determine the appropriate | ||||||
|  | <tt>difference_type</tt> and <tt>iterator_category</tt> to use based on the | ||||||
|  | <tt>Incrementable</tt> type supplied by the user.  The | ||||||
|  | <tt>counting_iterator_traits</tt> class provides these types.  If the | ||||||
|  | <tt>Incrementable</tt> type is an integral type or an iterator, these types | ||||||
|  | will be correctly deduced by the <tt>counting_iterator_traits</tt> provided by | ||||||
|  | the library. Otherwise, the user must specialize | ||||||
|  | <tt>counting_iterator_traits</tt> for her type or add nested typedefs to | ||||||
|  | her type to fulfill the needs of | ||||||
|  | <a href="http://www.sgi.com/tech/stl/iterator_traits.html"> | ||||||
|  | <tt>std::iterator_traits</tt></a>. | ||||||
|  |  | ||||||
|  | <p>The following pseudocode describes how the <tt>counting_iterator_traits</tt> are determined: | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class Incrementable> | ||||||
|  | struct counting_iterator_traits | ||||||
|  | { | ||||||
|  |   if (numeric_limits<Incrementable>::is_specialized) { | ||||||
|  |     if (!numeric_limits<Incrementable>::is_integer) | ||||||
|  |        COMPILE_TIME_ERROR; | ||||||
|  |  | ||||||
|  |     if (!numeric_limits<Incrementable>::is_bounded | ||||||
|  |         && numeric_limits<Incrementable>::is_signed) { | ||||||
|  |         typedef Incrementable difference_type; | ||||||
|  |     } | ||||||
|  |     else if (numeric_limits<Incrementable>::is_integral) { | ||||||
|  |         typedef <i>next-larger-signed-type-or-intmax_t</i> difference_type; | ||||||
|  |     } | ||||||
|  |     typedef std::random_access_iterator_tag iterator_category;    | ||||||
|  |   } else { | ||||||
|  |     typedef std::iterator_traits<Incrementable>::difference_type difference_type; | ||||||
|  |     typedef std::iterator_traits<Incrementable>::iterator_category iterator_category; | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <p>The italicized sections above are implementation details, but it is important | ||||||
|  | to know that the <tt>difference_type</tt> for integral types is selected so that | ||||||
|  | it can always represent the difference between two values if such a built-in | ||||||
|  | integer exists. On platforms with a working <tt>std::numeric_limits</tt> | ||||||
|  | implementation, the <tt>difference_type</tt> for any variable-length signed | ||||||
|  | integer type <tt>T</tt> is <tt>T</tt> itself. | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  | <p>Revised <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %b %Y" startspan -->19 Aug 2001<!--webbot bot="Timestamp" endspan i-checksum="14767" --></p> | ||||||
|  | <p><EFBFBD> Copyright Jeremy Siek 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> | ||||||
|  |  | ||||||
|  | </body> | ||||||
|  |  | ||||||
|  | </html> | ||||||
|  | <!--  LocalWords:  html charset alt gif hpp incrementable const namespace htm | ||||||
|  |  --> | ||||||
|  | <!--  LocalWords:  struct  typename iostream int Siek CopyConstructible pre | ||||||
|  |  --> | ||||||
|  |  | ||||||
							
								
								
									
										57
									
								
								counting_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								counting_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | // (C) Copyright Jeremy Siek 2000. 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. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <iostream> | ||||||
|  | #include <iterator> | ||||||
|  | #include <vector> | ||||||
|  | #include <boost/counting_iterator.hpp> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   // Example of using counting_iterator_generator | ||||||
|  |   std::cout << "counting from 0 to 4:" << std::endl; | ||||||
|  |   boost::counting_iterator_generator<int>::type first(0), last(4); | ||||||
|  |   std::copy(first, last, std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // Example of using make_counting_iterator() | ||||||
|  |   std::cout << "counting from -5 to 4:" << std::endl; | ||||||
|  |   std::copy(boost::make_counting_iterator(-5), | ||||||
|  |             boost::make_counting_iterator(5), | ||||||
|  |             std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // Example of using counting iterator to create an array of pointers. | ||||||
|  |   const int N = 7; | ||||||
|  |   std::vector<int> numbers; | ||||||
|  |   // Fill "numbers" array with [0,N) | ||||||
|  |   std::copy(boost::make_counting_iterator(0), boost::make_counting_iterator(N), | ||||||
|  |             std::back_inserter(numbers)); | ||||||
|  |  | ||||||
|  |   std::vector<std::vector<int>::iterator> pointers; | ||||||
|  |  | ||||||
|  |   // Use counting iterator to fill in the array of pointers. | ||||||
|  |   // causes an ICE with MSVC6 | ||||||
|  | #if !defined(BOOST_MSVC) || (BOOST_MSVC > 1200) | ||||||
|  |   std::copy(boost::make_counting_iterator(numbers.begin()), | ||||||
|  |             boost::make_counting_iterator(numbers.end()), | ||||||
|  |             std::back_inserter(pointers)); | ||||||
|  | #endif  | ||||||
|  |  | ||||||
|  | #if !defined(BOOST_MSVC) || (BOOST_MSVC > 1300) | ||||||
|  |   // Use indirect iterator to print out numbers by accessing | ||||||
|  |   // them through the array of pointers. | ||||||
|  |   std::cout << "indirectly printing out the numbers from 0 to "  | ||||||
|  |             << N << std::endl; | ||||||
|  |   std::copy(boost::make_indirect_iterator(pointers.begin()), | ||||||
|  |             boost::make_indirect_iterator(pointers.end()), | ||||||
|  |             std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  | #endif | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -7,9 +7,10 @@ | |||||||
| 	<body bgcolor="white" style="MARGIN-LEFT: 5%; MARGIN-RIGHT: 5%"> | 	<body bgcolor="white" style="MARGIN-LEFT: 5%; MARGIN-RIGHT: 5%"> | ||||||
| 		<table border="0" width="100%"> | 		<table border="0" width="100%"> | ||||||
| 			<tr> | 			<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="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" width="277" height="86"> | ||||||
| 				</td> | 				</td> | ||||||
| 				<td align="center"> | 				<td align="middle"> | ||||||
| 					<h1>current_function.hpp</h1> | 					<h1>current_function.hpp</h1> | ||||||
| 				</td> | 				</td> | ||||||
| 			</tr> | 			</tr> | ||||||
| @@ -29,8 +30,9 @@ | |||||||
| 			function. On such compilers, the string literal has an unspecified value.</p> | 			function. On such compilers, the string literal has an unspecified value.</p> | ||||||
| 		<p> | 		<p> | ||||||
| 			<br> | 			<br> | ||||||
| 			<small>Copyright <20> 2002 by Peter Dimov. Distributed under the Boost Software License, Version  | 			<small>Copyright <20> 2002 by Peter Dimov. Permission to copy, use, modify, sell and  | ||||||
| 				1.0. See accompanying file <A href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</A> or  | 				distribute this document is granted provided this copyright notice appears in  | ||||||
| 				copy at <A href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</A>.</small></p> | 				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> | 	</body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -1,6 +1,4 @@ | |||||||
| #include <boost/config.hpp> | #if defined(_MSC_VER) && !defined(__ICL) | ||||||
|  |  | ||||||
| #if defined(BOOST_MSVC) |  | ||||||
| #pragma warning(disable: 4786)  // identifier truncated in debug info | #pragma warning(disable: 4786)  // identifier truncated in debug info | ||||||
| #pragma warning(disable: 4710)  // function not inlined | #pragma warning(disable: 4710)  // function not inlined | ||||||
| #pragma warning(disable: 4711)  // function selected for automatic inline expansion | #pragma warning(disable: 4711)  // function selected for automatic inline expansion | ||||||
| @@ -12,22 +10,18 @@ | |||||||
| // | // | ||||||
| //  Copyright (c) 2002 Peter Dimov and Multi Media Ltd. | //  Copyright (c) 2002 Peter Dimov and Multi Media Ltd. | ||||||
| // | // | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | //  Permission to copy, use, modify, sell and distribute this software | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | //  is granted provided this copyright notice appears in all copies. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | //  This software is provided "as is" without express or implied | ||||||
|  | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include <boost/current_function.hpp> | #include <boost/current_function.hpp> | ||||||
| #include <boost/config.hpp> |  | ||||||
| #include <cstdio> | #include <cstdio> | ||||||
|  |  | ||||||
| void message(char const * file, long line, char const * func, char const * msg) | void message(char const * file, long line, char const * func, char const * msg) | ||||||
| { | { | ||||||
| #if !defined(BOOST_NO_STDC_NAMESPACE) |     std::printf("%s(%ld): %s in function '%s'\n", file, line, msg, func); | ||||||
|     using std::printf; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|     printf("%s(%ld): %s in function '%s'\n", file, line, msg, func); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| #define MESSAGE(msg) message(__FILE__, __LINE__, BOOST_CURRENT_FUNCTION, msg) | #define MESSAGE(msg) message(__FILE__, __LINE__, BOOST_CURRENT_FUNCTION, msg) | ||||||
| @@ -35,6 +29,4 @@ void message(char const * file, long line, char const * func, char const * msg) | |||||||
| int main() | int main() | ||||||
| { | { | ||||||
|     MESSAGE("assertion failed"); |     MESSAGE("assertion failed"); | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										389
									
								
								enable_if.html
									
									
									
									
									
								
							
							
						
						
									
										389
									
								
								enable_if.html
									
									
									
									
									
								
							| @@ -1,389 +0,0 @@ | |||||||
| <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" |  | ||||||
|             "http://www.w3.org/TR/REC-html40/loose.dtd"> |  | ||||||
| <HTML> |  | ||||||
| <HEAD><TITLE>enable_if</TITLE> |  | ||||||
|  |  | ||||||
| <META http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> |  | ||||||
| <META name="GENERATOR" content="Microsoft FrontPage 5.0"> |  | ||||||
| </HEAD> |  | ||||||
| <BODY > |  | ||||||
| <!--HEVEA command line is: hevea -nosymb -noiso -pedantic -v enable_if_docs_for_boost.tex --> |  | ||||||
| <!--HTMLHEAD--> |  | ||||||
| <!--ENDHTML--> |  | ||||||
| <!--PREFIX <ARG ></ARG>--> |  | ||||||
| <!--CUT DEF section 1 --> |  | ||||||
| <BR> |  | ||||||
| <BR> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <h1> |  | ||||||
| <img border="0" src="../../boost.png" align="center" width="277" height="86">enable_if</h1> |  | ||||||
| <BR> |  | ||||||
| <BR> |  | ||||||
| Copyright 2003 Jaakko Järvi, Jeremiah Willcock, Andrew Lumsdaine.<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC section Introduction--> |  | ||||||
|  |  | ||||||
| <H2><A NAME="htoc1">1</A>  Introduction</H2><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="introduction"></A> |  | ||||||
| The <TT>enable_if</TT> family of templates is a set of tools to allow a function template or a class template specialization  |  | ||||||
| to include or exclude itself from a set of matching functions or specializations |  | ||||||
| based on properties of its template arguments.  |  | ||||||
| For example, one can define function templates that |  | ||||||
| are only enabled for, and thus only match, an arbitrary set of types |  | ||||||
| defined by a traits class. The <TT>enable_if</TT> templates can also be |  | ||||||
| applied to enable class template specializations. Applications of |  | ||||||
| <TT>enable_if</TT> are discussed in length |  | ||||||
| in [<A HREF="#jarvi:03:cuj_arbitrary_overloading"><CITE>1</CITE></A>] and [<A HREF="#jarvi:03:c++typeclasses"><CITE>2</CITE></A>].<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC subsection Synopsis--> |  | ||||||
|  |  | ||||||
| <H3><A NAME="htoc2">1.1</A>  Synopsis</H3><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="sec:synopsis"></A> |  | ||||||
| <PRE>namespace boost { |  | ||||||
|   template <class Cond, class T = void> struct enable_if; |  | ||||||
|   template <class Cond, class T = void> struct disable_if; |  | ||||||
|   template <class Cond, class T> struct lazy_enable_if; |  | ||||||
|   template <class Cond, class T> struct lazy_disable_if; |  | ||||||
|  |  | ||||||
|   template <bool B, class T = void> struct enable_if_c; |  | ||||||
|   template <bool B, class T = void> struct disable_if_c; |  | ||||||
|   template <bool B, class T> struct lazy_enable_if_c; |  | ||||||
|   template <bool B, class T> struct lazy_disable_if_c; |  | ||||||
| } |  | ||||||
| </PRE> |  | ||||||
| <!--TOC subsection Background--> |  | ||||||
|  |  | ||||||
| <H3><A NAME="htoc3">1.2</A>  Background</H3><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="sec:background"></A> |  | ||||||
| Sensible operation of template function overloading in C++ relies |  | ||||||
| on the <EM>SFINAE</EM> (substitution-failure-is-not-an-error) |  | ||||||
| principle [<A HREF="#vandevoorde2002:templates"><CITE>3</CITE></A>]: if an invalid argument |  | ||||||
| or return type is formed during the instantiation of a function |  | ||||||
| template, the instantiation is removed from the overload resolution |  | ||||||
| set instead of causing a compilation error. The following example,  |  | ||||||
| taken from [<A HREF="#jarvi:03:cuj_arbitrary_overloading"><CITE>1</CITE></A>], |  | ||||||
| demonstrates why this is important: |  | ||||||
| <PRE>int negate(int i) { return -i; } |  | ||||||
|  |  | ||||||
| template <class F> |  | ||||||
| typename F::result_type negate(const F& f) { return -f(); } |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| Suppose the compiler encounters the call <TT>negate(1)</TT>. The first |  | ||||||
| definition is obviously a better match, but the compiler must |  | ||||||
| nevertheless consider (and instantiate the prototypes) of both |  | ||||||
| definitions to find this out. Instantiating the latter definition with |  | ||||||
| <TT>F</TT> as <TT>int</TT> would result in: |  | ||||||
| <PRE>int::result_type negate(const int&); |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| where the return type is invalid. If this was an error, adding an unrelated function template  |  | ||||||
| (that was never called) could break otherwise valid code. |  | ||||||
| Due to the SFINAE principle the above example is not, however, erroneous.  |  | ||||||
| The latter definition of <TT>negate</TT> is simply removed from the overload resolution set.<BR> |  | ||||||
| <BR> |  | ||||||
| The <TT>enable_if</TT> templates are tools for controlled creation of the SFINAE |  | ||||||
| conditions.<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC section The <TT>enable_if</TT> templates--> |  | ||||||
|  |  | ||||||
| <H2><A NAME="htoc4">2</A>  The <TT>enable_if</TT> templates</H2><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="enable_if"></A> |  | ||||||
| The names of the <TT>enable_if</TT> templates have three parts: an optional <TT>lazy_</TT> tag,  |  | ||||||
| either <TT>enable_if</TT> or <TT>disable_if</TT>, and an optional <TT>_c</TT> tag. |  | ||||||
| All eight combinations of these parts are supported. |  | ||||||
| The meaning of the <TT>lazy_</TT> tag is described in Section <A HREF="#sec:enable_if_lazy">3.3</A>. |  | ||||||
| The second part of the name indicates whether a true condition argument should  |  | ||||||
| enable or disable the current overload. |  | ||||||
| The third part of the name indicates whether the condition argument is a <TT>bool</TT> value  |  | ||||||
| (<TT>_c</TT> suffix), or a type containing a static <TT>bool</TT> constant named <TT>value</TT> (no suffix). |  | ||||||
| The latter version interoperates with Boost.MPL. <BR> |  | ||||||
| <BR> |  | ||||||
| The definitions of <TT>enable_if_c</TT> and <TT>enable_if</TT> are as follows (we use <TT>enable_if</TT> templates  |  | ||||||
| unqualified but they are in the <TT>boost</TT> namespace). |  | ||||||
| <PRE>template <bool B, class T = void> |  | ||||||
| struct enable_if_c { |  | ||||||
|   typedef T type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct enable_if_c<false, T> {}; |  | ||||||
|  |  | ||||||
| template <class Cond, class T = void> |  | ||||||
| struct enable_if : public enable_if_c<Cond::value, T> {}; |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| An instantiation of the <TT>enable_if_c</TT> template with the parameter |  | ||||||
| <TT>B</TT> as <TT>true</TT> contains a member type <TT>type</TT>, defined |  | ||||||
| to be <TT>T</TT>. If <TT>B</TT> is |  | ||||||
| <TT>false</TT>, no such member is defined. Thus  |  | ||||||
| <TT>enable_if_c<B, T>::type</TT> is either a valid or an invalid type |  | ||||||
| expression, depending on the value of <TT>B</TT>. |  | ||||||
| When valid, <TT>enable_if_c<B, T>::type</TT> equals <TT>T</TT>. |  | ||||||
| The <TT>enable_if_c</TT> template can thus be used for controlling when functions are considered for |  | ||||||
| overload resolution and when they are not.  |  | ||||||
| For example, the following function is defined for all arithmetic types (according to the |  | ||||||
| classification of the <A HREF="../type_traits/index.html">Boost type_traits library</A>): |  | ||||||
| <PRE>template <class T> |  | ||||||
| typename enable_if_c<boost::is_arithmetic<T>::value, T>::type  |  | ||||||
| foo(T t) { return t; } |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| The <TT>disable_if_c</TT> template is provided as well, and has the |  | ||||||
| same functionality as <TT>enable_if_c</TT> except for the negated condition. The following |  | ||||||
| function is enabled for all non-arithmetic types. |  | ||||||
| <PRE>template <class T> |  | ||||||
| typename disable_if_c<boost::is_arithmetic<T>::value, T>::type  |  | ||||||
| bar(T t) { return t; } |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| For easier syntax in some cases and interoperation with Boost.MPL we provide versions of |  | ||||||
| the <TT>enable_if</TT> templates taking any type with a <TT>bool</TT> member constant named  |  | ||||||
| <TT>value</TT> as the condition argument. |  | ||||||
| The MPL <TT>bool_</TT>, <TT>and_</TT>, <TT>or_</TT>, and <TT>not_</TT> templates are likely to be  |  | ||||||
| useful for creating such types. Also, the traits classes in the Boost.Type_traits library  |  | ||||||
| follow this convention.  |  | ||||||
| For example, the above example function <TT>foo</TT> can be alternatively written as: |  | ||||||
| <PRE>template <class T> |  | ||||||
| typename enable_if<boost::is_arithmetic<T>, T>::type  |  | ||||||
| foo(T t) { return t; } |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| <!--TOC section Using <TT>enable_if</TT>--> |  | ||||||
|  |  | ||||||
| <H2><A NAME="htoc5">3</A>  Using <TT>enable_if</TT></H2><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="sec:using_enable_if"></A> |  | ||||||
| The <TT>enable_if</TT> templates are defined in |  | ||||||
| <TT>boost/utility/enable_if.hpp</TT>, which is included by <TT>boost/utility.hpp</TT>.<BR> |  | ||||||
| <BR> |  | ||||||
| The <TT>enable_if</TT> template can be used either as the return type, or as an  |  | ||||||
| extra argument. For example, the <TT>foo</TT> function in the previous section could also be written |  | ||||||
| as: |  | ||||||
| <PRE>template <class T> |  | ||||||
| T foo(T t, typename enable_if<boost::is_arithmetic<T> >::type* dummy = 0);  |  | ||||||
|  |  | ||||||
| </PRE>Hence, an extra parameter of type <TT>void*</TT> is added, but it is given  |  | ||||||
| a default value to keep the parameter hidden from client code. |  | ||||||
| Note that the second template argument was not given to <TT>enable_if</TT>, as the default  |  | ||||||
| <TT>void</TT> gives the desired behavior.<BR> |  | ||||||
| <BR> |  | ||||||
| Whether to write the enabler as an argument or within the return type is |  | ||||||
| largely a matter of taste, but for certain functions, only one |  | ||||||
| alternative is possible: |  | ||||||
| <UL><LI> |  | ||||||
| Operators have a fixed number of arguments, thus <TT>enable_if</TT> must be used in the return type. |  | ||||||
| <LI>Constructors and destructors do not have a return type; an extra argument is the only option. |  | ||||||
| <LI>There does not seem to be a way to specify an enabler for a conversion operator. Converting constructors, |  | ||||||
| however, can have enablers as extra default arguments. |  | ||||||
| </UL> |  | ||||||
| <!--TOC subsection Enabling template class specializations--> |  | ||||||
|  |  | ||||||
| <H3><A NAME="htoc6">3.1</A>  Enabling template class specializations</H3><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="sec:enable_if_classes"></A> |  | ||||||
| Class template specializations can be enabled or disabled with <TT>enable_if</TT>. |  | ||||||
| One extra template parameter needs to be added for the enabler expressions. |  | ||||||
| This parameter has the default value <TT>void</TT>. |  | ||||||
| For example: |  | ||||||
| <PRE>template <class T, class Enable = void>  |  | ||||||
| class A { ... }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| class A<T, typename enable_if<is_integral<T> >::type> { ... }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| class A<T, typename enable_if<is_float<T> >::type> { ... }; |  | ||||||
|  |  | ||||||
| </PRE>Instantiating <TT>A</TT> with any integral type matches the first specialization, |  | ||||||
| whereas any floating point type matches the second one. All other types |  | ||||||
| match the primary template. |  | ||||||
| The condition can be any compile-time boolean expression that depends on the  |  | ||||||
| template arguments of the class. |  | ||||||
| Note that again, the second argument to <TT>enable_if</TT> is not needed; the default (<TT>void</TT>)  |  | ||||||
| is the correct value.<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC subsection Overlapping enabler conditions--> |  | ||||||
|  |  | ||||||
| <H3><A NAME="htoc7">3.2</A>  Overlapping enabler conditions</H3><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="sec:overlapping_conditions"></A> |  | ||||||
| Once the compiler has examined the enabling conditions and included the |  | ||||||
| function into the overload resolution set, normal C++ overload resolution  |  | ||||||
| rules are used to select the best matching function. |  | ||||||
| In particular, there is no ordering between enabling conditions. |  | ||||||
| Function templates with enabling conditions that are not mutually exclusive can  |  | ||||||
| lead to ambiguities. For example: |  | ||||||
| <PRE>template <class T> |  | ||||||
| typename enable_if<boost::is_integral<T>, void>::type  |  | ||||||
| foo(T t) {} |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| typename enable_if<boost::is_arithmetic<T>, void>::type  |  | ||||||
| foo(T t) {} |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| All integral types are also arithmetic. Therefore, say, for the call <TT>foo(1)</TT>, |  | ||||||
| both conditions are true and both functions are thus in the overload resolution set. |  | ||||||
| They are both equally good matches and thus ambiguous. |  | ||||||
| Of course, more than one enabling condition can be simultaneously true as long as  |  | ||||||
| other arguments disambiguate the functions.<BR> |  | ||||||
| <BR> |  | ||||||
| The above discussion applies to using <TT>enable_if</TT> in class template |  | ||||||
| partial specializations as well.<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC subsection Lazy <TT>enable_if</TT>--> |  | ||||||
|  |  | ||||||
| <H3><A NAME="htoc8">3.3</A>  Lazy <TT>enable_if</TT></H3><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="sec:enable_if_lazy"></A> |  | ||||||
| In some cases it is necessary to avoid instantiating part of a |  | ||||||
| function signature unless an enabling condition is true. For example: |  | ||||||
| <PRE>template <class T, class U> class mult_traits; |  | ||||||
|  |  | ||||||
| template <class T, class U> |  | ||||||
| typename enable_if<is_multipliable<T, U>, typename mult_traits<T, U>::type>::type |  | ||||||
| operator*(const T& t, const U& u) { ... } |  | ||||||
|  |  | ||||||
| </PRE>Assume the class template <TT>mult_traits</TT> is a traits class defining  |  | ||||||
| the resulting type of a multiplication operator. The <TT>is_multipliable</TT> traits |  | ||||||
| class specifies for which types to enable the operator. Whenever |  | ||||||
| <TT>is_multipliable<A, B>::value</TT> is <TT>true</TT> for some types <TT>A</TT> and <TT>B</TT>, |  | ||||||
| then <TT>mult_traits<A, B>::type</TT> is defined.<BR> |  | ||||||
| <BR> |  | ||||||
| Now, trying to invoke (some other overload) of <TT>operator*</TT> with, say, operand types <TT>C</TT> and <TT>D</TT>  |  | ||||||
| for which <TT>is_multipliable<C, D>::value</TT> is <TT>false</TT>  |  | ||||||
| and <TT>mult_traits<C, D>::type</TT> is not defined is an error on some compilers.  |  | ||||||
| The SFINAE principle is not applied because |  | ||||||
| the invalid type occurs as an argument to another template. The <TT>lazy_enable_if</TT>  |  | ||||||
| and <TT>lazy_disable_if</TT> templates (and their <TT>_c</TT> versions) can be used in such |  | ||||||
| situations: |  | ||||||
| <PRE>template<class T, class U> |  | ||||||
| typename lazy_enable_if<is_multipliable<T, U>, mult_traits<T, U> >::type |  | ||||||
| operator*(const T& t, const U& u) { ... } |  | ||||||
|  |  | ||||||
| </PRE>The second argument of <TT>lazy_enable_if</TT> must be a class type |  | ||||||
| that defines a nested type named <TT>type</TT> whenever the first |  | ||||||
| parameter (the condition) is true.<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC paragraph Note--> |  | ||||||
|  |  | ||||||
| <H5>Note</H5><!--SEC END --> |  | ||||||
|  |  | ||||||
| Referring to one member type or static constant in a traits class |  | ||||||
| causes all of the members (type and static constant) of that |  | ||||||
| specialization to be instantiated. Therefore, if your traits classes |  | ||||||
| can sometimes contain invalid types, you should use two distinct |  | ||||||
| templates for describing the conditions and the type mappings. In the |  | ||||||
| above example, <TT>is_multipliable<T, U>::value</TT> defines when |  | ||||||
| <TT>mult_traits<T, U>::type</TT> is valid.<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC subsection Compiler workarounds--> |  | ||||||
|  |  | ||||||
| <H3><A NAME="htoc9">3.4</A>  Compiler workarounds</H3><!--SEC END --> |  | ||||||
|  |  | ||||||
| <A NAME="sec:workarounds"></A> |  | ||||||
| Some compilers flag functions as ambiguous if the only distinguishing factor is a different  |  | ||||||
| condition in an enabler (even though the functions could never be ambiguous). For example, |  | ||||||
| some compilers (e.g. GCC 3.2) diagnose the following two functions as ambiguous: |  | ||||||
| <PRE>template <class T> |  | ||||||
| typename enable_if<boost::is_arithmetic<T>, T>::type  |  | ||||||
| foo(T t); |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| typename disable_if<boost::is_arithmetic<T>, T>::type  |  | ||||||
| foo(T t); |  | ||||||
|  |  | ||||||
| </PRE>Two workarounds can be applied: |  | ||||||
| <UL><LI> |  | ||||||
| Use an extra dummy parameter which disambiguates the functions. Use a default value for |  | ||||||
| it to hide the parameter from the caller. For example: |  | ||||||
| <PRE>template <int> struct dummy { dummy(int) {} }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| typename enable_if<boost::is_arithmetic<T>, T>::type  |  | ||||||
| foo(T t, dummy<0> = 0); |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| typename disable_if<boost::is_arithmetic<T>, T>::type  |  | ||||||
| foo(T t, dummy<1> = 0); |  | ||||||
| </PRE><BR> |  | ||||||
| <BR> |  | ||||||
| <LI>Define the functions in different namespaces and bring them into a common |  | ||||||
| namespace with <TT>using</TT> declarations: |  | ||||||
| <PRE>namespace A { |  | ||||||
|   template <class T> |  | ||||||
|   typename enable_if<boost::is_arithmetic<T>, T>::type  |  | ||||||
|   foo(T t); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| namespace B { |  | ||||||
|   template <class T> |  | ||||||
|   typename disable_if<boost::is_arithmetic<T>, T>::type  |  | ||||||
|   foo(T t); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| using A::foo; |  | ||||||
| using B::foo; |  | ||||||
|  |  | ||||||
| </PRE> |  | ||||||
| Note that the second workaround above cannot be used for member |  | ||||||
| templates. On the other hand, operators do not accept extra arguments, |  | ||||||
| which makes the first workaround unusable. As the net effect, |  | ||||||
| neither of the workarounds are of assistance for templated operators that |  | ||||||
| need to be defined as member functions (assignment and |  | ||||||
| subscript operators). |  | ||||||
| </UL> |  | ||||||
| <!--TOC section Acknowledgements--> |  | ||||||
|  |  | ||||||
| <H2><A NAME="htoc10">4</A>  Acknowledgements</H2><!--SEC END --> |  | ||||||
|  |  | ||||||
| We are grateful to Howard Hinnant, Jason Shirk, Paul Mensonides, and Richard |  | ||||||
| Smith whose findings have influenced the library.<BR> |  | ||||||
| <BR> |  | ||||||
| <!--TOC section References--> |  | ||||||
|  |  | ||||||
| <H2>References</H2><!--SEC END --> |  | ||||||
| <DL COMPACT=compact><DT><A NAME="jarvi:03:cuj_arbitrary_overloading"><FONT COLOR=purple>[1]</FONT></A><DD> |  | ||||||
| Jaakko Järvi, Jeremiah Willcock, Howard Hinnant, and Andrew Lumsdaine. |  | ||||||
| Function overloading based on arbitrary properties of types. |  | ||||||
| <EM>C/C++ Users Journal</EM>, 21(6):25--32, June 2003.<BR> |  | ||||||
| <BR> |  | ||||||
| <DT><A NAME="jarvi:03:c++typeclasses"><FONT COLOR=purple>[2]</FONT></A><DD> |  | ||||||
| Jaakko Järvi, Jeremiah Willcock, and Andrew Lumsdaine. |  | ||||||
| Concept-controlled polymorphism. |  | ||||||
| In Frank Pfennig and Yannis Smaragdakis, editors, <EM>Generative |  | ||||||
|  Programming and Component Engineering</EM>, volume 2830 of <EM>LNCS</EM>, pages |  | ||||||
|  228--244. Springer Verlag, September 2003.<BR> |  | ||||||
| <BR> |  | ||||||
| <DT><A NAME="vandevoorde2002:templates"><FONT COLOR=purple>[3]</FONT></A><DD> |  | ||||||
| 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> |  | ||||||
| <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> |  | ||||||
| <!--HTMLFOOT--> |  | ||||||
| <!--ENDHTML--> |  | ||||||
| <!--FOOTER--> |  | ||||||
| <HR SIZE=2> |  | ||||||
| <BLOCKQUOTE><EM>This document was translated from L<sup>A</sup>T<sub>E</sub>X by |  | ||||||
| </EM><A HREF="http://pauillac.inria.fr/~maranget/hevea/index.html"><EM>H<FONT SIZE=2><sup>E</sup></FONT>V<FONT SIZE=2><sup>E</sup></FONT>A</EM></A><EM>. |  | ||||||
| </EM></BLOCKQUOTE> |  | ||||||
| </BODY> |  | ||||||
| </HTML> |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| # 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/ |  | ||||||
|  |  | ||||||
| project |  | ||||||
|     : requirements <library>/boost/test//boost_test_exec_monitor |  | ||||||
|     ; |  | ||||||
|  |  | ||||||
| test-suite utility/enable_if |  | ||||||
|         : |  | ||||||
|         [ run constructors.cpp ] |  | ||||||
|         [ run dummy_arg_disambiguation.cpp ] |  | ||||||
|         [ run lazy.cpp ] |  | ||||||
|         [ run lazy_test.cpp ] |  | ||||||
|         [ run member_templates.cpp ] |  | ||||||
|         [ run namespace_disambiguation.cpp ] |  | ||||||
|         [ run no_disambiguation.cpp ] |  | ||||||
|         [ run partial_specializations.cpp ] |  | ||||||
|     ; |  | ||||||
|  |  | ||||||
| @@ -1,62 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits.hpp> |  | ||||||
|  |  | ||||||
| using boost::enable_if; |  | ||||||
| using boost::disable_if; |  | ||||||
| using boost::is_arithmetic; |  | ||||||
|  |  | ||||||
| struct container { |  | ||||||
|   bool my_value; |  | ||||||
|  |  | ||||||
|   template <class T> |  | ||||||
|   container(const T&, const typename enable_if<is_arithmetic<T>, T>::type * = 0): |  | ||||||
|   my_value(true) {} |  | ||||||
|  |  | ||||||
|   template <class T> |  | ||||||
|   container(const T&, const typename disable_if<is_arithmetic<T>, T>::type * = 0): |  | ||||||
|   my_value(false) {} |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| // example from Howard Hinnant (tests enable_if template members of a templated class) |  | ||||||
| template <class charT> |  | ||||||
| struct xstring |  | ||||||
| { |  | ||||||
|   template <class It> |  | ||||||
|   xstring(It begin, It end, typename  |  | ||||||
|           disable_if<is_arithmetic<It> >::type* = 0) |  | ||||||
|     : data(end-begin) {} |  | ||||||
|    |  | ||||||
|   int data; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|   |  | ||||||
|   BOOST_CHECK(container(1).my_value); |  | ||||||
|   BOOST_CHECK(container(1.0).my_value); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!container("1").my_value);   |  | ||||||
|   BOOST_CHECK(!container(static_cast<void*>(0)).my_value);   |  | ||||||
|  |  | ||||||
|   char sa[] = "123456"; |  | ||||||
|   BOOST_CHECK(xstring<char>(sa, sa+6).data == 6); |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,46 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits/is_arithmetic.hpp> |  | ||||||
|  |  | ||||||
| using boost::enable_if; |  | ||||||
| using boost::disable_if; |  | ||||||
| using boost::is_arithmetic; |  | ||||||
|  |  | ||||||
| template <int N> struct dummy { |  | ||||||
|   dummy(int) {}; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template<class T> |  | ||||||
| typename enable_if<is_arithmetic<T>, bool>::type |  | ||||||
| arithmetic_object(T t, dummy<0> = 0) { return true; } |  | ||||||
|  |  | ||||||
| template<class T> |  | ||||||
| typename disable_if<is_arithmetic<T>, bool>::type |  | ||||||
| arithmetic_object(T t, dummy<1> = 0) { return false; } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|   |  | ||||||
|   BOOST_CHECK(arithmetic_object(1)); |  | ||||||
|   BOOST_CHECK(arithmetic_object(1.0)); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!arithmetic_object("1"));   |  | ||||||
|   BOOST_CHECK(!arithmetic_object(static_cast<void*>(0)));   |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,82 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits/is_same.hpp> |  | ||||||
|  |  | ||||||
| using boost::enable_if_c; |  | ||||||
| using boost::lazy_enable_if_c; |  | ||||||
|  |  | ||||||
| // This class provides a reduced example of a traits class for |  | ||||||
| // computing the result of multiplying two types.  The member typedef |  | ||||||
| // 'type' in this traits class defines the return type of this |  | ||||||
| // operator.  The return type member is invalid unless both arguments |  | ||||||
| // for mult_traits are values that mult_traits expects (ints in this |  | ||||||
| // case).  This kind of situation may arise if a traits class only |  | ||||||
| // makes sense for some set of types, not all C++ types. |  | ||||||
|  |  | ||||||
| template <class T> struct is_int { |  | ||||||
|   BOOST_STATIC_CONSTANT(bool, value = (boost::is_same<T, int>::value)); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class T, class U> |  | ||||||
| struct mult_traits { |  | ||||||
|   typedef typename T::does_not_exist type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <> |  | ||||||
| struct mult_traits<int, int> { |  | ||||||
|   typedef int type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // Next, a forwarding function mult() is defined.  It is enabled only |  | ||||||
| // when both arguments are of type int.  The first version, using |  | ||||||
| // non-lazy enable_if_c does not work. |  | ||||||
|  |  | ||||||
| #if 0 |  | ||||||
| template <class T, class U> |  | ||||||
| typename enable_if_c< |  | ||||||
|   is_int<T>::value && is_int<U>::value, |  | ||||||
|   typename mult_traits<T, U>::type |  | ||||||
| >::type |  | ||||||
| mult(const T& x, const U& y) {return x * y;} |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| // A correct version uses lazy_enable_if_c. |  | ||||||
| // This template removes compiler errors from invalid code used as an |  | ||||||
| // argument to enable_if_c. |  | ||||||
|  |  | ||||||
| #if 1 |  | ||||||
| template <class T, class U> |  | ||||||
| typename lazy_enable_if_c< |  | ||||||
|   is_int<T>::value & is_int<U>::value, |  | ||||||
|   mult_traits<T, U>  |  | ||||||
| >::type |  | ||||||
| mult(const T& x, const U& y) {return x * y;} |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| double mult(int i, double d) { return (double)i * d; } |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(mult(1, 2) == 2); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(mult(1, 3.0) == 3.0); |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,100 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| // Testing all variations of lazy_enable_if. |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
| #include <boost/mpl/not.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits/is_same.hpp> |  | ||||||
|  |  | ||||||
| using boost::lazy_enable_if; |  | ||||||
| using boost::lazy_disable_if; |  | ||||||
|  |  | ||||||
| using boost::lazy_enable_if_c; |  | ||||||
| using boost::lazy_disable_if_c; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct is_int_or_double { |  | ||||||
|   BOOST_STATIC_CONSTANT(bool,  |  | ||||||
|     value = (boost::is_same<T, int>::value ||  |  | ||||||
|              boost::is_same<T, double>::value)); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct some_traits { |  | ||||||
|   typedef typename T::does_not_exist type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <> |  | ||||||
| struct some_traits<int> { |  | ||||||
|   typedef bool type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <> |  | ||||||
| struct some_traits<double> { |  | ||||||
|   typedef bool type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct make_bool { |  | ||||||
|   typedef bool type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <> |  | ||||||
| struct make_bool<int> {}; |  | ||||||
|  |  | ||||||
| template <> |  | ||||||
| struct make_bool<double> {}; |  | ||||||
|  |  | ||||||
| namespace A { |  | ||||||
|  |  | ||||||
|   template<class T> |  | ||||||
|   typename lazy_enable_if<is_int_or_double<T>, some_traits<T> >::type |  | ||||||
|   foo(T t) { return true; } |  | ||||||
|  |  | ||||||
|   template<class T> |  | ||||||
|   typename lazy_enable_if_c<is_int_or_double<T>::value, some_traits<T> >::type |  | ||||||
|   foo2(T t) { return true; } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| namespace B { |  | ||||||
|   template<class T> |  | ||||||
|   typename lazy_disable_if<is_int_or_double<T>, make_bool<T> >::type |  | ||||||
|   foo(T t) { return false; } |  | ||||||
|  |  | ||||||
|   template<class T> |  | ||||||
|   typename lazy_disable_if_c<is_int_or_double<T>::value, make_bool<T> >::type |  | ||||||
|   foo2(T t) { return false; } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|   using namespace A; |  | ||||||
|   using namespace B; |  | ||||||
|   BOOST_CHECK(foo(1)); |  | ||||||
|   BOOST_CHECK(foo(1.0)); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!foo("1"));   |  | ||||||
|   BOOST_CHECK(!foo(static_cast<void*>(0)));   |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(foo2(1)); |  | ||||||
|   BOOST_CHECK(foo2(1.0)); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!foo2("1"));   |  | ||||||
|   BOOST_CHECK(!foo2(static_cast<void*>(0)));   |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,43 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits/is_arithmetic.hpp> |  | ||||||
|  |  | ||||||
| using boost::enable_if; |  | ||||||
| using boost::disable_if; |  | ||||||
| using boost::is_arithmetic; |  | ||||||
|  |  | ||||||
| struct container { |  | ||||||
|   template <class T> |  | ||||||
|   typename enable_if<is_arithmetic<T>, bool>::type |  | ||||||
|   arithmetic_object(const T&, const int* /* disambiguate */ = 0) {return true;} |  | ||||||
|  |  | ||||||
|   template <class T> |  | ||||||
|   typename disable_if<is_arithmetic<T>, bool>::type |  | ||||||
|   arithmetic_object(const T&) {return false;} |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|   |  | ||||||
|   BOOST_CHECK(container().arithmetic_object(1)); |  | ||||||
|   BOOST_CHECK(container().arithmetic_object(1.0)); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!container().arithmetic_object("1"));   |  | ||||||
|   BOOST_CHECK(!container().arithmetic_object(static_cast<void*>(0)));   |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,47 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
| #include <boost/mpl/not.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits/is_arithmetic.hpp> |  | ||||||
|  |  | ||||||
| using boost::enable_if; |  | ||||||
| using boost::mpl::not_; |  | ||||||
| using boost::is_arithmetic; |  | ||||||
|  |  | ||||||
| namespace A { |  | ||||||
|   template<class T> |  | ||||||
|   typename enable_if<is_arithmetic<T>, bool>::type |  | ||||||
|   arithmetic_object(T t) { return true; } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| namespace B { |  | ||||||
|   template<class T> |  | ||||||
|   typename enable_if<not_<is_arithmetic<T> >, bool>::type |  | ||||||
|   arithmetic_object(T t) { return false; } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|   using namespace A; |  | ||||||
|   using namespace B; |  | ||||||
|   BOOST_CHECK(arithmetic_object(1)); |  | ||||||
|   BOOST_CHECK(arithmetic_object(1.0)); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!arithmetic_object("1"));   |  | ||||||
|   BOOST_CHECK(!arithmetic_object(static_cast<void*>(0)));   |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,43 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
| #include <boost/mpl/not.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits/is_arithmetic.hpp> |  | ||||||
|  |  | ||||||
| using boost::mpl::not_; |  | ||||||
| using boost::enable_if; |  | ||||||
| using boost::is_arithmetic; |  | ||||||
|  |  | ||||||
| template<class T> |  | ||||||
| typename enable_if<is_arithmetic<T>, bool>::type |  | ||||||
| arithmetic_object(T t) { return true; } |  | ||||||
|  |  | ||||||
| template<class T> |  | ||||||
| typename enable_if<not_<is_arithmetic<T> >, bool>::type |  | ||||||
| arithmetic_object(T t) { return false; } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|   |  | ||||||
|   BOOST_CHECK(arithmetic_object(1)); |  | ||||||
|   BOOST_CHECK(arithmetic_object(1.0)); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!arithmetic_object("1"));   |  | ||||||
|   BOOST_CHECK(!arithmetic_object(static_cast<void*>(0)));   |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,67 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
| #include <boost/test/minimal.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/type_traits/is_arithmetic.hpp> |  | ||||||
|  |  | ||||||
| using boost::enable_if_c; |  | ||||||
| using boost::disable_if_c; |  | ||||||
| using boost::enable_if; |  | ||||||
| using boost::disable_if; |  | ||||||
| using boost::is_arithmetic; |  | ||||||
|  |  | ||||||
| template <class T, class Enable = void> |  | ||||||
| struct tester; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct tester<T, typename enable_if_c<is_arithmetic<T>::value>::type> { |  | ||||||
|   BOOST_STATIC_CONSTANT(bool, value = true); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct tester<T, typename disable_if_c<is_arithmetic<T>::value>::type> { |  | ||||||
|   BOOST_STATIC_CONSTANT(bool, value = false); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class T, class Enable = void> |  | ||||||
| struct tester2; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct tester2<T, typename enable_if<is_arithmetic<T> >::type> { |  | ||||||
|   BOOST_STATIC_CONSTANT(bool, value = true); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template <class T> |  | ||||||
| struct tester2<T, typename disable_if<is_arithmetic<T> >::type> { |  | ||||||
|   BOOST_STATIC_CONSTANT(bool, value = false); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| int test_main(int, char*[]) |  | ||||||
| { |  | ||||||
|   |  | ||||||
|   BOOST_CHECK(tester<int>::value); |  | ||||||
|   BOOST_CHECK(tester<double>::value); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!tester<char*>::value); |  | ||||||
|   BOOST_CHECK(!tester<void*>::value); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(tester2<int>::value); |  | ||||||
|   BOOST_CHECK(tester2<double>::value); |  | ||||||
|  |  | ||||||
|   BOOST_CHECK(!tester2<char*>::value); |  | ||||||
|   BOOST_CHECK(!tester2<void*>::value); |  | ||||||
|  |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
							
								
								
									
										273
									
								
								filter_iterator.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										273
									
								
								filter_iterator.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,273 @@ | |||||||
|  | <html> | ||||||
|  |  | ||||||
|  | <head> | ||||||
|  | <meta http-equiv="Content-Type" content="text/html; charset=windows-1252"> | ||||||
|  | <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> | ||||||
|  | <meta name="ProgId" content="FrontPage.Editor.Document"> | ||||||
|  | <title>Filter Iterator Adaptor Documentation</title> | ||||||
|  | </head> | ||||||
|  |  | ||||||
|  | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  |  | ||||||
|  | <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" | ||||||
|  | align="center" width="277" height="86"> | ||||||
|  |  | ||||||
|  | <h1>Filter Iterator Adaptor</h1> | ||||||
|  |  | ||||||
|  | Defined in header | ||||||
|  | <a href="../../boost/iterator_adaptors.hpp">boost/iterator_adaptors.hpp</a> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | The filter iterator adaptor creates a view of an iterator range in | ||||||
|  | which some elements of the range are skipped over. A <a | ||||||
|  | href="http://www.sgi.com/tech/stl/Predicate.html">Predicate</a> | ||||||
|  | function object controls which elements are skipped. When the | ||||||
|  | predicate is applied to an element, if it returns <tt>true</tt> then | ||||||
|  | the element is retained and if it returns <tt>false</tt> then the | ||||||
|  | element is skipped over. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h2>Synopsis</h2> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | namespace boost { | ||||||
|  |   template <class Predicate, class BaseIterator, ...> | ||||||
|  |   class filter_iterator_generator; | ||||||
|  |  | ||||||
|  |   template <class Predicate, class BaseIterator> | ||||||
|  |   typename filter_iterator_generator<Predicate, BaseIterator>::type | ||||||
|  |   make_filter_iterator(BaseIterator first, BaseIterator last, const Predicate& p = Predicate()); | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  |  | ||||||
|  | <h2><a name="filter_iterator_generator">The Filter Iterator Type | ||||||
|  | Generator</a></h2> | ||||||
|  |  | ||||||
|  | The class <tt>filter_iterator_generator</tt> is a helper class whose | ||||||
|  | purpose is to construct a filter iterator type.  The template | ||||||
|  | parameters for this class are the <tt>Predicate</tt> function object | ||||||
|  | type and the <tt>BaseIterator</tt> type that is being wrapped.  In | ||||||
|  | most cases the associated types for the wrapped iterator can be | ||||||
|  | deduced from <tt>std::iterator_traits</tt>, but in some situations the | ||||||
|  | user may want to override these types, so there are also template | ||||||
|  | parameters for each of the iterator's associated types. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class Predicate, class BaseIterator, | ||||||
|  |           class Value, class Reference, class Pointer, class Category, class Distance> | ||||||
|  | class filter_iterator_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   typedef <tt><a href="./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> type; // the resulting filter iterator type  | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Example</h3> | ||||||
|  |  | ||||||
|  | The following example uses filter iterator to print out all the | ||||||
|  | positive integers in an array.  | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | struct is_positive_number { | ||||||
|  |   bool operator()(int x) { return 0 < x; } | ||||||
|  | }; | ||||||
|  | int main() { | ||||||
|  |   int numbers[] = { 0, -1, 4, -3, 5, 8, -2 }; | ||||||
|  |   const int N = sizeof(numbers)/sizeof(int); | ||||||
|  |  | ||||||
|  |   typedef boost::filter_iterator_generator<is_positive_number, int*, int>::type FilterIter; | ||||||
|  |   is_positive_number predicate; | ||||||
|  |   FilterIter::policies_type policies(predicate, numbers + N); | ||||||
|  |   FilterIter filter_iter_first(numbers, policies); | ||||||
|  |   FilterIter filter_iter_last(numbers + N, policies); | ||||||
|  |  | ||||||
|  |   std::copy(filter_iter_first, filter_iter_last, std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  | The output is: | ||||||
|  | <pre> | ||||||
|  | 4 5 8 | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  | <Table border> | ||||||
|  | <TR> | ||||||
|  | <TH>Parameter</TH><TH>Description</TH> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><a href="http://www.sgi.com/tech/stl/Predicate.html"><tt>Predicate</tt></a></TD> | ||||||
|  | <TD>The function object that determines which elements are retained and which elements are skipped. | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>BaseIterator</tt></TD> | ||||||
|  | <TD>The iterator type being wrapped. This type must at least be a model | ||||||
|  |  of the <a href="http://www.sgi.com/tech/stl/InputIterator">InputIterator</a> concept.</TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>Value</tt></TD> | ||||||
|  | <TD>The <tt>value_type</tt> of the resulting iterator, | ||||||
|  | unless const. If const, a conforming compiler strips constness for the | ||||||
|  | <tt>value_type</tt>. Typically the default for this parameter is the | ||||||
|  | appropriate type<a href="#1">[1]</a>.<br> <b>Default:</b> | ||||||
|  | <tt>std::iterator_traits<BaseIterator>::value_type</TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>Reference</tt></TD> | ||||||
|  | <TD>The <tt>reference</tt> type of the resulting iterator, and in | ||||||
|  | particular, the result type of <tt>operator*()</tt>. Typically the default for | ||||||
|  | this parameter is the appropriate type.<br> <b>Default:</b> If | ||||||
|  | <tt>Value</tt> is supplied, <tt>Value&</tt> is used. Otherwise | ||||||
|  | <tt>std::iterator_traits<BaseIterator>::reference</tt> is | ||||||
|  | used.</TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>Pointer</tt></TD> | ||||||
|  | <TD>The <tt>pointer</tt> type of the resulting iterator, and in | ||||||
|  |  particular, the result type of <tt>operator->()</tt>.  | ||||||
|  |  Typically the default for | ||||||
|  | this parameter is the appropriate type.<br> | ||||||
|  | <b>Default:</b> If <tt>Value</tt> was supplied, then <tt>Value*</tt>, | ||||||
|  | otherwise <tt>std::iterator_traits<BaseIterator>::pointer</tt>.</TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>Category</tt></TD> | ||||||
|  | <TD>The <tt>iterator_category</tt> type for the resulting iterator. | ||||||
|  | Typically the | ||||||
|  | default for this parameter is the appropriate type. If you override | ||||||
|  | this parameter, do not use <tt>bidirectional_iterator_tag</tt> | ||||||
|  | because filter iterators can not go in reverse.<br> | ||||||
|  | <b>Default:</b> <tt>std::iterator_traits<BaseIterator>::iterator_category</tt></TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>Distance</tt></TD> | ||||||
|  | <TD>The <tt>difference_type</tt> for the resulting iterator. Typically the default for | ||||||
|  | this parameter is the appropriate type.<br> | ||||||
|  | <b>Default:</b> <tt>std::iterator_traits<BaseIterator>::difference_type</TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | </table> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Model of</h3> | ||||||
|  |  | ||||||
|  | The filter iterator adaptor (the type | ||||||
|  | <tt>filter_iterator_generator<...>::type</tt>) may be a model of <a | ||||||
|  | href="http://www.sgi.com/tech/stl/InputIterator.html">InputIterator</a> or <a | ||||||
|  | href="http://www.sgi.com/tech/stl/ForwardIterator.html">ForwardIterator</a> | ||||||
|  | depending on the adapted iterator type. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Members</h3> | ||||||
|  |  | ||||||
|  | The filter iterator type implements all of the member functions and | ||||||
|  | operators required of the <a | ||||||
|  | href="http://www.sgi.com/tech/stl/ForwardIterator.html">ForwardIterator</a> | ||||||
|  | concept.  In addition it has the following constructor: | ||||||
|  |  | ||||||
|  | <pre>filter_iterator_generator::type(const BaseIterator& it, const Policies& p = Policies())</pre> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | The policies type has only one public function, which is its constructor: | ||||||
|  |  | ||||||
|  | <pre>filter_iterator_generator::policies_type(const Predicate& p, const BaseIterator& end)</pre> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | <hr> | ||||||
|  | <p> | ||||||
|  |  | ||||||
|  | <h2><a name="make_filter_iterator">The Make Filter Iterator Function</a></h2> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class Predicate, class BaseIterator> | ||||||
|  | typename filter_generator<Predicate, BaseIterator>::type | ||||||
|  | make_filter_iterator(BaseIterator first, BaseIterator last, const Predicate& p = Predicate()) | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | This function provides a convenient way to create filter iterators. | ||||||
|  |  | ||||||
|  | <h3>Example</h3> | ||||||
|  |  | ||||||
|  | In this example we print out all numbers in the array that are | ||||||
|  | greater than negative two. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | int main() | ||||||
|  | { | ||||||
|  |   int numbers[] = { 0, -1, 4, -3, 5, 8, -2 }; | ||||||
|  |   const int N = sizeof(numbers)/sizeof(int); | ||||||
|  |  | ||||||
|  |   std::copy(boost::make_filter_iterator(numbers, numbers + N,  | ||||||
|  | 					std::bind2nd(std::greater<int>(), -2)), | ||||||
|  | 	    boost::make_filter_iterator(numbers + N, numbers + N,  | ||||||
|  | 					std::bind2nd(std::greater<int>(), -2)), | ||||||
|  | 	    std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  | The output is: | ||||||
|  | <pre> | ||||||
|  | 0 -1 4 5 8  | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | In the next example we print the positive numbers using the | ||||||
|  | <tt>make_filter_iterator()</tt> function. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | struct is_positive_number { | ||||||
|  |   bool operator()(int x) { return 0 < x; } | ||||||
|  | }; | ||||||
|  | int main() | ||||||
|  | { | ||||||
|  |   int numbers[] = { 0, -1, 4, -3, 5, 8, -2 }; | ||||||
|  |   const int N = sizeof(numbers)/sizeof(int); | ||||||
|  |  | ||||||
|  |   std::copy(boost::make_filter_iterator<is_positive_number>(numbers, numbers + N), | ||||||
|  | 	    boost::make_filter_iterator<is_positive_number>(numbers + N, numbers + N), | ||||||
|  | 	    std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  | The output is: | ||||||
|  | <pre> | ||||||
|  | 4 5 8 | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Notes</h3> | ||||||
|  |  | ||||||
|  | <a name="1">[1]</a> If the compiler does not support partial | ||||||
|  | specialization and the wrapped iterator type is a builtin pointer then | ||||||
|  | the <tt>Value</tt> type must be explicitly specified (don't use the | ||||||
|  | default). | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  | <p>Revised <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %b %Y" startspan -->09 Mar 2001<!--webbot bot="Timestamp" endspan i-checksum="14894" --></p> | ||||||
|  | <p><EFBFBD> Copyright Jeremy Siek 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> | ||||||
|  |  | ||||||
|  | </body> | ||||||
|  |  | ||||||
|  | </html> | ||||||
							
								
								
									
										61
									
								
								filter_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								filter_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | // Example of using the filter iterator adaptor from | ||||||
|  | // boost/iterator_adaptors.hpp. | ||||||
|  |  | ||||||
|  | //  (C) Copyright Jeremy Siek 1999. 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. | ||||||
|  |  | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <algorithm> | ||||||
|  | #include <functional> | ||||||
|  | #include <iostream> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | struct is_positive_number { | ||||||
|  |   bool operator()(int x) { return 0 < x; } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | int main() | ||||||
|  | { | ||||||
|  |   int numbers_[] = { 0, -1, 4, -3, 5, 8, -2 }; | ||||||
|  |   const int N = sizeof(numbers_)/sizeof(int); | ||||||
|  |    | ||||||
|  | #ifdef BOOST_NO_STD_ITERATOR_TRAITS | ||||||
|  |   // Assume there won't be proper iterator traits for pointers. This | ||||||
|  |   // is just a wrapper for int* which has the right traits. | ||||||
|  |   typedef boost::iterator_adaptor<int*, boost::default_iterator_policies, int> base_iterator; | ||||||
|  | #else | ||||||
|  |   typedef int* base_iterator; | ||||||
|  | #endif | ||||||
|  |   base_iterator numbers(numbers_); | ||||||
|  |    | ||||||
|  |   // Example using make_filter_iterator() | ||||||
|  |   std::copy(boost::make_filter_iterator<is_positive_number>(numbers, numbers + N), | ||||||
|  |             boost::make_filter_iterator<is_positive_number>(numbers + N, numbers + N), | ||||||
|  |             std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // Example using filter_iterator_generator | ||||||
|  |   typedef boost::filter_iterator_generator<is_positive_number, base_iterator, int>::type | ||||||
|  |     FilterIter; | ||||||
|  |   is_positive_number predicate; | ||||||
|  |   FilterIter::policies_type policies(predicate, numbers + N); | ||||||
|  |   FilterIter filter_iter_first(numbers, policies); | ||||||
|  |   FilterIter filter_iter_last(numbers + N, policies); | ||||||
|  |  | ||||||
|  |   std::copy(filter_iter_first, filter_iter_last, std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // Another example using make_filter_iterator() | ||||||
|  |   std::copy(boost::make_filter_iterator(numbers, numbers + N,  | ||||||
|  |                                         std::bind2nd(std::greater<int>(), -2)), | ||||||
|  |             boost::make_filter_iterator(numbers + N, numbers + N,  | ||||||
|  |                                         std::bind2nd(std::greater<int>(), -2)), | ||||||
|  |             std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |    | ||||||
|  |    | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
							
								
								
									
										41
									
								
								fun_out_iter_example.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								fun_out_iter_example.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | |||||||
|  | // (C) Copyright Jeremy Siek 2001. 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. | ||||||
|  |  | ||||||
|  | // Revision History: | ||||||
|  |  | ||||||
|  | // 27 Feb 2001   Jeremy Siek | ||||||
|  | //      Initial checkin. | ||||||
|  |  | ||||||
|  | #include <iostream> | ||||||
|  | #include <string> | ||||||
|  | #include <vector> | ||||||
|  |  | ||||||
|  | #include <boost/function_output_iterator.hpp> | ||||||
|  |  | ||||||
|  | struct string_appender { | ||||||
|  |   string_appender(std::string& s) : m_str(s) { } | ||||||
|  |   void operator()(const std::string& x) const { | ||||||
|  |     m_str += x; | ||||||
|  |   } | ||||||
|  |   std::string& m_str; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   std::vector<std::string> x; | ||||||
|  |   x.push_back("hello"); | ||||||
|  |   x.push_back(" "); | ||||||
|  |   x.push_back("world"); | ||||||
|  |   x.push_back("!"); | ||||||
|  |  | ||||||
|  |   std::string s = ""; | ||||||
|  |   std::copy(x.begin(), x.end(),  | ||||||
|  |             boost::make_function_output_iterator(string_appender(s))); | ||||||
|  |    | ||||||
|  |   std::cout << s << std::endl; | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
							
								
								
									
										169
									
								
								function_output_iterator.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										169
									
								
								function_output_iterator.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,169 @@ | |||||||
|  | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN"> | ||||||
|  |  | ||||||
|  | <html> | ||||||
|  | <head> | ||||||
|  |     <meta name="generator" content="HTML Tidy, see www.w3.org"> | ||||||
|  |     <meta http-equiv="Content-Type" content="text/html; charset=windows-1252"> | ||||||
|  |     <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> | ||||||
|  |     <meta name="ProgId" content="FrontPage.Editor.Document"> | ||||||
|  |  | ||||||
|  |     <title>Function Output Iterator Adaptor Documentation</title> | ||||||
|  | </head> | ||||||
|  |  | ||||||
|  | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  |          | ||||||
|  |     <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" align= | ||||||
|  |     "center" width="277" height="86">  | ||||||
|  |  | ||||||
|  |     <h1>Function Output Iterator Adaptor</h1> | ||||||
|  |     Defined in header <a href= | ||||||
|  |     "../../boost/function_output_iterator.hpp">boost/function_output_iterator.hpp</a>  | ||||||
|  |  | ||||||
|  |     <p>The function output iterator adaptor makes it easier to create | ||||||
|  |     custom output iterators. The adaptor takes a <a | ||||||
|  |     href="http://www.sgi.com/tech/stl/UnaryFunction.html">Unary | ||||||
|  |     Function</a> and creates a model of <a | ||||||
|  |     href="http://www.sgi.com/tech/stl/OutputIterator.html">Output | ||||||
|  |     Iterator</a>. Each item assigned to the output iterator is passed | ||||||
|  |     as an argument to the unary function.  The motivation for this | ||||||
|  |     iterator is that creating a C++ Standard conforming output | ||||||
|  |     iterator is non-trivial, particularly because the proper | ||||||
|  |     implementation usually requires a proxy object. On the other hand, | ||||||
|  |     creating a function (or function object) is much simpler. | ||||||
|  |  | ||||||
|  |     <h2>Synopsis</h2> | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | namespace boost { | ||||||
|  |   template <class UnaryFunction> | ||||||
|  |   class function_output_iterator; | ||||||
|  |  | ||||||
|  |   template <class UnaryFunction> | ||||||
|  |   function_output_iterator<UnaryFunction> | ||||||
|  |   make_function_output_iterator(const UnaryFunction& f = UnaryFunction()) | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Example</h3> | ||||||
|  |      | ||||||
|  |     In this example we create an output iterator that appends | ||||||
|  |     each item onto the end of a string, using the <tt>string_appender</tt> | ||||||
|  |     function.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | #include <iostream> | ||||||
|  | #include <string> | ||||||
|  | #include <vector> | ||||||
|  |  | ||||||
|  | #include <boost/function_output_iterator.hpp> | ||||||
|  |  | ||||||
|  | struct string_appender { | ||||||
|  |   string_appender(std::string& s) : m_str(s) { } | ||||||
|  |   void operator()(const std::string& x) const { | ||||||
|  |     m_str += x; | ||||||
|  |   } | ||||||
|  |   std::string& m_str; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   std::vector<std::string> x; | ||||||
|  |   x.push_back("hello"); | ||||||
|  |   x.push_back(" "); | ||||||
|  |   x.push_back("world"); | ||||||
|  |   x.push_back("!"); | ||||||
|  |  | ||||||
|  |   std::string s = ""; | ||||||
|  |   std::copy(x.begin(), x.end(),  | ||||||
|  |             boost::make_function_output_iterator(string_appender(s))); | ||||||
|  |    | ||||||
|  |   std::cout << s << std::endl; | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <h2><a name="function_output_iterator">The Function Output Iterator Class</a></h2> | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class UnaryFunction> | ||||||
|  | class function_output_iterator; | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     The <tt>function_output_iterator</tt> class creates an <a | ||||||
|  |     href="http://www.sgi.com/tech/stl/OutputIterator.html">Output | ||||||
|  |     Iterator</a> out of a | ||||||
|  |     <a href="http://www.sgi.com/tech/stl/UnaryFunction.html">Unary | ||||||
|  |     Function</a>. Each item assigned to the output iterator is passed | ||||||
|  |     as an argument to the unary function. | ||||||
|  |  | ||||||
|  |     <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  |     <table border> | ||||||
|  |       <tr> | ||||||
|  |         <th>Parameter | ||||||
|  |  | ||||||
|  |         <th>Description | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>UnaryFunction</tt>  | ||||||
|  |  | ||||||
|  |         <td>The function type being wrapped. The return type of the | ||||||
|  |         function is not used, so it can be <tt>void</tt>.  The | ||||||
|  |         function must be a model of <a | ||||||
|  |         href="http://www.sgi.com/tech/stl/UnaryFunction.html">Unary | ||||||
|  |         Function</a>.</td> | ||||||
|  |     </table> | ||||||
|  |  | ||||||
|  |     <h3>Concept Model</h3> | ||||||
|  |     The function output iterator class is a model of <a | ||||||
|  |     href="http://www.sgi.com/tech/stl/OutputIterator.html">Output | ||||||
|  |     Iterator</a>. | ||||||
|  |  | ||||||
|  |     <h2>Members</h3> | ||||||
|  |     The function output iterator implements the member functions | ||||||
|  |     and operators required of the <a | ||||||
|  |     href="http://www.sgi.com/tech/stl/OutputIterator.html">Output | ||||||
|  |     Iterator</a> concept. In addition it has the following constructor: | ||||||
|  | <pre> | ||||||
|  | explicit function_output_iterator(const UnaryFunction& f = UnaryFunction()) | ||||||
|  | </pre> | ||||||
|  |    <br>     | ||||||
|  |     <br> | ||||||
|  |  | ||||||
|  |     <hr> | ||||||
|  |     <h2><a name="make_function_output_iterator">The Function Output Iterator Object | ||||||
|  |     Generator</a></h2> | ||||||
|  |  | ||||||
|  |     The <tt>make_function_output_iterator()</tt> function provides a | ||||||
|  |     more convenient way to create function output iterator objects. The | ||||||
|  |     function saves the user the trouble of explicitly writing out the | ||||||
|  |     iterator types. If the default argument is used, the function | ||||||
|  |     type must be provided as an explicit template argument. | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class UnaryFunction> | ||||||
|  | function_output_iterator<UnaryFunction> | ||||||
|  | make_function_output_iterator(const UnaryFunction& f = UnaryFunction()) | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <p>© Copyright Jeremy Siek 2001. 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. | ||||||
|  |  | ||||||
|  | </body> | ||||||
|  | </html> | ||||||
| @@ -1,37 +1,33 @@ | |||||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN"> | ||||||
|  |  | ||||||
| <html> | <html> | ||||||
| <head> | <head> | ||||||
|   <meta http-equiv="Content-Language" content="en-us"> | <title>Generator Iterator Adaptor Documentation</title> | ||||||
|   <meta http-equiv="Content-Type" content="text/html; charset=us-ascii"> |  | ||||||
|  |  | ||||||
|   <title>Generator Iterator Adaptor Documentation</title> |  | ||||||
| </head> | </head> | ||||||
|  |  | ||||||
| <body bgcolor="#FFFFFF" text="#000000"> | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|   <img src="../../boost.png" alt="boost.png (6897 bytes)" align="middle" |  | ||||||
|   width="277" height="86"> |  | ||||||
|          |          | ||||||
|   <h1>Generator Iterator Adaptor</h1> | <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" align="center" width="277" height="86">  | ||||||
|  |  | ||||||
|   <p>Defined in header <a href= | <h1>Generator Iterator Adaptor</h1> | ||||||
|   "../../boost/generator_iterator.hpp">boost/generator_iterator.hpp</a></p> | 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>The generator iterator adaptor makes it easier to create custom input | <h2>Synopsis</h2> | ||||||
|   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 { | namespace boost { | ||||||
|   template <class Generator> |   template <class Generator> | ||||||
|   class generator_iterator_policies; |   class generator_iterator_policies; | ||||||
| @@ -44,85 +40,87 @@ namespace boost { | |||||||
|   make_generator_iterator(Generator & gen); |   make_generator_iterator(Generator & gen); | ||||||
| } | } | ||||||
| </pre> | </pre> | ||||||
|   </blockquote> | </blockquote> | ||||||
|   <hr> |  | ||||||
|  |  | ||||||
|   <h2>The Generator Iterator Generator Class</h2> | <hr> | ||||||
|  |  | ||||||
|   <p>The class generator_iterator_generator is a helper class whose purpose | <h2>The Generator Iterator Generator Class</h2> | ||||||
|   is to construct a generator iterator type. The template parameter for this |  | ||||||
|   class is the Generator function object type that is being wrapped. The | The class generator_iterator_generator is a helper class whose purpose | ||||||
|   generator iterator adaptor only holds a reference (or pointer) to the | is to construct a generator iterator type. The template parameter for | ||||||
|   function object, therefore the function object must outlive the generator | this class is the Generator function object type that is being | ||||||
|   iterator adaptor constructed from it.</p> | wrapped.  The generator iterator adaptor only holds a reference (or | ||||||
|   <pre> | pointer) to the function object, therefore the function object must | ||||||
| template <class Generator> | outlive the generator iterator adaptor constructed from it. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class Generator> | ||||||
| class generator_iterator_generator | class generator_iterator_generator | ||||||
| { | { | ||||||
| public: | public: | ||||||
|   typedef <i>unspecified</i> type; // the resulting generator iterator type  |   typedef <a href="iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...> type; // the resulting generator iterator type  | ||||||
| } | } | ||||||
| </pre> | </pre> | ||||||
|  |  | ||||||
|   <h3>Template Parameters</h3> |  | ||||||
|  |  | ||||||
|   <table border summary=""> | <h3>Template Parameters</h3> | ||||||
|     <tr> |  | ||||||
|       <th>Parameter</th> |  | ||||||
|  |  | ||||||
|       <th>Description</th> | <table border> | ||||||
|     </tr> | <tr> | ||||||
|  | <th>Parameter</th> | ||||||
|  | <th>Description</th> | ||||||
|  | </tr> | ||||||
|  |  | ||||||
|     <tr> | <tr> | ||||||
|       <td><tt><a href= | <td><tt><a href="http://www.sgi.com/tech/stl/Generator.html">Generator</a></tt>  | ||||||
|       "http://www.sgi.com/tech/stl/Generator.html">Generator</a></tt></td> | <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 | <h3>Concept Model</h3> | ||||||
|       return type of the function must be defined as | The generator iterator class is a model of | ||||||
|       <tt>Generator::result_type</tt>. The function object must be a model of | <a href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>. | ||||||
|       <a href= |  | ||||||
|       "http://www.sgi.com/tech/stl/Generator.html">Generator</a>.</td> |  | ||||||
|     </tr> |  | ||||||
|   </table> |  | ||||||
|  |  | ||||||
|   <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= | <br> | ||||||
|   "http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>.</p> |  | ||||||
|  |  | ||||||
|   <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 | The <tt>make_generator_iterator()</tt> function provides a | ||||||
|   required of the <a href= | convenient way to create generator iterator objects. The function | ||||||
|   "http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a> | saves the user the trouble of explicitly writing out the iterator | ||||||
|   concept.<br></p> | types. | ||||||
|   <hr> |  | ||||||
|  |  | ||||||
|   <h2><a name="make_generator_iterator" id="make_generator_iterator">The | <blockquote> | ||||||
|   Generator Iterator Object Generator</a></h2> | <pre> | ||||||
|  |  | ||||||
|   <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> |  | ||||||
| template <class Generator> | template <class Generator> | ||||||
| typename generator_iterator_generator<Generator>::type | typename generator_iterator_generator<Generator>::type | ||||||
| make_generator_iterator(Generator & gen); | make_generator_iterator(Generator & gen); | ||||||
| </pre> | </pre> | ||||||
|   </blockquote> | </blockquote> | ||||||
|   <hr> |  | ||||||
|  |  | ||||||
|   <h3>Example</h3> | <hr> | ||||||
|  |  | ||||||
|   <p>The following program shows how <code>generator_iterator</code> |  | ||||||
|   transforms a generator into an input iterator.</p> |  | ||||||
|  |  | ||||||
|   <blockquote> | <h3>Example</h3> | ||||||
|     <pre> |  | ||||||
| #include <iostream> | The following program shows how <code>generator_iterator</code> | ||||||
| #include <boost/generator_iterator.hpp> | transforms a generator into an input iterator. | ||||||
|  |  | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  | #include <iostream> | ||||||
|  | #include <boost/generator_iterator.hpp> | ||||||
|  |  | ||||||
| class my_generator | class my_generator | ||||||
| { | { | ||||||
| @@ -142,22 +140,11 @@ int main() | |||||||
|     std::cout << *it << std::endl; |     std::cout << *it << std::endl; | ||||||
| } | } | ||||||
| </pre> | </pre> | ||||||
|   </blockquote> | </blockquote> | ||||||
|   <hr> |  | ||||||
|  |  | ||||||
|   <p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= | <hr> | ||||||
|   "../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional" |  | ||||||
|   height="31" width="88"></a></p> |  | ||||||
|  |  | ||||||
|   <p>Revised  | Written by Jens Maurer. | ||||||
|   <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %B, %Y" startspan -->05 December, 2006<!--webbot bot="Timestamp" endspan i-checksum="38516" --></p> |  | ||||||
|  |  | ||||||
|   <p><i>Copyright © 2001 <a href= |  | ||||||
|   "http://www.boost.org/people/jens_maurer.htm">Jens Maurer</a></i></p> |  | ||||||
|  |  | ||||||
|   <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> | </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
							
								
								
									
										366
									
								
								half_open_range_test.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										366
									
								
								half_open_range_test.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,366 @@ | |||||||
|  | // (C) Copyright David Abrahams 2001. 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. | ||||||
|  | // | ||||||
|  | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  | // | ||||||
|  | // Revision History | ||||||
|  | // 11 Feb 2001  Compile with Borland, re-enable failing tests (David Abrahams) | ||||||
|  | // 29 Jan 2001  Initial revision (David Abrahams) | ||||||
|  |  | ||||||
|  | #include <boost/half_open_range.hpp> | ||||||
|  | #include <boost/utility.hpp> | ||||||
|  | #include <iterator> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <vector> | ||||||
|  | #include <list> | ||||||
|  | #include <cassert> | ||||||
|  | #include <stdexcept> | ||||||
|  | #ifndef BOOST_NO_LIMITS | ||||||
|  | # include <limits> | ||||||
|  | #endif | ||||||
|  | #ifndef BOOST_NO_SLIST | ||||||
|  | # include <slist> | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | inline unsigned unsigned_random(unsigned max) | ||||||
|  | { | ||||||
|  |     return (max > 0) ? (unsigned)rand() % max : 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Special tests for ranges supporting random access | ||||||
|  | template <class T> | ||||||
|  | void category_test_1( | ||||||
|  |     const boost::half_open_range<T>& r, std::random_access_iterator_tag) | ||||||
|  | { | ||||||
|  |     typedef boost::half_open_range<T> range; | ||||||
|  |     typedef typename range::size_type size_type; | ||||||
|  |     size_type size = r.size(); | ||||||
|  |  | ||||||
|  |     // pick a random offset | ||||||
|  |     size_type offset = unsigned_random(size); | ||||||
|  |  | ||||||
|  |     typename range::value_type x = *(r.begin() + offset); | ||||||
|  |     // test contains(value_type) | ||||||
|  |     assert(r.contains(r.start()) == !r.empty()); | ||||||
|  |     assert(!r.contains(r.finish())); | ||||||
|  |     assert(r.contains(x) == (offset != size)); | ||||||
|  |  | ||||||
|  |     range::const_iterator p = r.find(x); | ||||||
|  |     assert((p == r.end()) == (x == r.finish())); | ||||||
|  |     assert(r.find(r.finish()) == r.end()); | ||||||
|  |  | ||||||
|  |     if (offset != size) | ||||||
|  |     { | ||||||
|  |         assert(x == r[offset]); | ||||||
|  |         assert(x == r.at(offset)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool caught_out_of_range = false; | ||||||
|  |     try { | ||||||
|  |         bool never_initialized = x == r.at(size); | ||||||
|  |         (void)never_initialized; | ||||||
|  |     } | ||||||
|  |     catch(std::out_of_range&) | ||||||
|  |     { | ||||||
|  |         caught_out_of_range = true; | ||||||
|  |     } | ||||||
|  |     catch(...) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  |     assert(caught_out_of_range); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Those tests must be skipped for other ranges | ||||||
|  | template <class T> | ||||||
|  | void category_test_1( | ||||||
|  |     const boost::half_open_range<T>&, std::forward_iterator_tag) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | unsigned indices[][2] = { {0,0},{0,1},{0,2},{0,3}, | ||||||
|  |                                 {1,1},{1,2},{1,3}, | ||||||
|  |                                       {2,2},{2,3}, | ||||||
|  |                                             {3,3}}; | ||||||
|  |  | ||||||
|  | template <class Range> | ||||||
|  | void category_test_2( | ||||||
|  |     const std::vector<Range>& ranges, unsigned i, unsigned j, std::random_access_iterator_tag) | ||||||
|  | { | ||||||
|  |     typedef Range range; | ||||||
|  |     const range& ri = ranges[i]; | ||||||
|  |     const range& rj = ranges[j]; | ||||||
|  |  | ||||||
|  |     if (indices[i][0] <= indices[j][0] && indices[i][1] >= indices[j][1]) | ||||||
|  |         assert(ri.contains(rj)); | ||||||
|  |  | ||||||
|  |     if (ri.contains(rj)) | ||||||
|  |         assert((ri & rj) == rj); | ||||||
|  |     assert(boost::intersects(ri, rj) == !(ri & rj).empty()); | ||||||
|  |  | ||||||
|  |     range t1(ri); | ||||||
|  |     t1 &= rj; | ||||||
|  |     assert(t1 == range(indices[i][0] > indices[j][0] ? ri.start() : rj.start(), | ||||||
|  |                        indices[i][1] < indices[j][1] ? ri.finish() : rj.finish())); | ||||||
|  |     assert(t1 == (ri & rj)); | ||||||
|  |      | ||||||
|  |     range t2(ri); | ||||||
|  |     t2 |= rj; | ||||||
|  |      | ||||||
|  |     if (ri.empty()) | ||||||
|  |         assert(t2 == rj); | ||||||
|  |     else if (rj.empty()) | ||||||
|  |         assert(t2 == ri); | ||||||
|  |     else | ||||||
|  |         assert(t2 == range(indices[i][0] < indices[j][0] ? ri.start() : rj.start(), | ||||||
|  |                            indices[i][1] > indices[j][1] ? ri.finish() : rj.finish())); | ||||||
|  |     assert(t2 == (ri | rj)); | ||||||
|  |     if (i == j) | ||||||
|  |         assert(ri == rj); | ||||||
|  |      | ||||||
|  |     if (ri.empty() || rj.empty()) | ||||||
|  |         assert((ri == rj) == (ri.empty() && rj.empty())); | ||||||
|  |     else | ||||||
|  |         assert((ri == rj) == (ri.start() == rj.start() && ri.finish() == rj.finish())); | ||||||
|  |  | ||||||
|  |     assert((ri == rj) == !(ri != rj)); | ||||||
|  |  | ||||||
|  |     bool same = ri == rj; | ||||||
|  |     bool one_empty = ri.empty() != rj.empty(); | ||||||
|  |  | ||||||
|  |     std::less<range> less; | ||||||
|  |     std::less_equal<range> less_equal; | ||||||
|  |     std::greater<range> greater; | ||||||
|  |     std::greater_equal<range> greater_equal; | ||||||
|  |      | ||||||
|  |     if (same) | ||||||
|  |     { | ||||||
|  |         assert(greater_equal(ri,rj)); | ||||||
|  |         assert(less_equal(ri,rj)); | ||||||
|  |         assert(!greater(ri,rj)); | ||||||
|  |         assert(!less(ri,rj)); | ||||||
|  |     } | ||||||
|  |     else if (one_empty) | ||||||
|  |     { | ||||||
|  |         const range& empty = ri.empty() ? ri : rj; | ||||||
|  |         const range& non_empty = rj.empty() ? ri : rj; | ||||||
|  |          | ||||||
|  |         assert(less(empty,non_empty)); | ||||||
|  |         assert(less_equal(empty,non_empty)); | ||||||
|  |         assert(!greater(empty,non_empty)); | ||||||
|  |         assert(!greater_equal(empty,non_empty)); | ||||||
|  |         assert(!less(non_empty,empty)); | ||||||
|  |         assert(!less_equal(non_empty,empty)); | ||||||
|  |         assert(greater(non_empty,empty)); | ||||||
|  |         assert(greater_equal(non_empty,empty)); | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |         if (indices[i][0] < indices[j][0] || | ||||||
|  |             indices[i][0] == indices[j][0] && indices[i][1] < indices[j][1]) | ||||||
|  |         { | ||||||
|  |             assert(!greater_equal(ri,rj)); | ||||||
|  |             assert(less(ri,rj)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (indices[i][0] < indices[j][0] || | ||||||
|  |             indices[i][0] == indices[j][0] && indices[i][1] <= indices[j][1]) | ||||||
|  |         { | ||||||
|  |             assert(!greater(ri,rj)); | ||||||
|  |             assert(less_equal(ri,rj)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (indices[i][0] > indices[j][0] || | ||||||
|  |             indices[i][0] == indices[j][0] && indices[i][1] > indices[j][1]) | ||||||
|  |         { | ||||||
|  |             assert(!less_equal(ri,rj)); | ||||||
|  |             assert(greater(ri,rj)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (indices[i][0] > indices[j][0] || | ||||||
|  |             indices[i][0] == indices[j][0] && indices[i][1] >= indices[j][1]) | ||||||
|  |         { | ||||||
|  |             assert(!less(ri,rj)); | ||||||
|  |             assert(greater_equal(ri,rj)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | template <class Range> | ||||||
|  | void category_test_2( | ||||||
|  |     const std::vector<Range>&, unsigned, unsigned, std::forward_iterator_tag) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class T> | ||||||
|  | void category_test_2( | ||||||
|  |     const std::vector<boost::half_open_range<T> >&, unsigned, unsigned, std::bidirectional_iterator_tag) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Range> | ||||||
|  | void test_back(Range& x, std::bidirectional_iterator_tag) | ||||||
|  | { | ||||||
|  |     assert(x.back() == boost::prior(x.finish())); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Range> | ||||||
|  | void test_back(Range& x, std::forward_iterator_tag) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class T> | ||||||
|  | boost::half_open_range<T> range_identity(const boost::half_open_range<T>& x) | ||||||
|  | { | ||||||
|  |     return x; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class T> | ||||||
|  | void test(T x0, T x1, T x2, T x3) | ||||||
|  | { | ||||||
|  |     std::vector<boost::half_open_range<T> > ranges; | ||||||
|  |     typedef boost::half_open_range<T> range; | ||||||
|  |  | ||||||
|  |     T bounds[4] = { x0, x1, x2, x3 }; | ||||||
|  |  | ||||||
|  |     const std::size_t num_ranges = sizeof(indices)/sizeof(*indices); | ||||||
|  |     // test construction | ||||||
|  |     for (std::size_t n = 0; n < num_ranges;++n) | ||||||
|  |     { | ||||||
|  |         T start = bounds[indices[n][0]]; | ||||||
|  |         T finish = bounds[indices[n][1]]; | ||||||
|  |         boost::half_open_range<T> r(start, finish); | ||||||
|  |         ranges.push_back(r); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // test implicit conversion from std::pair<T,T> | ||||||
|  |     range converted = std::pair<T,T>(x0,x0); | ||||||
|  |     (void)converted; | ||||||
|  |  | ||||||
|  |     // test assignment, equality and inequality | ||||||
|  |     range r00 = range(x0, x0); | ||||||
|  |     assert(r00 == range(x0,x0)); | ||||||
|  |     assert(r00 == range(x1,x1)); // empty ranges are all equal | ||||||
|  |     if (x3 != x0) | ||||||
|  |         assert(r00 != range(x0, x3)); | ||||||
|  |     r00 = range(x0, x3); | ||||||
|  |     assert(r00 == range(x0, x3)); | ||||||
|  |     if (x3 != x0) | ||||||
|  |         assert(r00 != range(x0, x0)); | ||||||
|  |  | ||||||
|  |     typedef typename range::iterator iterator; | ||||||
|  |     typedef typename iterator::iterator_category category; | ||||||
|  |      | ||||||
|  |     for (unsigned i = 0; i < num_ranges; ++i) | ||||||
|  |     { | ||||||
|  |         const range& r = ranges[i]; | ||||||
|  |              | ||||||
|  |         // test begin(), end(), basic iteration. | ||||||
|  |         unsigned count = 0; | ||||||
|  |         for (range::const_iterator p = r.begin(), finish = r.end(); | ||||||
|  |              p != finish; | ||||||
|  |              ++p, ++count) | ||||||
|  |         { | ||||||
|  |             assert(count < 2100); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // test size(), empty(), front(), back() | ||||||
|  |         assert((unsigned)r.size() == count); | ||||||
|  |         if (indices[i][0] == indices[i][1]) | ||||||
|  |             assert(r.empty()); | ||||||
|  |         if (r.empty()) | ||||||
|  |             assert(r.size() == 0); | ||||||
|  |         if (!r.empty()) | ||||||
|  |         { | ||||||
|  |             assert(r.front() == r.start()); | ||||||
|  |             test_back(r, category()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |             // test swap | ||||||
|  |         range r1(r); | ||||||
|  |         range r2(x0,x3); | ||||||
|  |         const bool same = r1 == r2; | ||||||
|  |         r1.swap(r2); | ||||||
|  |         assert(r1 == range(x0,x3)); | ||||||
|  |         assert(r2 == r); | ||||||
|  |         if (!same) { | ||||||
|  |             assert(r1 != r); | ||||||
|  |             assert(r2 != range(x0,x3)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // do individual tests for random-access iterators | ||||||
|  |         category_test_1(r, category()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     for (unsigned j = 0; j < num_ranges; ++j) { | ||||||
|  |         for (unsigned k = 0; k < num_ranges; ++k) { | ||||||
|  |             category_test_2(ranges, j, k, category()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Integer> | ||||||
|  | void test_integer(Integer* = 0) // default arg works around MSVC bug | ||||||
|  | { | ||||||
|  |     Integer a = 0; | ||||||
|  |     Integer b = a + unsigned_random(128 - a); | ||||||
|  |     Integer c = b + unsigned_random(128 - b); | ||||||
|  |     Integer d = c + unsigned_random(128 - c); | ||||||
|  |  | ||||||
|  |     test(a, b, c, d); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Container> | ||||||
|  | void test_container(Container* = 0)  // default arg works around MSVC bug | ||||||
|  | { | ||||||
|  |     Container c(unsigned_random(1673)); | ||||||
|  |  | ||||||
|  |     const typename Container::size_type offset1 = unsigned_random(c.size()); | ||||||
|  |     const typename Container::size_type offset2 = unsigned_random(c.size() - offset1); | ||||||
|  |     typename Container::iterator internal1 = c.begin(); | ||||||
|  |     std::advance(internal1, offset1); | ||||||
|  |     typename Container::iterator internal2 = internal1; | ||||||
|  |     std::advance(internal2, offset2); | ||||||
|  |      | ||||||
|  |     test(c.begin(), internal1, internal2, c.end()); | ||||||
|  |  | ||||||
|  |     typedef typename Container::const_iterator const_iterator; | ||||||
|  |     test(const_iterator(c.begin()), | ||||||
|  |          const_iterator(internal1), | ||||||
|  |          const_iterator(internal2), | ||||||
|  |          const_iterator(c.end())); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int main() | ||||||
|  | { | ||||||
|  |     // Test the built-in integer types. | ||||||
|  |     test_integer<char>(); | ||||||
|  |     test_integer<unsigned char>(); | ||||||
|  |     test_integer<signed char>(); | ||||||
|  |     test_integer<wchar_t>(); | ||||||
|  |     test_integer<short>(); | ||||||
|  |     test_integer<unsigned short>(); | ||||||
|  |     test_integer<int>(); | ||||||
|  |     test_integer<unsigned int>(); | ||||||
|  |     test_integer<long>(); | ||||||
|  |     test_integer<unsigned long>(); | ||||||
|  | #if defined(BOOST_HAS_LONG_LONG) | ||||||
|  |     test_integer<long long>(); | ||||||
|  |     test_integer<unsigned long long>(); | ||||||
|  | #endif | ||||||
|  |     // Some tests on container iterators, to prove we handle a few different categories | ||||||
|  |     test_container<std::vector<int> >(); | ||||||
|  |     test_container<std::list<int> >(); | ||||||
|  | #ifndef BOOST_NO_SLIST | ||||||
|  |     test_container<BOOST_STD_EXTENSION_NAMESPACE::slist<int> >(); | ||||||
|  | #endif | ||||||
|  |     // Also prove that we can handle raw pointers. | ||||||
|  |     int array[2000]; | ||||||
|  |     const std::size_t a = 0; | ||||||
|  |     const std::size_t b = a + unsigned_random(2000 - a); | ||||||
|  |     const std::size_t c = b + unsigned_random(2000 - b); | ||||||
|  |     test(array, array+b, array+c, array+2000); | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
| @@ -1,296 +0,0 @@ | |||||||
| <!DOCTYPE HTML PUBLIC "-//SoftQuad Software//DTD HoTMetaL PRO 5.0::19981217::extensions to HTML 4.0//EN" "hmpro5.dtd"> |  | ||||||
|  |  | ||||||
| <HTML> |  | ||||||
|  |  | ||||||
| <HEAD> |  | ||||||
| <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=windows-1252"> |  | ||||||
| <TITLE>In_place_factory Documentation</TITLE> |  | ||||||
| </HEAD> |  | ||||||
|  |  | ||||||
| <BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#800080"> |  | ||||||
| <H2 align="left"><IMG SRC="../../boost.png" WIDTH="276" HEIGHT="86"></H2> |  | ||||||
|  |  | ||||||
| <blockquote> |  | ||||||
|   <blockquote> |  | ||||||
|     <blockquote> |  | ||||||
|       <blockquote> |  | ||||||
|         <blockquote> |  | ||||||
|           <blockquote> |  | ||||||
| <H2 align="left">Header <<A |  | ||||||
| HREF="../../boost/utility/in_place_factory.hpp">boost/utility/in_place_factory.hpp</A>> </H2> |  | ||||||
|  |  | ||||||
| <H2 align="left">Header <<A |  | ||||||
| HREF="../../boost/utility/typed_in_place_factory.hpp">boost/utility/typed_in_place_factory.hpp</A>> </H2> |  | ||||||
|  |  | ||||||
|           </blockquote> |  | ||||||
|         </blockquote> |  | ||||||
|       </blockquote> |  | ||||||
|     </blockquote> |  | ||||||
|   </blockquote> |  | ||||||
| </blockquote> |  | ||||||
| <p> </p> |  | ||||||
|  |  | ||||||
| <H2>Contents</H2> |  | ||||||
| <DL CLASS="page-index"> |  | ||||||
|   <DT><A HREF="#mot">Motivation</A></DT> |  | ||||||
|   <DT><A HREF="#framework">Framework</A></DT> |  | ||||||
|   <DT><A HREF="#specification">Specification</A></DT> |  | ||||||
|   <DT><A HREF="#container-usage">Container-side Usage</A></DT> |  | ||||||
|   <DT><A HREF="#user-usage">User-side Usage</A></DT> |  | ||||||
| </DL> |  | ||||||
|  |  | ||||||
| <HR> |  | ||||||
|  |  | ||||||
| <H2><A NAME="mot"></A>Motivation</H2> |  | ||||||
|  |  | ||||||
| <p>Suppose we have a class</p> |  | ||||||
| <pre>struct X |  | ||||||
| { |  | ||||||
|   X ( int, std:::string ) ; |  | ||||||
| } ;</pre> |  | ||||||
| <p>And a container for it which supports an empty state (that is, which can contain zero objects):</p> |  | ||||||
| <pre>struct C |  | ||||||
| { |  | ||||||
|    C() : contained_(0) {} |  | ||||||
|   ~C() { delete contained_ ; } |  | ||||||
|   X* contained_ ; |  | ||||||
| } ;</pre> |  | ||||||
| <p>A container designed to support an empty state typically doesn't require the contained type to be DefaultConstructible, |  | ||||||
| but it typically requires it to be CopyConstructible as a mechanism to |  | ||||||
| initialize the object to store:</p> |  | ||||||
| <pre>struct C |  | ||||||
| { |  | ||||||
|    C() : contained_(0) {} |  | ||||||
|    C ( X const& v ) : contained_ ( new X(v) ) {} |  | ||||||
|   ~C() { delete contained_ ; } |  | ||||||
|   X* contained_ ; |  | ||||||
| } ;</pre> |  | ||||||
| <p>There is a subtle problem with this: since the mechanism used to initialize the stored object is copy construction, |  | ||||||
| there must exist a previously constructed source object to copy from. This |  | ||||||
| object is likely to be temporary and serve no purpose besides being the source</p> |  | ||||||
| <pre>void foo() |  | ||||||
| { |  | ||||||
|   // Temporary object created. |  | ||||||
|   C c( X(123,"hello") ) ; |  | ||||||
| } |  | ||||||
| </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 |  | ||||||
| directly to the container:</p> |  | ||||||
| <pre>struct C |  | ||||||
| { |  | ||||||
|    C() : contained_(0) {} |  | ||||||
|    C ( X const& v ) : contained_ ( new X(v) ) {} |  | ||||||
|    C ( int a0, std::string a1 ) : contained_ ( new X(a0,a1) ) {} |  | ||||||
|   ~C() { delete contained_ ; } |  | ||||||
|   X* contained_ ; |  | ||||||
| } ;</pre> |  | ||||||
| <pre>void foo() |  | ||||||
| { |  | ||||||
|   // Wrapped object constructed in-place |  | ||||||
|   // No temporary created. |  | ||||||
|   C c(123,"hello") ; |  | ||||||
| } |  | ||||||
| </pre> |  | ||||||
| <p>Clearly, this solution doesn't scale well since the container must duplicate all the constructor overloads from the contained type |  | ||||||
| (at least all those which are to be supported directly in the container).</p> |  | ||||||
|  |  | ||||||
| <H2><A NAME="framework"></A>Framework</H2> |  | ||||||
| <p> |  | ||||||
| This library proposes a framework to allow some containers to directly contruct contained objects in-place without requiring |  | ||||||
| the entire set of constructor overloads from the contained type. It also allows the container to remove the CopyConstuctible |  | ||||||
| requirement from the contained type since objects can be directly constructed in-place without need of a copy.<br> |  | ||||||
| The only requirement on the container is that it must provide proper storage (that is, correctly aligned and sized). |  | ||||||
| Naturally, the container will typically support uninitialized storage to avoid the in-place construction to override |  | ||||||
| a fully-constructed object (as this would defeat the purpose of in-place construction) |  | ||||||
| </p> |  | ||||||
| <p>For this purpose, the framework provides two families of classes collectively called: InPlaceFactories and TypedInPlaceFactories.<br> |  | ||||||
| Essentially, these classes hold a sequence of actual parameters and a method to contruct an object in place using these parameters. |  | ||||||
| Each member of the family differs only in the number (and type) of the parameter list. The first family |  | ||||||
| takes the type of the object to construct directly in method provided for that |  | ||||||
| purpose, whereas the second family incorporates that type in the factory class |  | ||||||
| itself..</p> |  | ||||||
| <p>From the container POV, using the framework amounts to calling the factory's method to contruct the object in place. |  | ||||||
| From the user POV, it amounts to creating the right factory object to hold the parameters and pass it to the container.<br> |  | ||||||
| The following simplified example shows the basic idea. A complete example follows the formal specification of the framework:</p> |  | ||||||
| <pre>struct C |  | ||||||
| { |  | ||||||
|    template<class InPlaceFactory> |  | ||||||
|    C ( InPlaceFactory const& aFactory ) |  | ||||||
|     : |  | ||||||
|     contained_ ( uninitialized_storage() ) |  | ||||||
|    { |  | ||||||
|      aFactory.template apply<X>(contained_); |  | ||||||
|    } |  | ||||||
|  |  | ||||||
|   ~C()  |  | ||||||
|   {  |  | ||||||
|     contained_ -> X::~X(); |  | ||||||
|     delete[] contained_ ;  |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   char* uninitialized_storage() { return new char[sizeof(X)] ; } |  | ||||||
|  |  | ||||||
|   char* contained_ ; |  | ||||||
| } ; |  | ||||||
|  |  | ||||||
| void foo() |  | ||||||
| { |  | ||||||
|   C c( in_place(123,"hello") ) ; |  | ||||||
| } |  | ||||||
| </pre> |  | ||||||
|  |  | ||||||
| <HR> |  | ||||||
|  |  | ||||||
| <H2><A NAME="specification">Specification</A></H2> |  | ||||||
|  |  | ||||||
| <p>The following is the first member of the family of 'in_place_factory' classes, along with its corresponding helper template function. |  | ||||||
| The rest of the family varies only in the number and type of template (and constructor) parameters.</p> |  | ||||||
| <PRE>namespace boost { |  | ||||||
|  |  | ||||||
| struct in_place_factory_base {} ; |  | ||||||
|  |  | ||||||
| template<class A0> |  | ||||||
| class in_place_factory : public in_place_factory_base |  | ||||||
| { |  | ||||||
|   public:</PRE> |  | ||||||
|  |  | ||||||
| <PRE>    in_place_factory ( A0 const& a0 ) : m_a0(a0) {} |  | ||||||
|  |  | ||||||
|     template< class T > |  | ||||||
|     void apply ( void* address ) const |  | ||||||
|     { |  | ||||||
|       new (address) T(m_a0); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|   private:</PRE> |  | ||||||
|  |  | ||||||
| <PRE>    A0 const& m_a0 ; |  | ||||||
| } ; |  | ||||||
|  |  | ||||||
| template<class A0> |  | ||||||
| in_place_factory<A0> in_place ( A0 const& a0 ) |  | ||||||
| { |  | ||||||
|   return in_place_factory<A0>(a0); |  | ||||||
| } |  | ||||||
| </PRE> |  | ||||||
|  |  | ||||||
| <p>Similarly, the following is the first member of the family of 'typed_in_place_factory' classes, along with its corresponding |  | ||||||
| helper template function. The rest of the family varies only in the number and type of template (and constructor) parameters.</p> |  | ||||||
| <PRE>namespace boost { |  | ||||||
|  |  | ||||||
| struct typed_in_place_factory_base {} ; |  | ||||||
|  |  | ||||||
| template<class T, class A0> |  | ||||||
| class typed_in_place_factory : public typed_in_place_factory_base |  | ||||||
| { |  | ||||||
|   public:</PRE> |  | ||||||
|  |  | ||||||
| <PRE>    typed_in_place_factory ( A0 const& a0 ) : m_a0(a0) {} |  | ||||||
|  |  | ||||||
|     void apply ( void* address ) const |  | ||||||
|     { |  | ||||||
|       new (address) T(m_a0); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|   private:</PRE> |  | ||||||
|  |  | ||||||
| <PRE>    A0 const& m_a0 ; |  | ||||||
| } ; |  | ||||||
|  |  | ||||||
| template<class T, class A0> |  | ||||||
| typed_in_place_factory<A0> in_place ( A0 const& a0 ) |  | ||||||
| { |  | ||||||
|   return typed_in_place_factory<T,A0>(a0); |  | ||||||
| }</PRE> |  | ||||||
|  |  | ||||||
| <PRE>} |  | ||||||
| </PRE> |  | ||||||
|  |  | ||||||
| <p>As you can see, the 'in_place_factory' and 'typed_in_place_factory' template classes varies only in the way they specify |  | ||||||
| the target type: in the first family, the type is given as a template argument to the apply member function while in the |  | ||||||
| second it is given directly as part of the factory class.<br> |  | ||||||
| When the container holds a unique non-polymorphic type (such as the case of Boost.Optional), it knows the exact dynamic-type |  | ||||||
| of the contained object and can pass it to the apply() method of a (non-typed) factory. |  | ||||||
| In this case, end users can use an 'in_place_factory' instance which can be constructed without the type of the object to construct.<br> |  | ||||||
| However, if the container holds heterogeneous or polymorphic objects (such as the case of Boost.Variant), the dynamic-type |  | ||||||
| of the object to be constructed must be known by the factory itslef. In this case, end users must use a 'typed_in_place_factory' |  | ||||||
| instead.</p> |  | ||||||
|  |  | ||||||
| <HR> |  | ||||||
|  |  | ||||||
| <h2><A NAME="container-usage">Container-side Usage</a></h2> |  | ||||||
|  |  | ||||||
| <p>As shown in the introductory simplified example, the container class must |  | ||||||
| contain methods that accept an instance of |  | ||||||
| these factories and pass the object's storage to the factory's apply method.<br> |  | ||||||
| However, the type of the factory class cannot be completly specified in the container class because that would |  | ||||||
| defeat the whole purpose of the factories which is to allow the container to accept a variadic argument list |  | ||||||
| for the constructor of its contained object.<br> |  | ||||||
| The correct function overload must be based on the only distinctive and common |  | ||||||
| characteristic of all the classes in each family, the base class.<br> |  | ||||||
| Depending on the container class, you can use 'enable_if' to generate the right overload, or use the following |  | ||||||
| dispatch technique (used in the Boost.Optional class): |  | ||||||
| </p> |  | ||||||
| <pre>struct C |  | ||||||
| { |  | ||||||
|    C() : contained_(0) {} |  | ||||||
|    C ( X const& v ) : contained_ ( new X(v) ) {} |  | ||||||
|  |  | ||||||
|    template<class Expr> |  | ||||||
|    C ( Expr const& expr ) |  | ||||||
|     : |  | ||||||
|     contained_ ( uninitialized_storage() ) |  | ||||||
|    { |  | ||||||
|     construct(expr,&expr) |  | ||||||
|    } |  | ||||||
|  |  | ||||||
|   ~C() { delete contained_ ; } |  | ||||||
|  |  | ||||||
|   template<class InPlaceFactory> |  | ||||||
|   void construct ( InPlaceFactory const& aFactory, boost::in_place_factory_base* ) |  | ||||||
|   { |  | ||||||
|     aFactory.template apply<X>(contained_); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   template<class TypedInPlaceFactory> |  | ||||||
|   void construct ( TypedInPlaceFactory const& aFactory, boost::typed_in_place_factory_base* ) |  | ||||||
|   { |  | ||||||
|     aFactory.apply(contained_); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   X* uninitialized_storage() { return static_cast<X*>(new char[sizeof(X)]) ; } |  | ||||||
|  |  | ||||||
|   X* contained_ ; |  | ||||||
| } ; |  | ||||||
| </pre> |  | ||||||
|  |  | ||||||
| <hr> |  | ||||||
|  |  | ||||||
| <h2><A NAME="user-usage">User-side Usage</a></h2> |  | ||||||
|  |  | ||||||
| <p>End users pass to the container an instance of a factory object holding the actual parameters needed to construct the |  | ||||||
| contained object directly within the container. For this, the helper template function 'in_place' is used.<br> |  | ||||||
| The call 'in_place(a0,a1,a2,...,an)' constructs a (non-typed) 'in_place_factory' instance with the given argument list.<br> |  | ||||||
| The call 'in_place<T>(a0,a1,a2,...,an)' constructs a 'typed_in_place_factory' instance with the given argument list for the |  | ||||||
| type 'T'.</p> |  | ||||||
| <pre>void foo() |  | ||||||
| { |  | ||||||
|   C a( in_place(123,"hello") ) ;    // in_place_factory passed |  | ||||||
|   C b( in_place<X>(456,"world") ) ; // typed_in_place_factory passed |  | ||||||
| } |  | ||||||
| </pre> |  | ||||||
|  |  | ||||||
| <P>Revised September 17, 2004</P> |  | ||||||
| <p><EFBFBD> Copyright Fernando Luis Cacciola Carballal, 2004</p> |  | ||||||
| <p> Use, modification, and distribution are subject to the Boost Software |  | ||||||
| License, Version 1.0. (See accompanying file <a href="../../LICENSE_1_0.txt"> |  | ||||||
| LICENSE_1_0.txt</a> or copy at <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 |  | ||||||
| <A HREF="http://www.boost.org/more/mailing_lists.htm#main">discussion lists</A></P> |  | ||||||
| </BODY> |  | ||||||
| </HTML> |  | ||||||
| @@ -2,11 +2,11 @@ | |||||||
| //  boost/assert.hpp - BOOST_ASSERT(expr) | //  boost/assert.hpp - BOOST_ASSERT(expr) | ||||||
| // | // | ||||||
| //  Copyright (c) 2001, 2002 Peter Dimov and Multi Media Ltd. | //  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 | //  Permission to copy, use, modify, sell and distribute this software | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | //  is granted provided this copyright notice appears in all copies. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | //  This software is provided "as is" without express or implied | ||||||
|  | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // | // | ||||||
| //  Note: There are no include guards. This is intentional. | //  Note: There are no include guards. This is intentional. | ||||||
| // | // | ||||||
| @@ -33,18 +33,6 @@ void assertion_failed(char const * expr, char const * function, char const * fil | |||||||
| #define BOOST_ASSERT(expr) ((expr)? ((void)0): ::boost::assertion_failed(#expr, BOOST_CURRENT_FUNCTION, __FILE__, __LINE__)) | #define BOOST_ASSERT(expr) ((expr)? ((void)0): ::boost::assertion_failed(#expr, BOOST_CURRENT_FUNCTION, __FILE__, __LINE__)) | ||||||
|  |  | ||||||
| #else | #else | ||||||
| # include <assert.h> // .h to support old libraries w/o <cassert> - effect is the same | # include <assert.h> | ||||||
| # define BOOST_ASSERT(expr) assert(expr) | # define BOOST_ASSERT(expr) assert(expr) | ||||||
| #endif | #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 |  | ||||||
|   | |||||||
| @@ -1,10 +1,9 @@ | |||||||
| //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | //  (C) Copyright Boost.org 2000. Permission to copy, use, modify, sell and | ||||||
| //  Use, modification and distribution are subject to the Boost Software License, | //  distribute this software is granted provided this copyright notice appears | ||||||
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | //  in all copies. This software is provided "as is" without express or implied | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt). | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // |  | ||||||
| //  See http://www.boost.org/libs/utility for most recent version including documentation. |  | ||||||
|  |  | ||||||
|  | //  See http://www.boost.org/libs/utility/call_traits.htm for Documentation. | ||||||
| //  See boost/detail/call_traits.hpp and boost/detail/ob_call_traits.hpp | //  See boost/detail/call_traits.hpp and boost/detail/ob_call_traits.hpp | ||||||
| //  for full copyright notices. | //  for full copyright notices. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,8 +1,6 @@ | |||||||
| #ifndef BOOST_CHECKED_DELETE_HPP_INCLUDED | #ifndef BOOST_CHECKED_DELETE_HPP_INCLUDED | ||||||
| #define BOOST_CHECKED_DELETE_HPP_INCLUDED | #define BOOST_CHECKED_DELETE_HPP_INCLUDED | ||||||
|  |  | ||||||
| // MS compatible compilers support #pragma once |  | ||||||
|  |  | ||||||
| #if defined(_MSC_VER) && (_MSC_VER >= 1020) | #if defined(_MSC_VER) && (_MSC_VER >= 1020) | ||||||
| # pragma once | # pragma once | ||||||
| #endif | #endif | ||||||
| @@ -10,13 +8,13 @@ | |||||||
| // | // | ||||||
| //  boost/checked_delete.hpp | //  boost/checked_delete.hpp | ||||||
| // | // | ||||||
|  | //  Copyright (c) 1999, 2000, 2001, 2002 boost.org | ||||||
| //  Copyright (c) 2002, 2003 Peter Dimov | //  Copyright (c) 2002, 2003 Peter Dimov | ||||||
| //  Copyright (c) 2003 Daniel Frey |  | ||||||
| //  Copyright (c) 2003 Howard Hinnant |  | ||||||
| // | // | ||||||
| //  Distributed under the Boost Software License, Version 1.0. (See | //  Permission to copy, use, modify, sell and distribute this software | ||||||
| //  accompanying file LICENSE_1_0.txt or copy at | //  is granted provided this copyright notice appears in all copies. | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt) | //  This software is provided "as is" without express or implied | ||||||
|  | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // | // | ||||||
| //  See http://www.boost.org/libs/utility/checked_delete.html for documentation. | //  See http://www.boost.org/libs/utility/checked_delete.html for documentation. | ||||||
| // | // | ||||||
| @@ -28,16 +26,14 @@ namespace boost | |||||||
|  |  | ||||||
| template<class T> inline void checked_delete(T * x) | template<class T> inline void checked_delete(T * x) | ||||||
| { | { | ||||||
|     // intentionally complex - simplification causes regressions |     // Intel 7 accepts sizeof(incomplete) as 0 in system headers | ||||||
|     typedef char type_must_be_complete[ sizeof(T)? 1: -1 ]; |     typedef char type_must_be_complete[ sizeof(T)? 1: -1 ]; | ||||||
|     (void) sizeof(type_must_be_complete); |  | ||||||
|     delete x; |     delete x; | ||||||
| } | } | ||||||
|  |  | ||||||
| template<class T> inline void checked_array_delete(T * x) | template<class T> inline void checked_array_delete(T * x) | ||||||
| { | { | ||||||
|     typedef char type_must_be_complete[ sizeof(T)? 1: -1 ]; |     typedef char type_must_be_complete[ sizeof(T)? 1: -1 ]; | ||||||
|     (void) sizeof(type_must_be_complete); |  | ||||||
|     delete [] x; |     delete [] x; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,10 +1,9 @@ | |||||||
| //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | //  (C) Copyright Boost.org 2000. Permission to copy, use, modify, sell and | ||||||
| //  Use, modification and distribution are subject to the Boost Software License, | //  distribute this software is granted provided this copyright notice appears | ||||||
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | //  in all copies. This software is provided "as is" without express or implied | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt). | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // |  | ||||||
| //  See http://www.boost.org/libs/utility for most recent version including documentation. |  | ||||||
|  |  | ||||||
|  | //  See http://www.boost.org for most recent version including documentation. | ||||||
| //  See boost/detail/compressed_pair.hpp and boost/detail/ob_compressed_pair.hpp | //  See boost/detail/compressed_pair.hpp and boost/detail/ob_compressed_pair.hpp | ||||||
| //  for full copyright notices. | //  for full copyright notices. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,10 +1,8 @@ | |||||||
| #ifndef BOOST_CURRENT_FUNCTION_HPP_INCLUDED | #ifndef BOOST_CURRENT_FUNCTION_HPP_INCLUDED | ||||||
| #define BOOST_CURRENT_FUNCTION_HPP_INCLUDED | #define BOOST_CURRENT_FUNCTION_HPP_INCLUDED | ||||||
|  |  | ||||||
| // MS compatible compilers support #pragma once | #if _MSC_VER >= 1020 | ||||||
|  | #pragma once | ||||||
| #if defined(_MSC_VER) && (_MSC_VER >= 1020) |  | ||||||
| # pragma once |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| // | // | ||||||
| @@ -12,9 +10,10 @@ | |||||||
| // | // | ||||||
| //  Copyright (c) 2002 Peter Dimov and Multi Media Ltd. | //  Copyright (c) 2002 Peter Dimov and Multi Media Ltd. | ||||||
| // | // | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | //  Permission to copy, use, modify, sell and distribute this software | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | //  is granted provided this copyright notice appears in all copies. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | //  This software is provided "as is" without express or implied | ||||||
|  | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // | // | ||||||
| //  http://www.boost.org/libs/utility/current_function.html | //  http://www.boost.org/libs/utility/current_function.html | ||||||
| // | // | ||||||
| @@ -28,11 +27,7 @@ namespace detail | |||||||
| inline void current_function_helper() | inline void current_function_helper() | ||||||
| { | { | ||||||
|  |  | ||||||
| #if defined(__GNUC__) || (defined(__MWERKS__) && (__MWERKS__ >= 0x3000)) || (defined(__ICC) && (__ICC >= 600)) | #if defined(__GNUC__) || (defined(__MWERKS__) && (__MWERKS__ >= 0x3000)) | ||||||
|  |  | ||||||
| # define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__ |  | ||||||
|  |  | ||||||
| #elif defined(__DMC__) && (__DMC__ >= 0x810) |  | ||||||
|  |  | ||||||
| # define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__ | # define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__ | ||||||
|  |  | ||||||
| @@ -40,10 +35,6 @@ inline void current_function_helper() | |||||||
|  |  | ||||||
| # define BOOST_CURRENT_FUNCTION __FUNCSIG__ | # define BOOST_CURRENT_FUNCTION __FUNCSIG__ | ||||||
|  |  | ||||||
| #elif (defined(__INTEL_COMPILER) && (__INTEL_COMPILER >= 600)) || (defined(__IBMCPP__) && (__IBMCPP__ >= 500)) |  | ||||||
|  |  | ||||||
| # define BOOST_CURRENT_FUNCTION __FUNCTION__ |  | ||||||
|  |  | ||||||
| #elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x550) | #elif defined(__BORLANDC__) && (__BORLANDC__ >= 0x550) | ||||||
|  |  | ||||||
| # define BOOST_CURRENT_FUNCTION __FUNC__ | # define BOOST_CURRENT_FUNCTION __FUNC__ | ||||||
|   | |||||||
| @@ -1,9 +1,10 @@ | |||||||
| //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | ||||||
| //  Use, modification and distribution are subject to the Boost Software License, | //  Permission to copy, use, modify, sell and | ||||||
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | //  distribute this software is granted provided this copyright notice appears | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt). | //  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. | ||||||
| //  See http://www.boost.org/libs/utility for most recent version including documentation. |  | ||||||
|  | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| // call_traits: defines typedefs for function usage | // call_traits: defines typedefs for function usage | ||||||
| // (see libs/utility/call_traits.htm) | // (see libs/utility/call_traits.htm) | ||||||
| @@ -21,11 +22,13 @@ | |||||||
| #ifndef BOOST_CONFIG_HPP | #ifndef BOOST_CONFIG_HPP | ||||||
| #include <boost/config.hpp> | #include <boost/config.hpp> | ||||||
| #endif | #endif | ||||||
| #include <cstddef> |  | ||||||
|  |  | ||||||
| #include <boost/type_traits/is_arithmetic.hpp> | #ifndef BOOST_ARITHMETIC_TYPE_TRAITS_HPP | ||||||
| #include <boost/type_traits/is_pointer.hpp> | #include <boost/type_traits/arithmetic_traits.hpp> | ||||||
| #include <boost/detail/workaround.hpp> | #endif | ||||||
|  | #ifndef BOOST_COMPOSITE_TYPE_TRAITS_HPP | ||||||
|  | #include <boost/type_traits/composite_traits.hpp> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| namespace boost{ | namespace boost{ | ||||||
|  |  | ||||||
| @@ -58,7 +61,7 @@ struct ct_imp<T, isp, true> | |||||||
| template <typename T, bool b1> | template <typename T, bool b1> | ||||||
| struct ct_imp<T, true, b1> | struct ct_imp<T, true, b1> | ||||||
| { | { | ||||||
|    typedef const T param_type; |    typedef T const param_type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| } | } | ||||||
| @@ -76,7 +79,7 @@ public: | |||||||
|    // however compiler bugs prevent this - instead pass three bool's to |    // however compiler bugs prevent this - instead pass three bool's to | ||||||
|    // ct_imp<T,bool,bool,bool> and add an extra partial specialisation |    // ct_imp<T,bool,bool,bool> and add an extra partial specialisation | ||||||
|    // of ct_imp to handle the logic. (JM) |    // of ct_imp to handle the logic. (JM) | ||||||
|    typedef typename boost::detail::ct_imp< |    typedef typename detail::ct_imp< | ||||||
|       T, |       T, | ||||||
|       ::boost::is_pointer<T>::value, |       ::boost::is_pointer<T>::value, | ||||||
|       ::boost::is_arithmetic<T>::value |       ::boost::is_arithmetic<T>::value | ||||||
| @@ -92,7 +95,7 @@ struct call_traits<T&> | |||||||
|    typedef T& param_type;  // hh removed const |    typedef T& param_type;  // hh removed const | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #if BOOST_WORKAROUND( __BORLANDC__,  < 0x5A0 ) | #if defined(__BORLANDC__) && (__BORLANDC__ <= 0x560) | ||||||
| // these are illegal specialisations; cv-qualifies applied to | // these are illegal specialisations; cv-qualifies applied to | ||||||
| // references have no effect according to [8.3.2p1], | // references have no effect according to [8.3.2p1], | ||||||
| // C++ Builder requires them though as it treats cv-qualified | // C++ Builder requires them though as it treats cv-qualified | ||||||
| @@ -121,17 +124,8 @@ struct call_traits<T&const volatile> | |||||||
|    typedef const T& const_reference; |    typedef const T& const_reference; | ||||||
|    typedef T& param_type;  // hh removed const |    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 | #endif | ||||||
| #if !defined(BOOST_NO_ARRAY_TYPE_SPECIALIZATIONS) | #ifndef __SUNPRO_CC | ||||||
| template <typename T, std::size_t N> | template <typename T, std::size_t N> | ||||||
| struct call_traits<T [N]> | struct call_traits<T [N]> | ||||||
| { | { | ||||||
|   | |||||||
| @@ -1,16 +1,14 @@ | |||||||
| //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | ||||||
| //  Use, modification and distribution are subject to the Boost Software License, | //  Permission to copy, use, modify, sell and | ||||||
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | //  distribute this software is granted provided this copyright notice appears | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt). | //  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. | ||||||
| //  See http://www.boost.org/libs/utility for most recent version including documentation. |  | ||||||
|  | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| // compressed_pair: pair that "compresses" empty members | // compressed_pair: pair that "compresses" empty members | ||||||
| // (see libs/utility/compressed_pair.htm) | // (see libs/utility/compressed_pair.htm) | ||||||
| // | // | ||||||
| // JM changes 25 Jan 2004: |  | ||||||
| // For the case where T1 == T2 and both are empty, then first() and second() |  | ||||||
| // should return different objects. |  | ||||||
| // JM changes 25 Jan 2000: | // JM changes 25 Jan 2000: | ||||||
| // Removed default arguments from compressed_pair_switch to get | // Removed default arguments from compressed_pair_switch to get | ||||||
| // C++ Builder 4 to accept them | // C++ Builder 4 to accept them | ||||||
| @@ -21,16 +19,16 @@ | |||||||
| #define BOOST_DETAIL_COMPRESSED_PAIR_HPP | #define BOOST_DETAIL_COMPRESSED_PAIR_HPP | ||||||
|  |  | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
|  | #ifndef BOOST_OBJECT_TYPE_TRAITS_HPP | ||||||
| #include <boost/type_traits/remove_cv.hpp> | #include <boost/type_traits/object_traits.hpp> | ||||||
| #include <boost/type_traits/is_empty.hpp> |  | ||||||
| #include <boost/type_traits/is_same.hpp> |  | ||||||
| #include <boost/call_traits.hpp> |  | ||||||
|  |  | ||||||
| #ifdef BOOST_MSVC |  | ||||||
| # pragma warning(push) |  | ||||||
| # pragma warning(disable:4512) |  | ||||||
| #endif | #endif | ||||||
|  | #ifndef BOOST_SAME_TRAITS_HPP | ||||||
|  | #include <boost/type_traits/same_traits.hpp> | ||||||
|  | #endif | ||||||
|  | #ifndef BOOST_CALL_TRAITS_HPP | ||||||
|  | #include <boost/call_traits.hpp> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| namespace boost | namespace boost | ||||||
| { | { | ||||||
|  |  | ||||||
| @@ -136,7 +134,7 @@ namespace details | |||||||
|  |  | ||||||
|    template <class T1, class T2> |    template <class T1, class T2> | ||||||
|    class compressed_pair_imp<T1, T2, 1> |    class compressed_pair_imp<T1, T2, 1> | ||||||
|       : protected ::boost::remove_cv<T1>::type |       : private T1 | ||||||
|    { |    { | ||||||
|    public: |    public: | ||||||
|       typedef T1                                                 first_type; |       typedef T1                                                 first_type; | ||||||
| @@ -178,7 +176,7 @@ namespace details | |||||||
|  |  | ||||||
|    template <class T1, class T2> |    template <class T1, class T2> | ||||||
|    class compressed_pair_imp<T1, T2, 2> |    class compressed_pair_imp<T1, T2, 2> | ||||||
|       : protected ::boost::remove_cv<T2>::type |       : private T2 | ||||||
|    { |    { | ||||||
|    public: |    public: | ||||||
|       typedef T1                                                 first_type; |       typedef T1                                                 first_type; | ||||||
| @@ -221,8 +219,8 @@ namespace details | |||||||
|  |  | ||||||
|    template <class T1, class T2> |    template <class T1, class T2> | ||||||
|    class compressed_pair_imp<T1, T2, 3> |    class compressed_pair_imp<T1, T2, 3> | ||||||
|       : protected ::boost::remove_cv<T1>::type, |       : private T1, | ||||||
|         protected ::boost::remove_cv<T2>::type |         private T2 | ||||||
|    { |    { | ||||||
|    public: |    public: | ||||||
|       typedef T1                                                 first_type; |       typedef T1                                                 first_type; | ||||||
| @@ -257,14 +255,11 @@ namespace details | |||||||
|  |  | ||||||
|    // JM |    // JM | ||||||
|    // 4    T1 == T2, T1 and T2 both empty |    // 4    T1 == T2, T1 and T2 both empty | ||||||
|    //      Originally this did not store an instance of T2 at all |    //      Note does not actually store an instance of T2 at all - | ||||||
|    //      but that led to problems beause it meant &x.first() == &x.second() |    //      but reuses T1 base class for both first() and 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). |  | ||||||
|    template <class T1, class T2> |    template <class T1, class T2> | ||||||
|    class compressed_pair_imp<T1, T2, 4> |    class compressed_pair_imp<T1, T2, 4> | ||||||
|       : protected ::boost::remove_cv<T1>::type |       : private T1 | ||||||
|    { |    { | ||||||
|    public: |    public: | ||||||
|       typedef T1                                                 first_type; |       typedef T1                                                 first_type; | ||||||
| @@ -278,21 +273,20 @@ namespace details | |||||||
|  |  | ||||||
|       compressed_pair_imp() {} |       compressed_pair_imp() {} | ||||||
|  |  | ||||||
|       compressed_pair_imp(first_param_type x, second_param_type y) |       compressed_pair_imp(first_param_type x, second_param_type) | ||||||
|          : first_type(x), m_second(y) {} |          : first_type(x) {} | ||||||
|  |  | ||||||
|       compressed_pair_imp(first_param_type x) |       compressed_pair_imp(first_param_type x) | ||||||
|          : first_type(x), m_second(x) {} |          : first_type(x) {} | ||||||
|  |  | ||||||
|       first_reference       first()       {return *this;} |       first_reference       first()       {return *this;} | ||||||
|       first_const_reference first() const {return *this;} |       first_const_reference first() const {return *this;} | ||||||
|  |  | ||||||
|       second_reference       second()       {return m_second;} |       second_reference       second()       {return *this;} | ||||||
|       second_const_reference second() const {return m_second;} |       second_const_reference second() const {return *this;} | ||||||
|  |  | ||||||
|       void swap(::boost::compressed_pair<T1,T2>&) {} |       void swap(::boost::compressed_pair<T1,T2>&) {} | ||||||
|    private: |    private: | ||||||
|       T2 m_second; |  | ||||||
|    }; |    }; | ||||||
|  |  | ||||||
|    // 5    T1 == T2 and are not empty:   //JM |    // 5    T1 == T2 and are not empty:   //JM | ||||||
| @@ -435,9 +429,7 @@ swap(compressed_pair<T1, T2>& x, compressed_pair<T1, T2>& y) | |||||||
|  |  | ||||||
| } // boost | } // boost | ||||||
|  |  | ||||||
| #ifdef BOOST_MSVC |  | ||||||
| # pragma warning(pop) |  | ||||||
| #endif  |  | ||||||
|  |  | ||||||
| #endif // BOOST_DETAIL_COMPRESSED_PAIR_HPP | #endif // BOOST_DETAIL_COMPRESSED_PAIR_HPP | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,9 +1,10 @@ | |||||||
| //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | ||||||
| //  Use, modification and distribution are subject to the Boost Software License, | //  Permission to copy, use, modify, sell and | ||||||
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | //  distribute this software is granted provided this copyright notice appears | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt). | //  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. | ||||||
| //  See http://www.boost.org/libs/utility for most recent version including documentation. |  | ||||||
|  | //  See http://www.boost.org for most recent version including documentation. | ||||||
| // | // | ||||||
| //  Crippled version for crippled compilers: | //  Crippled version for crippled compilers: | ||||||
| //  see libs/utility/call_traits.htm | //  see libs/utility/call_traits.htm | ||||||
|   | |||||||
| @@ -1,9 +1,10 @@ | |||||||
| //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | //  (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. | ||||||
| //  Use, modification and distribution are subject to the Boost Software License, | //  Permission to copy, use, modify, sell and | ||||||
| //  Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | //  distribute this software is granted provided this copyright notice appears | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt). | //  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. | ||||||
| //  See http://www.boost.org/libs/utility for most recent version including documentation. |  | ||||||
|  | //  See http://www.boost.org for most recent version including documentation. | ||||||
| //  see libs/utility/compressed_pair.hpp | //  see libs/utility/compressed_pair.hpp | ||||||
| // | // | ||||||
| /* Release notes: | /* Release notes: | ||||||
| @@ -292,24 +293,22 @@ public: | |||||||
|    typedef typename call_traits<second_type>::const_reference second_const_reference; |    typedef typename call_traits<second_type>::const_reference second_const_reference; | ||||||
|  |  | ||||||
|             compressed_pair_4() : T1() {} |             compressed_pair_4() : T1() {} | ||||||
|             compressed_pair_4(first_param_type x, second_param_type y) : T1(x), m_second(y) {} |             compressed_pair_4(first_param_type x, second_param_type) : T1(x) {} | ||||||
|    // only one single argument constructor since T1 == T2 |    // only one single argument constructor since T1 == T2 | ||||||
|    explicit compressed_pair_4(first_param_type x) : T1(x), m_second(x) {} |    explicit compressed_pair_4(first_param_type x) : T1(x) {} | ||||||
|    compressed_pair_4(const ::boost::compressed_pair<T1,T2>& x) |    compressed_pair_4(const ::boost::compressed_pair<T1,T2>& x) | ||||||
|       : T1(x.first()), m_second(x.second()) {} |       : T1(x.first()){} | ||||||
|  |  | ||||||
|    first_reference       first()       { return *this; } |    first_reference       first()       { return *this; } | ||||||
|    first_const_reference first() const { return *this; } |    first_const_reference first() const { return *this; } | ||||||
|  |  | ||||||
|    second_reference       second()       { return m_second; } |    second_reference       second()       { return *this; } | ||||||
|    second_const_reference second() const { return m_second; } |    second_const_reference second() const { return *this; } | ||||||
|  |  | ||||||
|    void swap(compressed_pair_4& y) |    void swap(compressed_pair_4& y) | ||||||
|    { |    { | ||||||
|       // no need to swap empty base classes: |       // no need to swap empty base classes: | ||||||
|    } |    } | ||||||
| private: |  | ||||||
|    T2 m_second; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // T1 == T2, not empty | // T1 == T2, not empty | ||||||
|   | |||||||
| @@ -1,11 +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 |  | ||||||
|  |  | ||||||
| #error The header <boost/exception.hpp> has been deprecated. Please #include <boost/exception/all.hpp> instead. |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| @@ -1,7 +1,8 @@ | |||||||
| // (C) Copyright Jens Maurer 2001. | // (C) Copyright Jens Maurer 2001. Permission to copy, use, | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | // modify, sell and distribute this software is granted provided this | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | // copyright notice appears in all copies. This software is provided | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | // "as is" without express or implied warranty, and with no claim as | ||||||
|  | // to its suitability for any purpose. | ||||||
| // | // | ||||||
| // Revision History: | // Revision History: | ||||||
|  |  | ||||||
| @@ -13,63 +14,57 @@ | |||||||
| #ifndef BOOST_ITERATOR_ADAPTOR_GENERATOR_ITERATOR_HPP | #ifndef BOOST_ITERATOR_ADAPTOR_GENERATOR_ITERATOR_HPP | ||||||
| #define BOOST_ITERATOR_ADAPTOR_GENERATOR_ITERATOR_HPP | #define BOOST_ITERATOR_ADAPTOR_GENERATOR_ITERATOR_HPP | ||||||
|  |  | ||||||
| #include <boost/iterator/iterator_facade.hpp> | #include <boost/iterator_adaptors.hpp> | ||||||
| #include <boost/ref.hpp> | #include <boost/ref.hpp> | ||||||
|  |  | ||||||
| namespace boost { | namespace boost { | ||||||
|  |  | ||||||
| template<class Generator> | template<class Generator> | ||||||
| class generator_iterator | class generator_iterator_policies | ||||||
|   : public iterator_facade< |  | ||||||
|         generator_iterator<Generator> |  | ||||||
|       , typename Generator::result_type |  | ||||||
|       , single_pass_traversal_tag |  | ||||||
|       , typename Generator::result_type const& |  | ||||||
|     > |  | ||||||
| { | { | ||||||
|     typedef iterator_facade< | public: | ||||||
|         generator_iterator<Generator> |     generator_iterator_policies() { } | ||||||
|       , typename Generator::result_type |  | ||||||
|       , single_pass_traversal_tag |  | ||||||
|       , typename Generator::result_type const& |  | ||||||
|     > super_t; |  | ||||||
|  |  | ||||||
|  public: |     template<class Base> | ||||||
|     generator_iterator() {} |     void initialize(Base& base) { | ||||||
|     generator_iterator(Generator* g) : m_g(g), m_value((*m_g)()) {} |       m_value = (*base)(); | ||||||
|  |  | ||||||
|     void increment() |  | ||||||
|     { |  | ||||||
|         m_value = (*m_g)(); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // The Iter template argument is necessary for compatibility with a MWCW | ||||||
|  |     // bug workaround | ||||||
|  |     template <class IteratorAdaptor> | ||||||
|  |     void increment(IteratorAdaptor& iter) { | ||||||
|  |       m_value = (*iter.base())(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     template <class IteratorAdaptor> | ||||||
|     const typename Generator::result_type& |     const typename Generator::result_type& | ||||||
|     dereference() const |     dereference(const IteratorAdaptor&) const | ||||||
|     { |         { return m_value; } | ||||||
|         return m_value; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool equal(generator_iterator const& y) const |     template <class IteratorAdaptor1, class IteratorAdaptor2> | ||||||
|     { |     bool equal(const IteratorAdaptor1& x, const IteratorAdaptor2& y) const | ||||||
|         return this->m_g == y.m_g && this->m_value == y.m_value; |         { return x.base() == y.base() && | ||||||
|     } |             x.policies().m_value == y.policies().m_value; } | ||||||
|  |  | ||||||
|  private: | private: | ||||||
|     Generator* m_g; |  | ||||||
|   typename Generator::result_type m_value; |   typename Generator::result_type m_value; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<class Generator> | template<class Generator> | ||||||
| struct generator_iterator_generator | struct generator_iterator_generator | ||||||
| { | { | ||||||
|   typedef generator_iterator<Generator> type; |   typedef iterator_adaptor<Generator*, generator_iterator_policies<Generator>, | ||||||
|  |     typename Generator::result_type, const typename Generator::result_type&, | ||||||
|  |     const typename Generator::result_type*, std::input_iterator_tag, | ||||||
|  |     long>       type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class Generator> | template <class Generator> | ||||||
| inline generator_iterator<Generator> | inline typename generator_iterator_generator<Generator>::type | ||||||
| make_generator_iterator(Generator & gen) | make_generator_iterator(Generator & gen) | ||||||
| { | { | ||||||
|   typedef generator_iterator<Generator> result_t; |   typedef typename generator_iterator_generator<Generator>::type result_t; | ||||||
|   return result_t(&gen); |   return result_t(&gen); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,19 +1,16 @@ | |||||||
| //  Boost next_prior.hpp header file  ---------------------------------------// | //  Boost next_prior.hpp header file  ---------------------------------------// | ||||||
|  |  | ||||||
| //  (C) Copyright Dave Abrahams and Daniel Walker 1999-2003. Distributed under the Boost | //  (C) Copyright Boost.org 1999-2003. Permission to copy, use, modify, sell | ||||||
| //  Software License, Version 1.0. (See accompanying file | //  and distribute this software is granted provided this copyright | ||||||
| //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | //  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. | ||||||
|  |  | ||||||
| //  See http://www.boost.org/libs/utility for documentation. | //  See http://www.boost.org/libs/utility for documentation. | ||||||
|  |  | ||||||
| //  Revision History |  | ||||||
| //  13 Dec 2003  Added next(x, n) and prior(x, n) (Daniel Walker) |  | ||||||
|  |  | ||||||
| #ifndef BOOST_NEXT_PRIOR_HPP_INCLUDED | #ifndef BOOST_NEXT_PRIOR_HPP_INCLUDED | ||||||
| #define BOOST_NEXT_PRIOR_HPP_INCLUDED | #define BOOST_NEXT_PRIOR_HPP_INCLUDED | ||||||
|  |  | ||||||
| #include <iterator> |  | ||||||
|  |  | ||||||
| namespace boost { | namespace boost { | ||||||
|  |  | ||||||
| //  Helper functions for classes like bidirectional iterators not supporting | //  Helper functions for classes like bidirectional iterators not supporting | ||||||
| @@ -22,30 +19,15 @@ namespace boost { | |||||||
| //  Usage: | //  Usage: | ||||||
| //    const std::list<T>::iterator p = get_some_iterator(); | //    const std::list<T>::iterator p = get_some_iterator(); | ||||||
| //    const std::list<T>::iterator prev = boost::prior(p); | //    const std::list<T>::iterator prev = boost::prior(p); | ||||||
| //    const std::list<T>::iterator next = boost::next(prev, 2); |  | ||||||
|  |  | ||||||
| //  Contributed by Dave Abrahams | //  Contributed by Dave Abrahams | ||||||
|  |  | ||||||
| template <class T> | template <class T> | ||||||
| inline T next(T x) { return ++x; } | inline T next(T x) { return ++x; } | ||||||
|  |  | ||||||
| template <class T, class Distance> |  | ||||||
| inline T next(T x, Distance n) |  | ||||||
| { |  | ||||||
|     std::advance(x, n); |  | ||||||
|     return x; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template <class T> | template <class T> | ||||||
| inline T prior(T x) { return --x; } | inline T prior(T x) { return --x; } | ||||||
|  |  | ||||||
| template <class T, class Distance> |  | ||||||
| inline T prior(T x, Distance n) |  | ||||||
| { |  | ||||||
|     std::advance(x, -n); |  | ||||||
|     return x; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| } // namespace boost | } // namespace boost | ||||||
|  |  | ||||||
| #endif  // BOOST_NEXT_PRIOR_HPP_INCLUDED | #endif  // BOOST_NEXT_PRIOR_HPP_INCLUDED | ||||||
|   | |||||||
| @@ -1,8 +1,10 @@ | |||||||
| //  Boost noncopyable.hpp header file  --------------------------------------// | //  Boost noncopyable.hpp header file  --------------------------------------// | ||||||
|  |  | ||||||
| //  (C) Copyright Beman Dawes 1999-2003. Distributed under the Boost | //  (C) Copyright Boost.org 1999-2003. Permission to copy, use, modify, sell | ||||||
| //  Software License, Version 1.0. (See accompanying file | //  and distribute this software is granted provided this copyright | ||||||
| //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | //  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. | ||||||
|  |  | ||||||
| //  See http://www.boost.org/libs/utility for documentation. | //  See http://www.boost.org/libs/utility for documentation. | ||||||
|  |  | ||||||
| @@ -16,20 +18,15 @@ namespace boost { | |||||||
|  |  | ||||||
| //  Contributed by Dave Abrahams | //  Contributed by Dave Abrahams | ||||||
|  |  | ||||||
| namespace noncopyable_  // protection from unintended ADL | class noncopyable | ||||||
| { | { | ||||||
|   class noncopyable |  | ||||||
|   { |  | ||||||
|  protected: |  protected: | ||||||
|     noncopyable() {} |     noncopyable() {} | ||||||
|     ~noncopyable() {} |     ~noncopyable() {} | ||||||
|  private:  // emphasize the following members are private |  private:  // emphasize the following members are private | ||||||
|     noncopyable( const noncopyable& ); |     noncopyable( const noncopyable& ); | ||||||
|     const noncopyable& operator=( const noncopyable& ); |     const noncopyable& operator=( const noncopyable& ); | ||||||
|   }; | }; | ||||||
| } |  | ||||||
|  |  | ||||||
| typedef noncopyable_::noncopyable noncopyable; |  | ||||||
|  |  | ||||||
| } // namespace boost | } // namespace boost | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,18 +1,14 @@ | |||||||
| //  Boost operators.hpp header file  ----------------------------------------// | //  Boost operators.hpp header file  ----------------------------------------// | ||||||
|  |  | ||||||
| //  (C) Copyright David Abrahams, Jeremy Siek, Daryle Walker 1999-2001. | //  (C) Copyright David Abrahams, Jeremy Siek, and Daryle Walker 1999-2001. | ||||||
| //  Distributed under the Boost Software License, Version 1.0. (See | //  Permission to copy, use, modify, sell and distribute this software is | ||||||
| //  accompanying file LICENSE_1_0.txt or copy at | //  granted provided this copyright notice appears in all copies.  This | ||||||
| //  http://www.boost.org/LICENSE_1_0.txt) | //  software is provided "as is" without express or implied warranty, and | ||||||
|  | //  with no claim as to its suitability for any purpose. | ||||||
|  |  | ||||||
| //  See http://www.boost.org/libs/utility/operators.htm for documentation. | //  See http://www.boost.org/libs/utility/operators.htm for documentation. | ||||||
|  |  | ||||||
| //  Revision History | //  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 | //  21 Oct 02 Modified implementation of operators to allow compilers with a | ||||||
| //            correct named return value optimization (NRVO) to produce optimal | //            correct named return value optimization (NRVO) to produce optimal | ||||||
| //            code.  (Daniel Frey) | //            code.  (Daniel Frey) | ||||||
| @@ -82,10 +78,9 @@ | |||||||
|  |  | ||||||
| #include <boost/config.hpp> | #include <boost/config.hpp> | ||||||
| #include <boost/iterator.hpp> | #include <boost/iterator.hpp> | ||||||
| #include <boost/detail/workaround.hpp> |  | ||||||
|  |  | ||||||
| #if defined(__sgi) && !defined(__GNUC__) | #if defined(__sgi) && !defined(__GNUC__) | ||||||
| #   pragma set woff 1234 | #pragma set woff 1234 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if defined(BOOST_MSVC) | #if defined(BOOST_MSVC) | ||||||
| @@ -95,14 +90,14 @@ | |||||||
| namespace boost { | namespace boost { | ||||||
| namespace detail { | namespace detail { | ||||||
|  |  | ||||||
| template <typename T> class empty_base { |  | ||||||
|  |  | ||||||
| // Helmut Zeisel, empty base class optimization bug with GCC 3.0.0 | // Helmut Zeisel, empty base class optimization bug with GCC 3.0.0 | ||||||
| #if defined(__GNUC__) && __GNUC__==3 && __GNUC_MINOR__==0 && __GNU_PATCHLEVEL__==0 | #if defined(__GNUC__) && __GNUC__==3 && __GNUC_MINOR__==0 && __GNU_PATCHLEVEL__==0 | ||||||
|  | class empty_base { | ||||||
|   bool dummy;  |   bool dummy;  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  | #else | ||||||
|  | class empty_base {}; | ||||||
|  | #endif | ||||||
|  |  | ||||||
| } // namespace detail | } // namespace detail | ||||||
| } // namespace boost | } // namespace boost | ||||||
| @@ -124,42 +119,39 @@ namespace boost | |||||||
| //  Note that friend functions defined in a class are implicitly inline. | //  Note that friend functions defined in a class are implicitly inline. | ||||||
| //  See the C++ std, 11.4 [class.friend] paragraph 5 | //  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 | 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 !(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 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 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 !(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); } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class B = ::boost::detail::empty_base<T> > | template <class T, class B = ::boost::detail::empty_base> | ||||||
| struct less_than_comparable1 : B | 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 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 !(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 !(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 | 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 x == y; } | ||||||
|      friend bool operator!=(const U& y, const T& x) { return !static_cast<bool>(x == y); } |      friend bool operator!=(const U& y, const T& x) { return !(x == y); } | ||||||
|      friend bool operator!=(const T& y, const U& x) { return !static_cast<bool>(y == x); } |      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 | 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". |  | ||||||
| #define BOOST_OPERATOR2_LEFT(name) name##2##_##left |  | ||||||
|  |  | ||||||
| //  NRVO-friendly implementation (contributed by Daniel Frey) ---------------// | //  NRVO-friendly implementation (contributed by Daniel Frey) ---------------// | ||||||
|  |  | ||||||
| #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||||
| @@ -170,7 +162,7 @@ struct equality_comparable1 : B | |||||||
| // implementation available. | // implementation available. | ||||||
|  |  | ||||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                         \ | #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                                                            \ | struct NAME##2 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ |   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||||
| @@ -179,7 +171,7 @@ struct NAME##2 : B                                                            \ | |||||||
|     { T nrv( rhs ); nrv OP##= lhs; return nrv; }                              \ |     { 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                                                            \ | struct NAME##1 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ |   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||||
| @@ -187,21 +179,21 @@ struct NAME##1 : B                                                            \ | |||||||
| }; | }; | ||||||
|  |  | ||||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )                     \ | #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                                                            \ | struct NAME##2 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ |   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ |     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||||
| };                                                                            \ | };                                                                            \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
| 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                                   \ | struct NAME##2_left : B                                                       \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const U& lhs, const T& rhs )                          \ |   friend T operator OP( const U& lhs, const T& rhs )                          \ | ||||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ |     { 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                                                            \ | struct NAME##1 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ |   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||||
| @@ -210,40 +202,39 @@ struct NAME##1 : B                                                      \ | |||||||
|  |  | ||||||
| #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||||
|  |  | ||||||
| // For compilers without NRVO the following code is optimal, but not | // For compilers without NRVO the following code is optimal, but not symmetric! | ||||||
| // symmetric!  Note that the implementation of | // Note that the implementation of NAME##2_left only looks cool, but doesn't | ||||||
| // BOOST_OPERATOR2_LEFT(NAME) only looks cool, but doesn't provide | // provide optimization opportunities to the compiler :) | ||||||
| // optimization opportunities to the compiler :) |  | ||||||
|  |  | ||||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                         \ | #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                                                            \ | struct NAME##2 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; }       \ |   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; }       \ |   friend T operator OP( const U& lhs, T rhs ) { return rhs OP##= lhs; }       \ | ||||||
| };                                                                            \ | };                                                                            \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | template <class T, class B = ::boost::detail::empty_base>                     \ | ||||||
| struct NAME##1 : B                                                            \ | struct NAME##1 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ |   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )                     \ | #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                                                            \ | struct NAME##2 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; }       \ |   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                                   \ | struct NAME##2_left : B                                                       \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const U& lhs, const T& rhs )                          \ |   friend T operator OP( const U& lhs, const T& rhs )                          \ | ||||||
|     { return T( lhs ) OP##= 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                                                            \ | struct NAME##1 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ |   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ | ||||||
| @@ -262,11 +253,10 @@ BOOST_BINARY_OPERATOR_COMMUTATIVE( orable, | ) | |||||||
|  |  | ||||||
| #undef BOOST_BINARY_OPERATOR_COMMUTATIVE | #undef BOOST_BINARY_OPERATOR_COMMUTATIVE | ||||||
| #undef BOOST_BINARY_OPERATOR_NON_COMMUTATIVE | #undef BOOST_BINARY_OPERATOR_NON_COMMUTATIVE | ||||||
| #undef BOOST_OPERATOR2_LEFT |  | ||||||
|  |  | ||||||
| //  incrementable and decrementable contributed by Jeremy Siek | //  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 | struct incrementable : B | ||||||
| { | { | ||||||
|   friend T operator++(T& x, int) |   friend T operator++(T& x, int) | ||||||
| @@ -279,7 +269,7 @@ private: // The use of this typedef works around a Borland bug | |||||||
|   typedef T incrementable_type; |   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 | struct decrementable : B | ||||||
| { | { | ||||||
|   friend T operator--(T& x, int) |   friend T operator--(T& x, int) | ||||||
| @@ -294,7 +284,7 @@ private: // The use of this typedef works around a Borland bug | |||||||
|  |  | ||||||
| //  Iterator operator classes (contributed by Jeremy Siek) ------------------// | //  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 | struct dereferenceable : B | ||||||
| { | { | ||||||
|   P operator->() const |   P operator->() const | ||||||
| @@ -303,7 +293,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 | struct indexable : B | ||||||
| { | { | ||||||
|   R operator[](I n) const |   R operator[](I n) const | ||||||
| @@ -318,14 +308,14 @@ struct indexable : B | |||||||
| #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||||
|  |  | ||||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | #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                                                            \ | struct NAME##2 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ |   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ |     { 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                                                            \ | struct NAME##1 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ |   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||||
| @@ -335,13 +325,13 @@ struct NAME##1 : B                                                            \ | |||||||
| #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||||
|  |  | ||||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | #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                                                            \ | struct NAME##2 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; }       \ |   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                                                            \ | struct NAME##1 : B                                                            \ | ||||||
| {                                                                             \ | {                                                                             \ | ||||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ |   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ | ||||||
| @@ -354,209 +344,209 @@ BOOST_BINARY_OPERATOR( right_shiftable, >> ) | |||||||
|  |  | ||||||
| #undef BOOST_BINARY_OPERATOR | #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 | struct equivalent2 : B | ||||||
| { | { | ||||||
|   friend bool operator==(const T& x, const U& 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); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class B = ::boost::detail::empty_base<T> > | template <class T, class B = ::boost::detail::empty_base> | ||||||
| struct equivalent1 : B | struct equivalent1 : B | ||||||
| { | { | ||||||
|   friend bool operator==(const T&x, const T&y) |   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 | struct partially_ordered2 : B | ||||||
| { | { | ||||||
|   friend bool operator<=(const T& x, const U& 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 T& x, const U& 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) |   friend bool operator>(const U& x, const T& y) | ||||||
|     { return y < x; } |     { return y < x; } | ||||||
|   friend bool operator<(const U& x, const T& y) |   friend bool operator<(const U& x, const T& y) | ||||||
|     { return y > x; } |     { return y > x; } | ||||||
|   friend bool operator<=(const U& x, const T& y) |   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) |   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 | struct partially_ordered1 : B | ||||||
| { | { | ||||||
|   friend bool operator>(const T& x, const T& y) |   friend bool operator>(const T& x, const T& y) | ||||||
|     { return y < x; } |     { return y < x; } | ||||||
|   friend bool operator<=(const T& x, const T& y) |   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) |   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) ----------------// | //  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 | struct totally_ordered2 | ||||||
|     : less_than_comparable2<T, U |     : less_than_comparable2<T, U | ||||||
|     , equality_comparable2<T, U, B |     , 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 | struct totally_ordered1 | ||||||
|     : less_than_comparable1<T |     : less_than_comparable1<T | ||||||
|     , equality_comparable1<T, B |     , 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 | struct additive2 | ||||||
|     : addable2<T, U |     : addable2<T, U | ||||||
|     , subtractable2<T, U, B |     , 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 | struct additive1 | ||||||
|     : addable1<T |     : addable1<T | ||||||
|     , subtractable1<T, B |     , 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 | struct multiplicative2 | ||||||
|     : multipliable2<T, U |     : multipliable2<T, U | ||||||
|     , dividable2<T, U, B |     , 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 | struct multiplicative1 | ||||||
|     : multipliable1<T |     : multipliable1<T | ||||||
|     , dividable1<T, B |     , 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 | struct integer_multiplicative2 | ||||||
|     : multiplicative2<T, U |     : multiplicative2<T, U | ||||||
|     , modable2<T, U, B |     , 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 | struct integer_multiplicative1 | ||||||
|     : multiplicative1<T |     : multiplicative1<T | ||||||
|     , modable1<T, B |     , 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 | struct arithmetic2 | ||||||
|     : additive2<T, U |     : additive2<T, U | ||||||
|     , multiplicative2<T, U, B |     , 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 | struct arithmetic1 | ||||||
|     : additive1<T |     : additive1<T | ||||||
|     , multiplicative1<T, B |     , 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 | struct integer_arithmetic2 | ||||||
|     : additive2<T, U |     : additive2<T, U | ||||||
|     , integer_multiplicative2<T, U, B |     , 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 | struct integer_arithmetic1 | ||||||
|     : additive1<T |     : additive1<T | ||||||
|     , integer_multiplicative1<T, B |     , 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 | struct bitwise2 | ||||||
|     : xorable2<T, U |     : xorable2<T, U | ||||||
|     , andable2<T, U |     , andable2<T, U | ||||||
|     , orable2<T, U, B |     , 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 | struct bitwise1 | ||||||
|     : xorable1<T |     : xorable1<T | ||||||
|     , andable1<T |     , andable1<T | ||||||
|     , orable1<T, B |     , 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 | struct unit_steppable | ||||||
|     : incrementable<T |     : incrementable<T | ||||||
|     , decrementable<T, B |     , 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 | struct shiftable2 | ||||||
|     : left_shiftable2<T, U |     : left_shiftable2<T, U | ||||||
|     , right_shiftable2<T, U, B |     , 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 | struct shiftable1 | ||||||
|     : left_shiftable1<T |     : left_shiftable1<T | ||||||
|     , right_shiftable1<T, B |     , 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 | struct ring_operators2 | ||||||
|     : additive2<T, U |     : additive2<T, U | ||||||
|     , subtractable2_left<T, U |     , subtractable2_left<T, U | ||||||
|     , multipliable2<T, U, B |     , 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 | struct ring_operators1 | ||||||
|     : additive1<T |     : additive1<T | ||||||
|     , multipliable1<T, B |     , 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 | struct ordered_ring_operators2 | ||||||
|     : ring_operators2<T, U |     : ring_operators2<T, U | ||||||
|     , totally_ordered2<T, U, B |     , 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 | struct ordered_ring_operators1 | ||||||
|     : ring_operators1<T |     : ring_operators1<T | ||||||
|     , totally_ordered1<T, B |     , 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 | struct field_operators2 | ||||||
|     : ring_operators2<T, U |     : ring_operators2<T, U | ||||||
|     , dividable2<T, U |     , dividable2<T, U | ||||||
|     , dividable2_left<T, U, B |     , 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 | struct field_operators1 | ||||||
|     : ring_operators1<T |     : ring_operators1<T | ||||||
|     , dividable1<T, B |     , 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 | struct ordered_field_operators2 | ||||||
|     : field_operators2<T, U |     : field_operators2<T, U | ||||||
|     , totally_ordered2<T, U, B |     , 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 | struct ordered_field_operators1 | ||||||
|     : field_operators1<T |     : field_operators1<T | ||||||
|     , totally_ordered1<T, B |     , 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 | struct euclidian_ring_operators2 | ||||||
|     : ring_operators2<T, U |     : ring_operators2<T, U | ||||||
|     , dividable2<T, U |     , dividable2<T, U | ||||||
| @@ -565,71 +555,43 @@ struct euclidian_ring_operators2 | |||||||
|     , modable2_left<T, U, B |     , 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 | struct euclidian_ring_operators1 | ||||||
|     : ring_operators1<T |     : ring_operators1<T | ||||||
|     , dividable1<T |     , dividable1<T | ||||||
|     , modable1<T, B |     , 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 | struct ordered_euclidian_ring_operators2 | ||||||
|     : totally_ordered2<T, U |     : totally_ordered2<T, U | ||||||
|     , euclidian_ring_operators2<T, U, B |     , 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 | struct ordered_euclidian_ring_operators1 | ||||||
|     : totally_ordered1<T |     : totally_ordered1<T | ||||||
|     , euclidian_ring_operators1<T, B |     , euclidian_ring_operators1<T, B | ||||||
|       > > {}; |       > > {}; | ||||||
|        |        | ||||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | template <class T, class P, class B = ::boost::detail::empty_base> | ||||||
| struct euclidean_ring_operators2 |  | ||||||
|     : ring_operators2<T, U |  | ||||||
|     , dividable2<T, U |  | ||||||
|     , dividable2_left<T, U |  | ||||||
|     , modable2<T, U |  | ||||||
|     , modable2_left<T, U, B |  | ||||||
|       > > > > > {}; |  | ||||||
|  |  | ||||||
| template <class T, class B = ::boost::detail::empty_base<T> > |  | ||||||
| struct euclidean_ring_operators1 |  | ||||||
|     : ring_operators1<T |  | ||||||
|     , dividable1<T |  | ||||||
|     , modable1<T, B |  | ||||||
|       > > > {}; |  | ||||||
|  |  | ||||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > |  | ||||||
| struct ordered_euclidean_ring_operators2 |  | ||||||
|     : totally_ordered2<T, U |  | ||||||
|     , euclidean_ring_operators2<T, U, B |  | ||||||
|       > > {}; |  | ||||||
|  |  | ||||||
| template <class T, class B = ::boost::detail::empty_base<T> > |  | ||||||
| struct ordered_euclidean_ring_operators1 |  | ||||||
|     : totally_ordered1<T |  | ||||||
|     , euclidean_ring_operators1<T, B |  | ||||||
|       > > {}; |  | ||||||
|  |  | ||||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > |  | ||||||
| struct input_iteratable | struct input_iteratable | ||||||
|     : equality_comparable1<T |     : equality_comparable1<T | ||||||
|     , incrementable<T |     , incrementable<T | ||||||
|     , dereferenceable<T, P, B |     , 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 | struct output_iteratable | ||||||
|     : incrementable<T, B |     : 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 | struct forward_iteratable | ||||||
|     : input_iteratable<T, P, B |     : 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 | struct bidirectional_iteratable | ||||||
|     : forward_iteratable<T, P |     : forward_iteratable<T, P | ||||||
|     , decrementable<T, B |     , decrementable<T, B | ||||||
| @@ -639,7 +601,7 @@ struct bidirectional_iteratable | |||||||
| //  which is an indirect base class of bidirectional_iterable, | //  which is an indirect base class of bidirectional_iterable, | ||||||
| //  random_access_iteratable must not be derived from totally_ordered1 | //  random_access_iteratable must not be derived from totally_ordered1 | ||||||
| //  but from less_than_comparable1 only. (Helmut Zeisel, 02-Dec-2001) | //  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 | struct random_access_iteratable | ||||||
|     : bidirectional_iteratable<T, P |     : bidirectional_iteratable<T, P | ||||||
|     , less_than_comparable1<T |     , less_than_comparable1<T | ||||||
| @@ -684,19 +646,19 @@ struct random_access_iteratable | |||||||
|      // Otherwise, because a Borland C++ 5.5 bug prevents a using declaration |      // Otherwise, because a Borland C++ 5.5 bug prevents a using declaration | ||||||
|      // from working, we are forced to use inheritance for that compiler. |      // from working, we are forced to use inheritance for that compiler. | ||||||
| #    define BOOST_IMPORT_TEMPLATE4(template_name)                                          \ | #    define BOOST_IMPORT_TEMPLATE4(template_name)                                          \ | ||||||
|      template <class T, class U, class V, class W, class B = ::boost::detail::empty_base<T> > \ |      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> {}; |      struct template_name : ::template_name<T, U, V, W, B> {}; | ||||||
|  |  | ||||||
| #    define BOOST_IMPORT_TEMPLATE3(template_name)                                 \ | #    define BOOST_IMPORT_TEMPLATE3(template_name)                                 \ | ||||||
|      template <class T, class U, class V, class B = ::boost::detail::empty_base<T> > \ |      template <class T, class U, class V, class B = ::boost::detail::empty_base>  \ | ||||||
|      struct template_name : ::template_name<T, U, V, B> {}; |      struct template_name : ::template_name<T, U, V, B> {}; | ||||||
|  |  | ||||||
| #    define BOOST_IMPORT_TEMPLATE2(template_name)                              \ | #    define BOOST_IMPORT_TEMPLATE2(template_name)                              \ | ||||||
|      template <class T, class U, class B = ::boost::detail::empty_base<T> > \ |      template <class T, class U, class B = ::boost::detail::empty_base>        \ | ||||||
|      struct template_name : ::template_name<T, U, B> {}; |      struct template_name : ::template_name<T, U, B> {}; | ||||||
|  |  | ||||||
| #    define BOOST_IMPORT_TEMPLATE1(template_name)                              \ | #    define BOOST_IMPORT_TEMPLATE1(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<T, B> {}; |      struct template_name : ::template_name<T, B> {}; | ||||||
|  |  | ||||||
| #  endif // BOOST_NO_USING_TEMPLATE | #  endif // BOOST_NO_USING_TEMPLATE | ||||||
| @@ -707,7 +669,7 @@ struct random_access_iteratable | |||||||
| // Here's where we put it all together, defining the xxxx forms of the templates | // Here's where we put it all together, defining the xxxx forms of the templates | ||||||
| // in namespace boost. We also define specializations of is_chained_base<> for | // in namespace boost. We also define specializations of is_chained_base<> for | ||||||
| // the xxxx, xxxx1, and xxxx2 templates, importing them into boost:: as | // the xxxx, xxxx1, and xxxx2 templates, importing them into boost:: as | ||||||
| // necessary. | // neccessary. | ||||||
| // | // | ||||||
| #ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | #ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||||
|  |  | ||||||
| @@ -732,7 +694,7 @@ template<class T> struct is_chained_base { | |||||||
|  |  | ||||||
| } // namespace boost | } // namespace boost | ||||||
|  |  | ||||||
| // Import a 4-type-argument operator template into boost (if necessary) and | // Import a 4-type-argument operator template into boost (if neccessary) and | ||||||
| // provide a specialization of 'is_chained_base<>' for it. | // provide a specialization of 'is_chained_base<>' for it. | ||||||
| # define BOOST_OPERATOR_TEMPLATE4(template_name4)                     \ | # define BOOST_OPERATOR_TEMPLATE4(template_name4)                     \ | ||||||
|   BOOST_IMPORT_TEMPLATE4(template_name4)                              \ |   BOOST_IMPORT_TEMPLATE4(template_name4)                              \ | ||||||
| @@ -741,7 +703,7 @@ template<class T> struct is_chained_base { | |||||||
|     typedef ::boost::detail::true_t value;                            \ |     typedef ::boost::detail::true_t value;                            \ | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
| // Import a 3-type-argument operator template into boost (if necessary) and | // Import a 3-type-argument operator template into boost (if neccessary) and | ||||||
| // provide a specialization of 'is_chained_base<>' for it. | // provide a specialization of 'is_chained_base<>' for it. | ||||||
| # define BOOST_OPERATOR_TEMPLATE3(template_name3)                     \ | # define BOOST_OPERATOR_TEMPLATE3(template_name3)                     \ | ||||||
|   BOOST_IMPORT_TEMPLATE3(template_name3)                              \ |   BOOST_IMPORT_TEMPLATE3(template_name3)                              \ | ||||||
| @@ -750,7 +712,7 @@ template<class T> struct is_chained_base { | |||||||
|     typedef ::boost::detail::true_t value;                            \ |     typedef ::boost::detail::true_t value;                            \ | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
| // Import a 2-type-argument operator template into boost (if necessary) and | // Import a 2-type-argument operator template into boost (if neccessary) and | ||||||
| // provide a specialization of 'is_chained_base<>' for it. | // provide a specialization of 'is_chained_base<>' for it. | ||||||
| # define BOOST_OPERATOR_TEMPLATE2(template_name2)                  \ | # define BOOST_OPERATOR_TEMPLATE2(template_name2)                  \ | ||||||
|   BOOST_IMPORT_TEMPLATE2(template_name2)                           \ |   BOOST_IMPORT_TEMPLATE2(template_name2)                           \ | ||||||
| @@ -759,7 +721,7 @@ template<class T> struct is_chained_base { | |||||||
|     typedef ::boost::detail::true_t value;                         \ |     typedef ::boost::detail::true_t value;                         \ | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
| // Import a 1-type-argument operator template into boost (if necessary) and | // Import a 1-type-argument operator template into boost (if neccessary) and | ||||||
| // provide a specialization of 'is_chained_base<>' for it. | // provide a specialization of 'is_chained_base<>' for it. | ||||||
| # define BOOST_OPERATOR_TEMPLATE1(template_name1)                  \ | # define BOOST_OPERATOR_TEMPLATE1(template_name1)                  \ | ||||||
|   BOOST_IMPORT_TEMPLATE1(template_name1)                           \ |   BOOST_IMPORT_TEMPLATE1(template_name1)                           \ | ||||||
| @@ -785,7 +747,7 @@ template<class T> struct is_chained_base { | |||||||
| # define BOOST_OPERATOR_TEMPLATE(template_name)                    \ | # define BOOST_OPERATOR_TEMPLATE(template_name)                    \ | ||||||
| template <class T                                                  \ | template <class T                                                  \ | ||||||
|          ,class U = 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             \ |          ,class O = typename is_chained_base<U>::value             \ | ||||||
|          >                                                         \ |          >                                                         \ | ||||||
| struct template_name : template_name##2<T, U, B> {};               \ | struct template_name : template_name##2<T, U, B> {};               \ | ||||||
| @@ -821,7 +783,7 @@ BOOST_OPERATOR_TEMPLATE1(template_name##1) | |||||||
|    // In this case we can only assume that template_name<> is equivalent to the |    // In this case we can only assume that template_name<> is equivalent to the | ||||||
|    // more commonly needed template_name1<> form. |    // more commonly needed template_name1<> form. | ||||||
| #  define BOOST_OPERATOR_TEMPLATE(template_name)                   \ | #  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> {}; |    struct template_name : template_name##1<T, B> {}; | ||||||
|  |  | ||||||
| #endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | #endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||||
| @@ -868,8 +830,6 @@ BOOST_OPERATOR_TEMPLATE(field_operators) | |||||||
| BOOST_OPERATOR_TEMPLATE(ordered_field_operators) | BOOST_OPERATOR_TEMPLATE(ordered_field_operators) | ||||||
| BOOST_OPERATOR_TEMPLATE(euclidian_ring_operators) | BOOST_OPERATOR_TEMPLATE(euclidian_ring_operators) | ||||||
| BOOST_OPERATOR_TEMPLATE(ordered_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_TEMPLATE2(input_iteratable) | ||||||
| BOOST_OPERATOR_TEMPLATE1(output_iteratable) | BOOST_OPERATOR_TEMPLATE1(output_iteratable) | ||||||
| BOOST_OPERATOR_TEMPLATE2(forward_iteratable) | BOOST_OPERATOR_TEMPLATE2(forward_iteratable) | ||||||
|   | |||||||
| @@ -1,27 +1,25 @@ | |||||||
| #ifndef BOOST_REF_HPP_INCLUDED | #ifndef BOOST_REF_HPP_INCLUDED | ||||||
| #define BOOST_REF_HPP_INCLUDED | # define BOOST_REF_HPP_INCLUDED | ||||||
|  |  | ||||||
| // MS compatible compilers support #pragma once | # if _MSC_VER+0 >= 1020 | ||||||
|  |  | ||||||
| #if defined(_MSC_VER) && (_MSC_VER >= 1020) |  | ||||||
| #  pragma once | #  pragma once | ||||||
| #endif | # endif | ||||||
|  |  | ||||||
| #include <boost/config.hpp> | # include <boost/config.hpp> | ||||||
| #include <boost/utility/addressof.hpp> | # include <boost/utility/addressof.hpp> | ||||||
| #include <boost/mpl/bool.hpp> | # include <boost/mpl/bool.hpp> | ||||||
| #include <boost/detail/workaround.hpp> |  | ||||||
|  |  | ||||||
| // | // | ||||||
| //  ref.hpp - ref/cref, useful helper functions | //  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) 2001, 2002 Peter Dimov | ||||||
| //  Copyright (C) 2002 David Abrahams | //  Copyright (C) 2002 David Abrahams | ||||||
| // | // | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | //  Permission to copy, use, modify, sell and distribute this software | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | //  is granted provided this copyright notice appears in all copies. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | //  This software is provided "as is" without express or implied | ||||||
|  | //  warranty, and with no claim as to its suitability for any purpose. | ||||||
| // | // | ||||||
| //  See http://www.boost.org/libs/bind/ref.html for documentation. | //  See http://www.boost.org/libs/bind/ref.html for documentation. | ||||||
| // | // | ||||||
| @@ -34,13 +32,13 @@ template<class T> class reference_wrapper | |||||||
| public: | public: | ||||||
|     typedef T type; |     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) {} |     explicit reference_wrapper(T& t): t_(&t) {} | ||||||
|  |  | ||||||
| #else | #else | ||||||
|  |  | ||||||
|     explicit reference_wrapper(T& t): t_(boost::addressof(t)) {} |     explicit reference_wrapper(T& t): t_(addressof(t)) {} | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| @@ -55,7 +53,7 @@ private: | |||||||
|     T* t_; |     T* t_; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| # if defined( __BORLANDC__ ) && BOOST_WORKAROUND( __BORLANDC__, BOOST_TESTED_AT(0x581) ) | # if defined(__BORLANDC__) && (__BORLANDC__ <= 0x570) | ||||||
| #  define BOOST_REF_CONST | #  define BOOST_REF_CONST | ||||||
| # else | # else | ||||||
| #  define BOOST_REF_CONST const | #  define BOOST_REF_CONST const | ||||||
| @@ -74,13 +72,18 @@ template<class T> inline reference_wrapper<T const> BOOST_REF_CONST cref(T const | |||||||
| # undef BOOST_REF_CONST | # undef BOOST_REF_CONST | ||||||
|  |  | ||||||
| # ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | # ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||||
|  |  | ||||||
| template<typename T> | template<typename T> | ||||||
| class is_reference_wrapper | class is_reference_wrapper | ||||||
|     : public mpl::false_ |     : public mpl::false_ | ||||||
| { | { | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | template<typename T> | ||||||
|  | class is_reference_wrapper<reference_wrapper<T> > | ||||||
|  |     : public mpl::true_ | ||||||
|  | { | ||||||
|  | }; | ||||||
|  |  | ||||||
| template<typename T> | template<typename T> | ||||||
| class unwrap_reference | class unwrap_reference | ||||||
| { | { | ||||||
| @@ -88,30 +91,12 @@ class unwrap_reference | |||||||
|     typedef T type; |     typedef T type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #  define AUX_REFERENCE_WRAPPER_METAFUNCTIONS_DEF(X) \ | template<typename T> | ||||||
| template<typename T> \ | class unwrap_reference<reference_wrapper<T> > | ||||||
| class is_reference_wrapper< X > \ | { | ||||||
|     : public mpl::true_ \ |  public: | ||||||
| { \ |     typedef T type; | ||||||
| }; \ | }; | ||||||
| \ |  | ||||||
| template<typename T> \ |  | ||||||
| class unwrap_reference< X > \ |  | ||||||
| { \ |  | ||||||
|  public: \ |  | ||||||
|     typedef T type; \ |  | ||||||
| }; \ |  | ||||||
| /**/ |  | ||||||
|  |  | ||||||
| AUX_REFERENCE_WRAPPER_METAFUNCTIONS_DEF(reference_wrapper<T>) |  | ||||||
| #if !defined(BOOST_NO_CV_SPECIALIZATIONS) |  | ||||||
| AUX_REFERENCE_WRAPPER_METAFUNCTIONS_DEF(reference_wrapper<T> const) |  | ||||||
| AUX_REFERENCE_WRAPPER_METAFUNCTIONS_DEF(reference_wrapper<T> volatile) |  | ||||||
| AUX_REFERENCE_WRAPPER_METAFUNCTIONS_DEF(reference_wrapper<T> const volatile) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #  undef AUX_REFERENCE_WRAPPER_METAFUNCTIONS_DEF |  | ||||||
|  |  | ||||||
| # else // no partial specialization | # else // no partial specialization | ||||||
|  |  | ||||||
| } // namespace boost | } // namespace boost | ||||||
| @@ -173,17 +158,6 @@ class unwrap_reference | |||||||
|  |  | ||||||
| # endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | # endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||||
|  |  | ||||||
| template <class T> inline typename unwrap_reference<T>::type& |  | ||||||
| unwrap_ref(T& t) |  | ||||||
| { |  | ||||||
|     return t; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template<class T> inline T* get_pointer( reference_wrapper<T> const & r ) |  | ||||||
| { |  | ||||||
|     return r.get_pointer(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| } // namespace boost | } // namespace boost | ||||||
|  |  | ||||||
| #endif // #ifndef BOOST_REF_HPP_INCLUDED | #endif // #ifndef BOOST_REF_HPP_INCLUDED | ||||||
|   | |||||||
| @@ -1,12 +0,0 @@ | |||||||
| // Copyright (C) 2007 Joseph Gauterin |  | ||||||
| // |  | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See |  | ||||||
| // accompanying file LICENSE_1_0.txt or copy at |  | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
|  |  | ||||||
| #ifndef BOOST_SWAP_HPP |  | ||||||
| #define BOOST_SWAP_HPP |  | ||||||
|  |  | ||||||
| #include "boost/utility/swap.hpp" |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| @@ -1,20 +1,21 @@ | |||||||
| //  Boost utility.hpp header file  -------------------------------------------// | //  Boost utility.hpp header file  -------------------------------------------// | ||||||
|  |  | ||||||
| //  Copyright 1999-2003 Aleksey Gurtovoy.  Use, modification, and distribution are | //  (C) Copyright Boost.org 1999-2003. Permission to copy, use, modify, sell | ||||||
| //  subject to the Boost Software License, Version 1.0.  (See accompanying file | //  and distribute this software is granted provided this copyright | ||||||
| //  LICENSE_1_0.txt or a copy at <http://www.boost.org/LICENSE_1_0.txt>.) | //  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. | ||||||
|  |  | ||||||
| //  See <http://www.boost.org/libs/utility/> for the library's home page. | //  See http://www.boost.org/libs/utility for documentation. | ||||||
|  |  | ||||||
| #ifndef BOOST_UTILITY_HPP | #ifndef BOOST_UTILITY_HPP | ||||||
| #define BOOST_UTILITY_HPP | #define BOOST_UTILITY_HPP | ||||||
|  |  | ||||||
| #include <boost/utility/addressof.hpp> | #include <boost/utility/addressof.hpp> | ||||||
| #include <boost/utility/base_from_member.hpp>   | #include <boost/utility/base_from_member.hpp>   | ||||||
| #include <boost/utility/binary.hpp> |  | ||||||
| #include <boost/utility/enable_if.hpp> |  | ||||||
| #include <boost/checked_delete.hpp> | #include <boost/checked_delete.hpp> | ||||||
| #include <boost/next_prior.hpp> | #include <boost/next_prior.hpp> | ||||||
| #include <boost/noncopyable.hpp> | #include <boost/noncopyable.hpp> | ||||||
|  |  | ||||||
| #endif  // BOOST_UTILITY_HPP | #endif  // BOOST_UTILITY_HPP | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,11 +1,15 @@ | |||||||
| // Copyright (C) 2002 Brad King (brad.king@kitware.com)  | // Copyright (C) 2002 Brad King (brad.king@kitware.com)  | ||||||
| //                    Douglas Gregor (gregod@cs.rpi.edu) | //                    Doug Gregor (gregod@cs.rpi.edu) | ||||||
|  | //                    Peter Dimov | ||||||
| // | // | ||||||
| // Copyright (C) 2002, 2008 Peter Dimov | // Permission to copy, use, sell and distribute this software is granted | ||||||
|  | // provided this copyright notice appears in all copies. | ||||||
|  | // Permission to modify the code and to distribute modified code is granted | ||||||
|  | // provided this copyright notice appears in all copies, and a notice | ||||||
|  | // that the code was modified is included with the copyright notice. | ||||||
| // | // | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | // This software is provided "as is" without express or implied warranty, | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | // and with no claim as to its suitability for any purpose. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
|  |  | ||||||
| // For more information, see http://www.boost.org | // For more information, see http://www.boost.org | ||||||
|  |  | ||||||
| @@ -14,89 +18,26 @@ | |||||||
|  |  | ||||||
| # include <boost/config.hpp> | # include <boost/config.hpp> | ||||||
| # include <boost/detail/workaround.hpp> | # include <boost/detail/workaround.hpp> | ||||||
|  | # if BOOST_WORKAROUND(BOOST_MSVC, == 1300) | ||||||
|  | #  include <boost/type_traits/add_pointer.hpp> | ||||||
|  | # endif | ||||||
|  |  | ||||||
| namespace boost | namespace boost { | ||||||
|  |  | ||||||
|  | // Do not make addressof() inline. Breaks MSVC 7. (Peter Dimov) | ||||||
|  |  | ||||||
|  | // VC7 strips const from nested classes unless we add indirection here | ||||||
|  | # if BOOST_WORKAROUND(BOOST_MSVC, == 1300) | ||||||
|  | template <typename T> typename add_pointer<T>::type | ||||||
|  | # else | ||||||
|  | template <typename T> T* | ||||||
|  | # endif | ||||||
|  | addressof(T& v) | ||||||
| { | { | ||||||
|  |  | ||||||
| namespace detail |  | ||||||
| { |  | ||||||
|  |  | ||||||
| template<class T> struct addr_impl_ref |  | ||||||
| { |  | ||||||
|     T & v_; |  | ||||||
|  |  | ||||||
|     inline addr_impl_ref( T & v ): v_( v ) {} |  | ||||||
|     inline operator T& () const { return v_; } |  | ||||||
|  |  | ||||||
| private: |  | ||||||
|     addr_impl_ref & operator=(const addr_impl_ref &); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template<class T> struct addressof_impl |  | ||||||
| { |  | ||||||
|     static inline T * f( T & v, long ) |  | ||||||
|     { |  | ||||||
|   return reinterpret_cast<T*>( |   return reinterpret_cast<T*>( | ||||||
|        &const_cast<char&>(reinterpret_cast<const volatile char &>(v))); |        &const_cast<char&>(reinterpret_cast<const volatile char &>(v))); | ||||||
|     } |  | ||||||
|  |  | ||||||
|     static inline T * f( T * v, int ) |  | ||||||
|     { |  | ||||||
|         return v; |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| } // namespace detail |  | ||||||
|  |  | ||||||
| template<class T> T * addressof( T & v ) |  | ||||||
| { |  | ||||||
| #if defined( __BORLANDC__ ) && BOOST_WORKAROUND( __BORLANDC__, BOOST_TESTED_AT( 0x610 ) ) |  | ||||||
|  |  | ||||||
|     return boost::detail::addressof_impl<T>::f( v, 0 ); |  | ||||||
|  |  | ||||||
| #else |  | ||||||
|  |  | ||||||
|     return boost::detail::addressof_impl<T>::f( boost::detail::addr_impl_ref<T>( v ), 0 ); |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| #if defined( __SUNPRO_CC ) && BOOST_WORKAROUND( __SUNPRO_CC, BOOST_TESTED_AT( 0x590 ) ) |  | ||||||
|  |  | ||||||
| namespace detail |  | ||||||
| { |  | ||||||
|  |  | ||||||
| template<class T> struct addressof_addp |  | ||||||
| { |  | ||||||
|     typedef T * type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| } // namespace detail |  | ||||||
|  |  | ||||||
| template< class T, std::size_t N > |  | ||||||
| typename detail::addressof_addp< T[N] >::type addressof( T (&t)[N] ) |  | ||||||
| { |  | ||||||
|     return &t; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| // Borland doesn't like casting an array reference to a char reference |  | ||||||
| // but these overloads work around the problem. |  | ||||||
| #if defined( __BORLANDC__ ) && BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) |  | ||||||
| template<typename T,std::size_t N> |  | ||||||
| T (*addressof(T (&t)[N]))[N] |  | ||||||
| { |  | ||||||
|    return reinterpret_cast<T(*)[N]>(&t); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template<typename T,std::size_t N> |  | ||||||
| const T (*addressof(const T (&t)[N]))[N] |  | ||||||
| { |  | ||||||
|    return reinterpret_cast<const T(*)[N]>(&t); |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| } // namespace boost |  | ||||||
|  |  | ||||||
| #endif // BOOST_UTILITY_ADDRESSOF_HPP | #endif // BOOST_UTILITY_ADDRESSOF_HPP | ||||||
|   | |||||||
| @@ -1,53 +1,17 @@ | |||||||
| //  boost utility/base_from_member.hpp header file  --------------------------// | //  boost utility/base_from_member.hpp header file  --------------------------// | ||||||
|  |  | ||||||
| //  Copyright 2001, 2003, 2004 Daryle Walker.  Use, modification, and | //  (C) Copyright Daryle Walker 2001.  Permission to copy, use, modify, sell | ||||||
| //  distribution are subject to the Boost Software License, Version 1.0.  (See | //  and distribute this software is granted provided this copyright | ||||||
| //  accompanying file LICENSE_1_0.txt or a copy at | //  notice appears in all copies.  This software is provided "as is" without | ||||||
| //  <http://www.boost.org/LICENSE_1_0.txt>.) | //  express or implied warranty, and with no claim as to its suitability for | ||||||
|  | //  any purpose. | ||||||
|  |  | ||||||
| //  See <http://www.boost.org/libs/utility/> for the library's home page. | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| #ifndef BOOST_UTILITY_BASE_FROM_MEMBER_HPP | #ifndef BOOST_UTILITY_BASE_FROM_MEMBER_HPP | ||||||
| #define BOOST_UTILITY_BASE_FROM_MEMBER_HPP | #define BOOST_UTILITY_BASE_FROM_MEMBER_HPP | ||||||
|  |  | ||||||
| #include <boost/preprocessor/arithmetic/inc.hpp> | #include <boost/utility_fwd.hpp>  // required for parameter defaults | ||||||
| #include <boost/preprocessor/repetition/enum_binary_params.hpp> |  | ||||||
| #include <boost/preprocessor/repetition/enum_params.hpp> |  | ||||||
| #include <boost/preprocessor/repetition/repeat_from_to.hpp> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //  Base-from-member arity configuration macro  ------------------------------// |  | ||||||
|  |  | ||||||
| // The following macro determines how many arguments will be in the largest |  | ||||||
| // constructor template of base_from_member.  Constructor templates will be |  | ||||||
| // generated from one argument to this maximum.  Code from other files can read |  | ||||||
| // this number if they need to always match the exact maximum base_from_member |  | ||||||
| // uses.  The maximum constructor length can be changed by overriding the |  | ||||||
| // #defined constant.  Make sure to apply the override, if any, for all source |  | ||||||
| // files during project compiling for consistency. |  | ||||||
|  |  | ||||||
| // Contributed by Jonathan Turkanis |  | ||||||
|  |  | ||||||
| #ifndef BOOST_BASE_FROM_MEMBER_MAX_ARITY |  | ||||||
| #define BOOST_BASE_FROM_MEMBER_MAX_ARITY  10 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //  An iteration of a constructor template for base_from_member  -------------// |  | ||||||
|  |  | ||||||
| // A macro that should expand to: |  | ||||||
| //     template < typename T1, ..., typename Tn > |  | ||||||
| //     base_from_member( T1 x1, ..., Tn xn ) |  | ||||||
| //         : member( x1, ..., xn ) |  | ||||||
| //         {} |  | ||||||
| // This macro should only persist within this file. |  | ||||||
|  |  | ||||||
| #define BOOST_PRIVATE_CTR_DEF( z, n, data )                            \ |  | ||||||
|     template < BOOST_PP_ENUM_PARAMS(n, typename T) >                   \ |  | ||||||
|     explicit base_from_member( BOOST_PP_ENUM_BINARY_PARAMS(n, T, x) )  \ |  | ||||||
|         : member( BOOST_PP_ENUM_PARAMS(n, x) )                         \ |  | ||||||
|         {}                                                             \ |  | ||||||
|     /**/ |  | ||||||
|  |  | ||||||
|  |  | ||||||
| namespace boost | namespace boost | ||||||
| @@ -62,26 +26,34 @@ namespace boost | |||||||
|  |  | ||||||
| // Contributed by Daryle Walker | // Contributed by Daryle Walker | ||||||
|  |  | ||||||
| template < typename MemberType, int UniqueID = 0 > | template < typename MemberType, int UniqueID > | ||||||
| class base_from_member | class base_from_member | ||||||
| { | { | ||||||
| protected: | protected: | ||||||
|     MemberType  member; |     MemberType  member; | ||||||
|  |  | ||||||
|     base_from_member() |     explicit  base_from_member() | ||||||
|         : member() |         : member() | ||||||
|         {} |         {} | ||||||
|  |  | ||||||
|     BOOST_PP_REPEAT_FROM_TO( 1, BOOST_PP_INC(BOOST_BASE_FROM_MEMBER_MAX_ARITY), |     template< typename T1 > | ||||||
|      BOOST_PRIVATE_CTR_DEF, _ ) |     explicit base_from_member( T1 x1 ) | ||||||
|  |         : member( x1 ) | ||||||
|  |         {} | ||||||
|  |  | ||||||
|  |     template< typename T1, typename T2 > | ||||||
|  |     base_from_member( T1 x1, T2 x2 ) | ||||||
|  |         : member( x1, x2 ) | ||||||
|  |         {} | ||||||
|  |  | ||||||
|  |     template< typename T1, typename T2, typename T3 > | ||||||
|  |     base_from_member( T1 x1, T2 x2, T3 x3 ) | ||||||
|  |         : member( x1, x2, x3 )  | ||||||
|  |         {} | ||||||
|  |  | ||||||
| };  // boost::base_from_member | };  // boost::base_from_member | ||||||
|  |  | ||||||
| }  // namespace boost | }  // namespace boost | ||||||
|  |  | ||||||
|  |  | ||||||
| // Undo any private macros |  | ||||||
| #undef BOOST_PRIVATE_CTR_DEF |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif  // BOOST_UTILITY_BASE_FROM_MEMBER_HPP | #endif  // BOOST_UTILITY_BASE_FROM_MEMBER_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,68 +0,0 @@ | |||||||
| // Copyright (C) 2003, Fernando Luis Cacciola Carballal. |  | ||||||
| // |  | ||||||
| // 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) |  | ||||||
| // |  | ||||||
| // See http://www.boost.org/lib/optional for documentation. |  | ||||||
| // |  | ||||||
| // You are welcome to contact the author at: |  | ||||||
| //  fernando_cacciola@hotmail.com |  | ||||||
| // |  | ||||||
| #ifndef BOOST_UTILITY_COMPARE_POINTEES_25AGO2003_HPP |  | ||||||
| #define BOOST_UTILITY_COMPARE_POINTEES_25AGO2003_HPP |  | ||||||
|  |  | ||||||
| #include<functional> |  | ||||||
|  |  | ||||||
| namespace boost { |  | ||||||
|  |  | ||||||
| // template<class OP> bool equal_pointees(OP const& x, OP const& y); |  | ||||||
| // template<class OP> struct equal_pointees_t; |  | ||||||
| // |  | ||||||
| // Being OP a model of OptionalPointee (either a pointer or an optional): |  | ||||||
| // |  | ||||||
| // If both x and y have valid pointees, returns the result of (*x == *y) |  | ||||||
| // If only one has a valid pointee, returns false. |  | ||||||
| // If none have valid pointees, returns true. |  | ||||||
| // No-throw |  | ||||||
| template<class OptionalPointee> |  | ||||||
| inline |  | ||||||
| bool equal_pointees ( OptionalPointee const& x, OptionalPointee const& y ) |  | ||||||
| { |  | ||||||
|   return (!x) != (!y) ? false : ( !x ? true : (*x) == (*y) ) ; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template<class OptionalPointee> |  | ||||||
| struct equal_pointees_t : std::binary_function<OptionalPointee,OptionalPointee,bool> |  | ||||||
| { |  | ||||||
|   bool operator() ( OptionalPointee const& x, OptionalPointee const& y ) const |  | ||||||
|     { return equal_pointees(x,y) ; } |  | ||||||
| } ; |  | ||||||
|  |  | ||||||
| // template<class OP> bool less_pointees(OP const& x, OP const& y); |  | ||||||
| // template<class OP> struct less_pointees_t; |  | ||||||
| // |  | ||||||
| // Being OP a model of OptionalPointee (either a pointer or an optional): |  | ||||||
| // |  | ||||||
| // If y has not a valid pointee, returns false. |  | ||||||
| // ElseIf x has not a valid pointee, returns true. |  | ||||||
| // ElseIf both x and y have valid pointees, returns the result of (*x < *y) |  | ||||||
| // No-throw |  | ||||||
| template<class OptionalPointee> |  | ||||||
| inline |  | ||||||
| bool less_pointees ( OptionalPointee const& x, OptionalPointee const& y ) |  | ||||||
| { |  | ||||||
|   return !y ? false : ( !x ? true : (*x) < (*y) ) ; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| template<class OptionalPointee> |  | ||||||
| struct less_pointees_t : std::binary_function<OptionalPointee,OptionalPointee,bool> |  | ||||||
| { |  | ||||||
|   bool operator() ( OptionalPointee const& x, OptionalPointee const& y ) const |  | ||||||
|     { return less_pointees(x,y) ; } |  | ||||||
| } ; |  | ||||||
|  |  | ||||||
| } // namespace boost |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| @@ -1,36 +0,0 @@ | |||||||
| // 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 |  | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
| // |  | ||||||
| // See http://www.boost.org/lib/optional for documentation. |  | ||||||
| // |  | ||||||
| // 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 |  | ||||||
|  |  | ||||||
| #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> |  | ||||||
|  |  | ||||||
| #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_MAX_INPLACE_FACTORY_ARITY 10 |  | ||||||
|  |  | ||||||
| #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_04APR2007_HPP |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| // 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 |  | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
| // |  | ||||||
| // See http://www.boost.org/lib/optional for documentation. |  | ||||||
| // |  | ||||||
| // 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 |  | ||||||
|  |  | ||||||
| #undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT |  | ||||||
| #undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL |  | ||||||
| #undef BOOST_MAX_INPLACE_FACTORY_ARITY |  | ||||||
|  |  | ||||||
| #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_04APR2007_HPP |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| @@ -1,148 +0,0 @@ | |||||||
| // Boost result_of library |  | ||||||
|  |  | ||||||
| //  Copyright Douglas Gregor 2004. 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) |  | ||||||
|  |  | ||||||
| // For more information, see http://www.boost.org/libs/utility |  | ||||||
| #if !defined(BOOST_PP_IS_ITERATING) |  | ||||||
| # error Boost result_of - do not include this file! |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| // 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 |  | ||||||
| #else |  | ||||||
| # define BOOST_RESULT_OF_ARGS BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551)) |  | ||||||
| template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) |  | ||||||
|          BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> |  | ||||||
| struct tr1_result_of<F(BOOST_RESULT_OF_ARGS)> |  | ||||||
|     : mpl::if_< |  | ||||||
|           mpl::or_< is_pointer<F>, is_member_function_pointer<F> > |  | ||||||
|         , boost::detail::tr1_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::tr1_result_of_impl< |  | ||||||
|             F, |  | ||||||
|             F(BOOST_RESULT_OF_ARGS),  |  | ||||||
|             (boost::detail::has_result_type<F>::value)> >::type { }; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if !defined(BOOST_NO_DECLTYPE) && defined(BOOST_RESULT_OF_USE_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::tr1_result_of_impl< |  | ||||||
|             typename remove_cv<F>::type,  |  | ||||||
|             typename remove_cv<F>::type(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), false |  | ||||||
|           > |  | ||||||
|         , detail::cpp0x_result_of_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 cpp0x_result_of_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_NO_DECLTYPE) |  | ||||||
|  |  | ||||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551)) |  | ||||||
| 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)> |  | ||||||
|     : tr1_result_of<F(BOOST_RESULT_OF_ARGS)> { }; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif // defined(BOOST_NO_DECLTYPE) |  | ||||||
|  |  | ||||||
| #undef BOOST_RESULT_OF_ARGS |  | ||||||
|  |  | ||||||
| #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 tr1_result_of_impl<R (*)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false> |  | ||||||
| { |  | ||||||
|   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 tr1_result_of_impl<R (&)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false> |  | ||||||
| { |  | ||||||
|   typedef R type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #if !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 tr1_result_of_impl<R (T0::*) |  | ||||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)), |  | ||||||
|                  FArgs, false> |  | ||||||
| { |  | ||||||
|   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 tr1_result_of_impl<R (T0::*) |  | ||||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) |  | ||||||
|                      const, |  | ||||||
|                  FArgs, false> |  | ||||||
| { |  | ||||||
|   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 tr1_result_of_impl<R (T0::*) |  | ||||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) |  | ||||||
|                      volatile, |  | ||||||
|                  FArgs, false> |  | ||||||
| { |  | ||||||
|   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 tr1_result_of_impl<R (T0::*) |  | ||||||
|                      (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) |  | ||||||
|                      const volatile, |  | ||||||
|                  FArgs, false> |  | ||||||
| { |  | ||||||
|   typedef R type; |  | ||||||
| }; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
| @@ -1,119 +0,0 @@ | |||||||
| // Boost enable_if library |  | ||||||
|  |  | ||||||
| // Copyright 2003 (c) 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) |  | ||||||
| //             Jeremiah Willcock (jewillco at osl.iu.edu) |  | ||||||
| //             Andrew Lumsdaine (lums at osl.iu.edu) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef BOOST_UTILITY_ENABLE_IF_HPP |  | ||||||
| #define BOOST_UTILITY_ENABLE_IF_HPP |  | ||||||
|  |  | ||||||
| #include "boost/config.hpp" |  | ||||||
|  |  | ||||||
| // Even the definition of enable_if causes problems on some compilers, |  | ||||||
| // so it's macroed out for all compilers that do not support SFINAE |  | ||||||
|  |  | ||||||
| #ifndef BOOST_NO_SFINAE |  | ||||||
|  |  | ||||||
| namespace boost |  | ||||||
| { |  | ||||||
|   |  | ||||||
|   template <bool B, class T = void> |  | ||||||
|   struct enable_if_c { |  | ||||||
|     typedef T type; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   template <class T> |  | ||||||
|   struct enable_if_c<false, T> {}; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T = void>  |  | ||||||
|   struct enable_if : public enable_if_c<Cond::value, T> {}; |  | ||||||
|  |  | ||||||
|   template <bool B, class T> |  | ||||||
|   struct lazy_enable_if_c { |  | ||||||
|     typedef typename T::type type; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   template <class T> |  | ||||||
|   struct lazy_enable_if_c<false, T> {}; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T>  |  | ||||||
|   struct lazy_enable_if : public lazy_enable_if_c<Cond::value, T> {}; |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   template <bool B, class T = void> |  | ||||||
|   struct disable_if_c { |  | ||||||
|     typedef T type; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   template <class T> |  | ||||||
|   struct disable_if_c<true, T> {}; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T = void>  |  | ||||||
|   struct disable_if : public disable_if_c<Cond::value, T> {}; |  | ||||||
|  |  | ||||||
|   template <bool B, class T> |  | ||||||
|   struct lazy_disable_if_c { |  | ||||||
|     typedef typename T::type type; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   template <class T> |  | ||||||
|   struct lazy_disable_if_c<true, T> {}; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T>  |  | ||||||
|   struct lazy_disable_if : public lazy_disable_if_c<Cond::value, T> {}; |  | ||||||
|  |  | ||||||
| } // namespace boost |  | ||||||
|  |  | ||||||
| #else |  | ||||||
|  |  | ||||||
| namespace boost { |  | ||||||
|  |  | ||||||
|   namespace detail { typedef void enable_if_default_T; } |  | ||||||
|  |  | ||||||
|   template <typename T> |  | ||||||
|   struct enable_if_does_not_work_on_this_compiler; |  | ||||||
|  |  | ||||||
|   template <bool B, class T = detail::enable_if_default_T> |  | ||||||
|   struct enable_if_c : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
|   template <bool B, class T = detail::enable_if_default_T>  |  | ||||||
|   struct disable_if_c : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
|   template <bool B, class T = detail::enable_if_default_T>  |  | ||||||
|   struct lazy_enable_if_c : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
|   template <bool B, class T = detail::enable_if_default_T>  |  | ||||||
|   struct lazy_disable_if_c : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T = detail::enable_if_default_T>  |  | ||||||
|   struct enable_if : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T = detail::enable_if_default_T>  |  | ||||||
|   struct disable_if : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T = detail::enable_if_default_T>  |  | ||||||
|   struct lazy_enable_if : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
|   template <class Cond, class T = detail::enable_if_default_T>  |  | ||||||
|   struct lazy_disable_if : enable_if_does_not_work_on_this_compiler<T> |  | ||||||
|   { }; |  | ||||||
|  |  | ||||||
| } // namespace boost |  | ||||||
|  |  | ||||||
| #endif // BOOST_NO_SFINAE |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| @@ -1,88 +0,0 @@ | |||||||
| // 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 |  | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
| // |  | ||||||
| // See http://www.boost.org/lib/optional for documentation. |  | ||||||
| // |  | ||||||
| // You are welcome to contact the author at: |  | ||||||
| //  fernando_cacciola@hotmail.com |  | ||||||
| // |  | ||||||
| #ifndef BOOST_UTILITY_INPLACE_FACTORY_04APR2007_HPP |  | ||||||
| #ifndef BOOST_PP_IS_ITERATING |  | ||||||
|  |  | ||||||
| #include <boost/utility/detail/in_place_factory_prefix.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() |  | ||||||
|  |  | ||||||
| } // 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 |  | ||||||
|  |  | ||||||
| @@ -1,100 +0,0 @@ | |||||||
| // Boost result_of library |  | ||||||
|  |  | ||||||
| //  Copyright Douglas Gregor 2004. 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) |  | ||||||
|  |  | ||||||
| // For more information, see http://www.boost.org/libs/utility |  | ||||||
| #ifndef BOOST_RESULT_OF_HPP |  | ||||||
| #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/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 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| namespace boost { |  | ||||||
|  |  | ||||||
| template<typename F> struct result_of; |  | ||||||
| template<typename F> struct tr1_result_of; // a TR1-style implementation of result_of |  | ||||||
|  |  | ||||||
| #if !defined(BOOST_NO_SFINAE) && !defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION) |  | ||||||
| namespace detail { |  | ||||||
|  |  | ||||||
| BOOST_MPL_HAS_XXX_TRAIT_DEF(result_type) |  | ||||||
|  |  | ||||||
| template<typename F, typename FArgs, bool HasResultType> struct tr1_result_of_impl; |  | ||||||
| template<typename F> struct cpp0x_result_of_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 |  | ||||||
|   : tr1_result_of_impl<typename remove_cv<F>::type, FArgs, false> { }; |  | ||||||
|  |  | ||||||
| template<typename F, typename FArgs> |  | ||||||
| struct tr1_result_of_impl<F, FArgs, true> |  | ||||||
| { |  | ||||||
|   typedef typename F::result_type type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| template<typename FArgs> |  | ||||||
| struct is_function_with_no_args : mpl::false_ {}; |  | ||||||
|  |  | ||||||
| template<typename F> |  | ||||||
| struct is_function_with_no_args<F(void)> : mpl::true_ {}; |  | ||||||
|  |  | ||||||
| template<typename F, typename FArgs> |  | ||||||
| struct result_of_nested_result : F::template result<FArgs> |  | ||||||
| {}; |  | ||||||
|  |  | ||||||
| template<typename F, typename FArgs> |  | ||||||
| struct tr1_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 |  | ||||||
| {}; |  | ||||||
|  |  | ||||||
| } // end namespace detail |  | ||||||
|  |  | ||||||
| #define BOOST_PP_ITERATION_PARAMS_1 (3,(0,BOOST_RESULT_OF_NUM_ARGS,<boost/utility/detail/result_of_iterate.hpp>)) |  | ||||||
| #include BOOST_PP_ITERATE() |  | ||||||
|  |  | ||||||
| #else |  | ||||||
| #  define BOOST_NO_RESULT_OF 1 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif // BOOST_RESULT_OF_HPP |  | ||||||
| @@ -1,55 +0,0 @@ | |||||||
| // Copyright (C) 2007, 2008 Steven Watanabe, Joseph Gauterin, Niels Dekker |  | ||||||
| // |  | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See |  | ||||||
| // accompanying file LICENSE_1_0.txt or copy at |  | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
| // For more information, see http://www.boost.org |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef BOOST_UTILITY_SWAP_HPP |  | ||||||
| #define BOOST_UTILITY_SWAP_HPP |  | ||||||
|  |  | ||||||
| // Note: the implementation of this utility contains various workarounds: |  | ||||||
| // - swap_impl is put outside the boost namespace, to avoid infinite |  | ||||||
| // recursion (causing stack overflow) when swapping objects of a primitive |  | ||||||
| // type. |  | ||||||
| // - swap_impl has a using-directive, rather than a using-declaration, |  | ||||||
| // because some compilers (including MSVC 7.1, Borland 5.9.3, and |  | ||||||
| // Intel 8.1) don't do argument-dependent lookup when it has a |  | ||||||
| // using-declaration instead. |  | ||||||
| // - boost::swap has two template arguments, instead of one, to |  | ||||||
| // avoid ambiguity when swapping objects of a Boost type that does |  | ||||||
| // not have its own boost::swap overload. |  | ||||||
|  |  | ||||||
| #include <algorithm> //for std::swap |  | ||||||
| #include <cstddef> //for std::size_t |  | ||||||
|  |  | ||||||
| namespace boost_swap_impl |  | ||||||
| { |  | ||||||
|   template<class T> |  | ||||||
|   void swap_impl(T& left, T& right) |  | ||||||
|   { |  | ||||||
|     using namespace std;//use std::swap if argument dependent lookup fails |  | ||||||
|     swap(left,right); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   template<class T, std::size_t N> |  | ||||||
|   void swap_impl(T (& left)[N], T (& right)[N]) |  | ||||||
|   { |  | ||||||
|     for (std::size_t i = 0; i < N; ++i) |  | ||||||
|     { |  | ||||||
|       ::boost_swap_impl::swap_impl(left[i], right[i]); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| namespace boost |  | ||||||
| { |  | ||||||
|   template<class T1, class T2> |  | ||||||
|   void swap(T1& left, T2& right) |  | ||||||
|   { |  | ||||||
|     ::boost_swap_impl::swap_impl(left, right); |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| @@ -1,77 +0,0 @@ | |||||||
| // 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 |  | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
| // |  | ||||||
| // See http://www.boost.org/lib/optional for documentation. |  | ||||||
| // |  | ||||||
| // 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 |  | ||||||
|  |  | ||||||
| #include <boost/utility/detail/in_place_factory_prefix.hpp> |  | ||||||
|  |  | ||||||
| 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() |  | ||||||
|  |  | ||||||
| } // 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,118 +1,68 @@ | |||||||
| // (C) Copyright 2002-2008, Fernando Luis Cacciola Carballal. | // (C) 2002, Fernando Luis Cacciola Carballal. | ||||||
| // | // | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | // This material is provided "as is", with absolutely no warranty expressed | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | // or implied. Any use is at your own risk. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | // | ||||||
|  | // Permission to use or copy this software for any purpose is hereby granted | ||||||
|  | // without fee, provided the above notices are retained on all copies. | ||||||
|  | // Permission to modify the code and to distribute modified code is granted, | ||||||
|  | // provided the above notices are retained, and a notice that the code was | ||||||
|  | // modified is included with the above copyright notice. | ||||||
| // | // | ||||||
| // 21 Ago 2002 (Created) Fernando Cacciola | // 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 |  | ||||||
| // 20 Feb 2009 (Fixed logical const-ness issues) Niels Dekker, Fernando Cacciola |  | ||||||
| // | // | ||||||
| #ifndef BOOST_UTILITY_VALUE_INIT_21AGO2002_HPP | #ifndef BOOST_UTILITY_VALUE_INIT_21AGO2002_HPP | ||||||
| #define 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 | #include "boost/detail/select_type.hpp" | ||||||
| // fact that various compilers haven't fully implemented value-initialization. | #include "boost/type_traits/cv_traits.hpp" | ||||||
| // 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> |  | ||||||
|  |  | ||||||
| namespace boost { | namespace boost { | ||||||
|  |  | ||||||
|  | namespace vinit_detail { | ||||||
|  |  | ||||||
| template<class T> | template<class T> | ||||||
| class value_initialized | class const_T_base | ||||||
| { | { | ||||||
|   private : |   protected : | ||||||
|     struct wrapper |  | ||||||
|     { |  | ||||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x592)) |  | ||||||
|       typename |  | ||||||
| #endif  |  | ||||||
|       remove_const<T>::type data; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     mutable |    const_T_base() : x() {} | ||||||
| #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 const & data() const |  | ||||||
|     { |  | ||||||
|       return wrapper_address()->data; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     T& data() |  | ||||||
|     { |  | ||||||
|       return wrapper_address()->data; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void swap(value_initialized & arg) |  | ||||||
|     { |  | ||||||
|       ::boost::swap( this->data(), arg.data() ); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     operator T const &() const { return this->data(); } |  | ||||||
|  |  | ||||||
|     operator T&() { return this->data(); } |  | ||||||
|  |  | ||||||
|  |    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> | template<class T> | ||||||
| T const& get ( value_initialized<T> const& x ) | T const& get ( value_initialized<T> const& x ) | ||||||
| @@ -125,27 +75,8 @@ T& get ( value_initialized<T>& x ) | |||||||
|   return x.data() ; |   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 | } // namespace boost | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										34
									
								
								include/boost/utility_fwd.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								include/boost/utility_fwd.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | |||||||
|  | //  Boost utility_fwd.hpp header file  ---------------------------------------// | ||||||
|  |  | ||||||
|  | //  (C) Copyright boost.org 2001.  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. | ||||||
|  |  | ||||||
|  | //  See http://www.boost.org/libs/utility for documentation. | ||||||
|  |  | ||||||
|  | #ifndef BOOST_UTILITY_FWD_HPP | ||||||
|  | #define BOOST_UTILITY_FWD_HPP | ||||||
|  |  | ||||||
|  |  | ||||||
|  | namespace boost | ||||||
|  | { | ||||||
|  |  | ||||||
|  |  | ||||||
|  | //  From <boost/utility/base_from_member.hpp>  -------------------------------// | ||||||
|  |  | ||||||
|  | template < typename MemberType, int UniqueID = 0 > | ||||||
|  |     class base_from_member; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | //  From <boost/utility.hpp>  ------------------------------------------------// | ||||||
|  |  | ||||||
|  | class noncopyable; | ||||||
|  |  | ||||||
|  | // Also has a few function templates | ||||||
|  |  | ||||||
|  | }  // namespace boost | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif  // BOOST_UTILITY_FWD_HPP | ||||||
							
								
								
									
										16
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								index.html
									
									
									
									
									
								
							| @@ -7,7 +7,7 @@ | |||||||
| 		<title>Boost Utility Library</title> | 		<title>Boost Utility Library</title> | ||||||
| 	</head> | 	</head> | ||||||
| 	<body bgcolor="#FFFFFF"> | 	<body bgcolor="#FFFFFF"> | ||||||
| 		<h1><IMG SRC="../../boost.png" WIDTH="276" HEIGHT="86" align="center">Boost  | 		<h1><IMG SRC="../../c++boost.gif" WIDTH="276" HEIGHT="86" align="center">Boost  | ||||||
| 			Utility Library</h1> | 			Utility Library</h1> | ||||||
| 		<p>The Boost Utility Library isn't really a single library at all. It is just a  | 		<p>The Boost Utility Library isn't really a single library at all. It is just a  | ||||||
| 			collection for components too small to be called libraries in their own right.</p> | 			collection for components too small to be called libraries in their own right.</p> | ||||||
| @@ -19,24 +19,16 @@ | |||||||
| 				<a href="call_traits.htm">call_traits</a><br> | 				<a href="call_traits.htm">call_traits</a><br> | ||||||
| 				<a href="checked_delete.html">checked_delete</a><br> | 				<a href="checked_delete.html">checked_delete</a><br> | ||||||
| 				<a href="compressed_pair.htm">compressed_pair</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="iterator_adaptors.htm">iterator_adaptors</a><br> | ||||||
|             <a href="generator_iterator.htm">generator iterator adaptors</a><br> |  | ||||||
| 				<a href="operators.htm">operators</a><br> | 				<a href="operators.htm">operators</a><br> | ||||||
| 				<a href="swap.html">swap</a><br> | 				<a href="tie.html">tie</a><br> | ||||||
| 				<a href="throw_exception.html">throw_exception</a><br> | 				<a href="throw_exception.html">throw_exception</a><br> | ||||||
| 				<a href="utility.htm">utility</a><br> | 				<a href="utility.htm">utility</a><br> | ||||||
|                 <a href="value_init.htm">value_init</a></p> |                 <a href="value_init.htm">value_init</a></p> | ||||||
| 		</blockquote> | 		</blockquote> | ||||||
| 		<hr> | 		<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  | 		<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> | 			<!--webbot bot="Timestamp" S-Type="EDITED" S-Format="%d %B, %Y" startspan -->09 January, 2003<!--webbot bot="Timestamp" endspan i-checksum="38582" --></p> | ||||||
|  | 		<p> </p> | ||||||
| 	</body> | 	</body> | ||||||
| </html> | </html> | ||||||
							
								
								
									
										444
									
								
								indirect_iterator.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										444
									
								
								indirect_iterator.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,444 @@ | |||||||
|  | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN"> | ||||||
|  |  | ||||||
|  | <html> | ||||||
|  | <head> | ||||||
|  |     <meta name="generator" content="HTML Tidy, see www.w3.org"> | ||||||
|  |     <meta http-equiv="Content-Type" content="text/html; charset=windows-1252"> | ||||||
|  |     <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> | ||||||
|  |     <meta name="ProgId" content="FrontPage.Editor.Document"> | ||||||
|  |  | ||||||
|  |     <title>Indirect Iterator Adaptor Documentation</title> | ||||||
|  | </head> | ||||||
|  |  | ||||||
|  | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  | 	 | ||||||
|  |     <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" align= | ||||||
|  |     "center" width="277" height="86">  | ||||||
|  |  | ||||||
|  |     <h1>Indirect Iterator Adaptor</h1> | ||||||
|  |     Defined in header <a href= | ||||||
|  |     "../../boost/iterator_adaptors.hpp">boost/iterator_adaptors.hpp</a>  | ||||||
|  |  | ||||||
|  |     <p>The indirect iterator adaptor augments an iterator by applying an | ||||||
|  |     <b>extra</b> dereference inside of <tt>operator*()</tt>. For example, this | ||||||
|  |     iterator makes it possible to view a container of pointers or | ||||||
|  |     smart-pointers (e.g. <tt>std::list<boost::shared_ptr<foo> | ||||||
|  |     ></tt>) as if it were a container of the pointed-to type. The following | ||||||
|  |     <b>pseudo-code</b> shows the basic idea of the indirect iterator: | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | // inside a hypothetical indirect_iterator class... | ||||||
|  | typedef std::iterator_traits<BaseIterator>::value_type Pointer; | ||||||
|  | typedef std::iterator_traits<Pointer>::reference reference; | ||||||
|  |  | ||||||
|  | reference indirect_iterator::operator*() const { | ||||||
|  |   return **this->base_iterator; | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h2>Synopsis</h2> | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | namespace boost { | ||||||
|  |   template <class BaseIterator, | ||||||
|  |             class Value, class Reference, class Category, class Pointer> | ||||||
|  |   struct indirect_iterator_generator; | ||||||
|  |    | ||||||
|  |   template <class BaseIterator, | ||||||
|  |             class Value, class Reference, class ConstReference,  | ||||||
|  |             class Category, class Pointer, class ConstPointer> | ||||||
|  |   struct indirect_iterator_pair_generator; | ||||||
|  |  | ||||||
|  |   template <class BaseIterator> | ||||||
|  |   typename indirect_iterator_generator<BaseIterator>::type | ||||||
|  |   make_indirect_iterator(BaseIterator base)   | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <h2><a name="indirect_iterator_generator">The Indirect Iterator Type | ||||||
|  |     Generator</a></h2> | ||||||
|  |     The <tt>indirect_iterator_generator</tt> template is a <a href= | ||||||
|  |     "../../more/generic_programming.html#type_generator">generator</a> of | ||||||
|  |     indirect iterator types. The main template parameter for this class is the | ||||||
|  |     <tt>BaseIterator</tt> type that is being wrapped. In most cases the type of | ||||||
|  |     the elements being pointed to can be deduced using | ||||||
|  |     <tt>std::iterator_traits</tt>, but in some situations the user may want to | ||||||
|  |     override this type, so there are also template parameters that allow a user | ||||||
|  |     to control the <tt>value_type</tt>, <tt>pointer</tt>, and | ||||||
|  |     <tt>reference</tt> types of the resulting iterators.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class BaseIterator, | ||||||
|  |           class Value, class Reference, class Pointer> | ||||||
|  | class indirect_iterator_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   typedef <tt><a href= | ||||||
|  | "./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> type; // the resulting indirect iterator type  | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Example</h3> | ||||||
|  |     This example uses the <tt>indirect_iterator_generator</tt> to create | ||||||
|  |     indirect iterators which dereference the pointers stored in the | ||||||
|  |     <tt>pointers_to_chars</tt> array to access the <tt>char</tt>s in the | ||||||
|  |     <tt>characters</tt> array.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <vector> | ||||||
|  | #include <iostream> | ||||||
|  | #include <iterator> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   char characters[] = "abcdefg"; | ||||||
|  |   const int N = sizeof(characters)/sizeof(char) - 1; // -1 since characters has a null char | ||||||
|  |   char* pointers_to_chars[N];                        // at the end. | ||||||
|  |   for (int i = 0; i < N; ++i) | ||||||
|  |     pointers_to_chars[i] = &characters[i]; | ||||||
|  |    | ||||||
|  |   boost::indirect_iterator_generator<char**, char>::type  | ||||||
|  |     indirect_first(pointers_to_chars), indirect_last(pointers_to_chars + N); | ||||||
|  |  | ||||||
|  |   std::copy(indirect_first, indirect_last, std::ostream_iterator<char>(std::cout, ",")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |    | ||||||
|  |   // to be continued... | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  |     <table border> | ||||||
|  |       <tr> | ||||||
|  |         <th>Parameter | ||||||
|  |  | ||||||
|  |         <th>Description | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>BaseIterator</tt>  | ||||||
|  |  | ||||||
|  |         <td>The iterator type being wrapped. The <tt>value_type</tt> | ||||||
|  |         of the base iterator should itself be dereferenceable.   | ||||||
|  |         The return type of the <tt>operator*</tt> for the | ||||||
|  |         <tt>value_type</tt> should match the <tt>Reference</tt> type. | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Value</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>value_type</tt> of the resulting iterator, unless const. If | ||||||
|  |         Value is <tt>const X</tt>, a conforming compiler makes the | ||||||
|  |         <tt>value_type</tt> <tt><i>non-</i>const X</tt><a href= | ||||||
|  |         "iterator_adaptors.htm#1">[1]</a>. Note that if the default | ||||||
|  |          is used for <tt>Value</tt>, then there must be a valid specialization | ||||||
|  |          of <tt>iterator_traits</tt> for the value type of the base iterator. | ||||||
|  |          <br> | ||||||
|  |          <b>Default:</b> <tt>std::iterator_traits<<br> | ||||||
|  |          <20> std::iterator_traits<BaseIterator>::value_type | ||||||
|  |         >::value_type</tt><a href="#2">[2]</a>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Reference</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>reference</tt> type of the resulting iterator, and in | ||||||
|  |         particular, the result type of <tt>operator*()</tt>.<br> | ||||||
|  |          <b>Default:</b> <tt>Value&</tt>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Pointer</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>pointer</tt> type of the resulting iterator, and in | ||||||
|  |         particular, the result type of <tt>operator->()</tt>.<br> | ||||||
|  |          <b>Default:</b> <tt>Value*</tt>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Category</tt>  | ||||||
|  |         <td>The <tt>iterator_category</tt> type for the resulting iterator.<br> | ||||||
|  |          <b>Default:</b> | ||||||
|  |         <tt>std::iterator_traits<BaseIterator>::iterator_category</tt>  | ||||||
|  |  | ||||||
|  |     </table> | ||||||
|  |  | ||||||
|  |     <h3>Concept Model</h3> | ||||||
|  |     The indirect iterator will model whichever <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/Iterators.html">standard iterator | ||||||
|  |     concept category</a> is modeled by the base iterator. Thus, if the | ||||||
|  |     base iterator is a model of <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  |     Access Iterator</a> then so is the resulting indirect iterator. If | ||||||
|  |     the base iterator models a more restrictive concept, the resulting | ||||||
|  |     indirect iterator will model the same concept <a href="#3">[3]</a>. | ||||||
|  |  | ||||||
|  |     <h3>Members</h3> | ||||||
|  |     The indirect iterator type implements the member functions and operators | ||||||
|  |     required of the <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random Access | ||||||
|  |     Iterator</a> concept. In addition it has the following constructor:  | ||||||
|  | <pre> | ||||||
|  | explicit indirect_iterator_generator::type(const BaseIterator& it) | ||||||
|  | </pre> | ||||||
|  |     <br> | ||||||
|  |      <br> | ||||||
|  |       | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <p> | ||||||
|  |  | ||||||
|  |     <h2><a name="indirect_iterator_pair_generator">The Indirect Iterator Pair | ||||||
|  |     Generator</a></h2> | ||||||
|  |     Sometimes a pair of <tt>const</tt>/non-<tt>const</tt> pair of iterators is | ||||||
|  |     needed, such as when implementing a container. The | ||||||
|  |     <tt>indirect_iterator_pair_generator</tt> class makes it more convenient to | ||||||
|  |     create this pair of iterator types.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  |   template <class BaseIterator, | ||||||
|  |             class Value, class Reference, class ConstReference,  | ||||||
|  |             class Category, class Pointer, class ConstPointer> | ||||||
|  |   struct indirect_iterator_pair_generator; | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   typedef <tt><a href= | ||||||
|  | "./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> iterator;       // the mutable indirect iterator type  | ||||||
|  |   typedef <tt><a href= | ||||||
|  | "./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> const_iterator; // the immutable indirect iterator type  | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Example</h3> | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  |   // continuing from the last example... | ||||||
|  |  | ||||||
|  |   typedef boost::indirect_iterator_pair_generator<char**, | ||||||
|  |     char, char*, char&, const char*, const char&> PairGen; | ||||||
|  |  | ||||||
|  |   char mutable_characters[N]; | ||||||
|  |   char* pointers_to_mutable_chars[N]; | ||||||
|  |   for (int i = 0; i < N; ++i) | ||||||
|  |     pointers_to_mutable_chars[i] = &mutable_characters[i]; | ||||||
|  |  | ||||||
|  |   PairGen::iterator mutable_indirect_first(pointers_to_mutable_chars), | ||||||
|  |     mutable_indirect_last(pointers_to_mutable_chars + N); | ||||||
|  |   PairGen::const_iterator const_indirect_first(pointers_to_chars), | ||||||
|  |     const_indirect_last(pointers_to_chars + N); | ||||||
|  |  | ||||||
|  |   std::transform(const_indirect_first, const_indirect_last, | ||||||
|  |      mutable_indirect_first, std::bind1st(std::plus<char>(), 1)); | ||||||
|  |  | ||||||
|  |   std::copy(mutable_indirect_first, mutable_indirect_last, | ||||||
|  |       std::ostream_iterator<char>(std::cout, ",")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |   // to be continued... | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <p>The output is: | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | b,c,d,e,f,g,h, | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  |     <table border> | ||||||
|  |       <tr> | ||||||
|  |         <th>Parameter | ||||||
|  |  | ||||||
|  |         <th>Description | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>BaseIterator</tt>  | ||||||
|  |  | ||||||
|  |         <td>The iterator type being wrapped. The <tt>value_type</tt> of the | ||||||
|  |         base iterator should itself be dereferenceable. | ||||||
|  |         The return type of the <tt>operator*</tt> for the | ||||||
|  |         <tt>value_type</tt> should match the <tt>Reference</tt> type. | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Value</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>value_type</tt> of the resulting iterators. | ||||||
|  |          If Value is <tt>const X</tt>, a conforming compiler makes the | ||||||
|  |          <tt>value_type</tt> <tt><i>non-</i>const X</tt><a href= | ||||||
|  |          "iterator_adaptors.htm#1">[1]</a>. Note that if the default | ||||||
|  |          is used for <tt>Value</tt>, then there must be a valid | ||||||
|  |          specialization of <tt>iterator_traits</tt> for the value type | ||||||
|  |          of the base iterator.<br> | ||||||
|  |  | ||||||
|  |          <b>Default:</b> <tt>std::iterator_traits<<br> | ||||||
|  |          <20> std::iterator_traits<BaseIterator>::value_type | ||||||
|  |         >::value_type</tt><a href="#2">[2]</a>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Reference</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>reference</tt> type of the resulting <tt>iterator</tt>, and | ||||||
|  |         in particular, the result type of its <tt>operator*()</tt>.<br> | ||||||
|  |          <b>Default:</b> <tt>Value&</tt>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>ConstReference</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>reference</tt> type of the resulting | ||||||
|  |         <tt>const_iterator</tt>, and in particular, the result type of its | ||||||
|  |         <tt>operator*()</tt>.<br> | ||||||
|  |          <b>Default:</b> <tt>const Value&</tt>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Category</tt>  | ||||||
|  |         <td>The <tt>iterator_category</tt> type for the resulting iterator.<br> | ||||||
|  |          <b>Default:</b> | ||||||
|  |         <tt>std::iterator_traits<BaseIterator>::iterator_category</tt>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Pointer</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>pointer</tt> type of the resulting <tt>iterator</tt>, and | ||||||
|  |         in particular, the result type of its <tt>operator->()</tt>.<br> | ||||||
|  |          <b>Default:</b> <tt>Value*</tt>  | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>ConstPointer</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>pointer</tt> type of the resulting <tt>const_iterator</tt>, | ||||||
|  |         and in particular, the result type of its <tt>operator->()</tt>.<br> | ||||||
|  |          <b>Default:</b> <tt>const Value*</tt>  | ||||||
|  |  | ||||||
|  |     </table> | ||||||
|  |  | ||||||
|  |     <h3>Concept Model</h3> | ||||||
|  |  | ||||||
|  |     The indirect iterators will model whichever <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/Iterators.html">standard iterator | ||||||
|  |     concept category</a> is modeled by the base iterator. Thus, if the | ||||||
|  |     base iterator is a model of <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  |     Access Iterator</a> then so are the resulting indirect | ||||||
|  |     iterators. If the base iterator models a more restrictive concept, | ||||||
|  |     the resulting indirect iterators will model the same concept <a | ||||||
|  |     href="#3">[3]</a>. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <h3>Members</h3> | ||||||
|  |     The resulting <tt>iterator</tt> and <tt>const_iterator</tt> types implement | ||||||
|  |     the member functions and operators required of the <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random Access | ||||||
|  |     Iterator</a> concept. In addition they support the following constructors:  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | explicit indirect_iterator_pair_generator::iterator(const BaseIterator& it) | ||||||
|  | explicit indirect_iterator_pair_generator::const_iterator(const BaseIterator& it) | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |     <br> | ||||||
|  |      <br> | ||||||
|  |       | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <p> | ||||||
|  |  | ||||||
|  |     <h2><a name="make_indirect_iterator">The Indirect Iterator Object | ||||||
|  |     Generator</a></h2> | ||||||
|  |     The <tt>make_indirect_iterator()</tt> function provides a more convenient | ||||||
|  |     way to create indirect iterator objects. The function saves the user the | ||||||
|  |     trouble of explicitly writing out the iterator types.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class BaseIterator> | ||||||
|  | typename indirect_iterator_generator<BaseIterator>::type | ||||||
|  | make_indirect_iterator(BaseIterator base)   | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Example</h3> | ||||||
|  |     Here we again print the <tt>char</tt>s from the array <tt>characters</tt> | ||||||
|  |     by accessing them through the array of pointers <tt>pointer_to_chars</tt>, | ||||||
|  |     but this time we use the <tt>make_indirect_iterator()</tt> function which | ||||||
|  |     saves us some typing.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  |   // continuing from the last example... | ||||||
|  |  | ||||||
|  |   std::copy(boost::make_indirect_iterator(pointers_to_chars),  | ||||||
|  |       boost::make_indirect_iterator(pointers_to_chars + N), | ||||||
|  |       std::ostream_iterator<char>(std::cout, ",")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |     The output is:  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | a,b,c,d,e,f,g, | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <h3>Notes</h3> | ||||||
|  |  | ||||||
|  |     <p> | ||||||
|  |  | ||||||
|  |     <p><a name="2">[2]</a> If your compiler does not support partial | ||||||
|  |     specialization and the base iterator or its <tt>value_type</tt> is a | ||||||
|  |     builtin pointer type, you will not be able to use the default for | ||||||
|  |     <tt>Value</tt> and will need to specify this type explicitly. | ||||||
|  |  | ||||||
|  |     <p><a name="3">[3]</a>There is a caveat to which concept the | ||||||
|  |     indirect iterator can model.  If the return type of the | ||||||
|  |     <tt>operator*</tt> for the base iterator's value type is not a | ||||||
|  |     true reference, then strickly speaking, the indirect iterator can | ||||||
|  |     not be a model of <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/ForwardIterator.html">Forward | ||||||
|  |     Iterator</a> or any of the concepts that refine it. In this case | ||||||
|  |     the <tt>Category</tt> for the indirect iterator should be | ||||||
|  |     specified as <tt>std::input_iterator_tag</tt>. However, even in | ||||||
|  |     this case, if the base iterator is a random access iterator, the | ||||||
|  |     resulting indirect iterator will still satisfy most of the | ||||||
|  |     requirements for <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  |     Access Iterator</a>. | ||||||
|  |      | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <p>Revised  | ||||||
|  |     <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %b %Y" startspan -->18 Sep 2001<!--webbot bot="Timestamp" endspan i-checksum="14941" --> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <p>© Copyright Jeremy Siek and David Abrahams 2001. 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.  | ||||||
|  |     <!--  LocalWords:  html charset alt gif hpp BaseIterator const namespace struct | ||||||
|  |              --> | ||||||
|  |       | ||||||
|  |     <!--  LocalWords:  ConstPointer ConstReference typename iostream int abcdefg | ||||||
|  |              --> | ||||||
|  |      <!--  LocalWords:  sizeof  PairGen pre Jeremy Siek David Abrahams | ||||||
|  |              --> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | </body> | ||||||
|  | </html> | ||||||
							
								
								
									
										62
									
								
								indirect_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								indirect_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | |||||||
|  | // (C) Copyright Jeremy Siek 2000. 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. | ||||||
|  |  | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <vector> | ||||||
|  | #include <iostream> | ||||||
|  | #include <iterator> | ||||||
|  | #include <functional> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   char characters[] = "abcdefg"; | ||||||
|  |   const int N = sizeof(characters)/sizeof(char) - 1; // -1 since characters has a null char | ||||||
|  |   char* pointers_to_chars[N];                        // at the end. | ||||||
|  |   for (int i = 0; i < N; ++i) | ||||||
|  |     pointers_to_chars[i] = &characters[i]; | ||||||
|  |  | ||||||
|  |   // Example of using indirect_iterator_generator | ||||||
|  |    | ||||||
|  |   boost::indirect_iterator_generator<char**, char>::type  | ||||||
|  |     indirect_first(pointers_to_chars), indirect_last(pointers_to_chars + N); | ||||||
|  |  | ||||||
|  |   std::copy(indirect_first, indirect_last, std::ostream_iterator<char>(std::cout, ",")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |    | ||||||
|  |  | ||||||
|  |   // Example of using indirect_iterator_pair_generator | ||||||
|  |  | ||||||
|  |   typedef boost::indirect_iterator_pair_generator<char**, char> PairGen; | ||||||
|  |  | ||||||
|  |   char mutable_characters[N]; | ||||||
|  |   char* pointers_to_mutable_chars[N]; | ||||||
|  |   for (int j = 0; j < N; ++j) | ||||||
|  |     pointers_to_mutable_chars[j] = &mutable_characters[j]; | ||||||
|  |  | ||||||
|  |   PairGen::iterator mutable_indirect_first(pointers_to_mutable_chars), | ||||||
|  |     mutable_indirect_last(pointers_to_mutable_chars + N); | ||||||
|  |   PairGen::const_iterator const_indirect_first(pointers_to_chars), | ||||||
|  |     const_indirect_last(pointers_to_chars + N); | ||||||
|  |  | ||||||
|  |   std::transform(const_indirect_first, const_indirect_last, | ||||||
|  |                  mutable_indirect_first, std::bind1st(std::plus<char>(), 1)); | ||||||
|  |  | ||||||
|  |   std::copy(mutable_indirect_first, mutable_indirect_last, | ||||||
|  |             std::ostream_iterator<char>(std::cout, ",")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |    | ||||||
|  |   // Example of using make_indirect_iterator() | ||||||
|  |  | ||||||
|  | #if !defined(BOOST_MSVC) || BOOST_MSVC > 1300 | ||||||
|  |   std::copy(boost::make_indirect_iterator(pointers_to_chars),  | ||||||
|  |             boost::make_indirect_iterator(pointers_to_chars + N), | ||||||
|  |             std::ostream_iterator<char>(std::cout, ",")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  | #endif | ||||||
|  |    | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
							
								
								
									
										46
									
								
								iterator_adaptor_examples.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								iterator_adaptor_examples.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | |||||||
|  | // (C) Copyright Jeremy Siek 2000. 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. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include <functional> | ||||||
|  | #include <algorithm> | ||||||
|  | #include <iostream> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  | #include <boost/pending/integer_range.hpp> | ||||||
|  |  | ||||||
|  | int | ||||||
|  | main(int, char*[]) | ||||||
|  | { | ||||||
|  |   // This is a simple example of using the transform_iterators class to | ||||||
|  |   // generate iterators that multiply the value returned by dereferencing | ||||||
|  |   // the iterator. In this case we are multiplying by 2. | ||||||
|  |   // Would be cooler to use lambda library in this example. | ||||||
|  |  | ||||||
|  |   int x[] = { 1, 2, 3, 4, 5, 6, 7, 8 }; | ||||||
|  |  | ||||||
|  |   typedef std::binder1st< std::multiplies<int> > Function; | ||||||
|  |   typedef boost::transform_iterator_generator<Function, int*  | ||||||
|  |   >::type doubling_iterator; | ||||||
|  |  | ||||||
|  |   doubling_iterator i(x, std::bind1st(std::multiplies<int>(), 2)), | ||||||
|  |     i_end(x + sizeof(x)/sizeof(int), std::bind1st(std::multiplies<int>(), 2)); | ||||||
|  |  | ||||||
|  |   std::cout << "multiplying the array by 2:" << std::endl; | ||||||
|  |   while (i != i_end) | ||||||
|  |     std::cout << *i++ << " "; | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // Here is an example of counting from 0 to 5 using the integer_range class. | ||||||
|  |  | ||||||
|  |   boost::integer_range<int> r(0,5); | ||||||
|  |  | ||||||
|  |   std::cout << "counting to from 0 to 4:" << std::endl; | ||||||
|  |   std::copy(r.begin(), r.end(), std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								iterator_adaptors.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								iterator_adaptors.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								iterator_adaptors.ppt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								iterator_adaptors.ppt
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										217
									
								
								iterator_traits_test.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										217
									
								
								iterator_traits_test.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,217 @@ | |||||||
|  | //  (C) Copyright David Abrahams 2002. 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. | ||||||
|  |  | ||||||
|  | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
|  | //  Revision History | ||||||
|  | //  04 Mar 2001 Patches for Intel C++ (Dave Abrahams) | ||||||
|  | //  19 Feb 2001 Take advantage of improved iterator_traits to do more tests | ||||||
|  | //              on MSVC. Reordered some #ifdefs for coherency. | ||||||
|  | //              (David Abrahams) | ||||||
|  | //  13 Feb 2001 Test new VC6 workarounds (David Abrahams) | ||||||
|  | //  11 Feb 2001 Final fixes for Borland (David Abrahams) | ||||||
|  | //  11 Feb 2001 Some fixes for Borland get it closer on that compiler | ||||||
|  | //              (David Abrahams) | ||||||
|  | //  07 Feb 2001 More comprehensive testing; factored out static tests for | ||||||
|  | //              better reuse (David Abrahams) | ||||||
|  | //  21 Jan 2001 Quick fix to my_iterator, which wasn't returning a | ||||||
|  | //              reference type from operator* (David Abrahams) | ||||||
|  | //  19 Jan 2001 Initial version with iterator operators (David Abrahams) | ||||||
|  |  | ||||||
|  | #include <boost/detail/iterator.hpp> | ||||||
|  | #include <boost/type_traits/is_same.hpp> | ||||||
|  | #include <boost/operators.hpp> | ||||||
|  | #include <boost/static_assert.hpp> | ||||||
|  | #include <iterator> | ||||||
|  | #include <vector> | ||||||
|  | #include <list> | ||||||
|  | #include <cassert> | ||||||
|  | #include <iostream> | ||||||
|  |  | ||||||
|  | // A UDT for which we can specialize std::iterator_traits<element*> on | ||||||
|  | // compilers which don't support partial specialization. There's no | ||||||
|  | // other reasonable way to test pointers on those compilers. | ||||||
|  | struct element {}; | ||||||
|  |  | ||||||
|  | // An iterator for which we can get traits. | ||||||
|  | struct my_iterator1 | ||||||
|  |     : boost::forward_iterator_helper<my_iterator1, char, long, const char*, const char&> | ||||||
|  | { | ||||||
|  |     my_iterator1(const char* p) : m_p(p) {} | ||||||
|  |      | ||||||
|  |     bool operator==(const my_iterator1& rhs) const | ||||||
|  |         { return this->m_p == rhs.m_p; } | ||||||
|  |  | ||||||
|  |     my_iterator1& operator++() { ++this->m_p; return *this; } | ||||||
|  |     const char& operator*() { return *m_p; } | ||||||
|  |  private: | ||||||
|  |     const char* m_p; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Used to prove that we don't require std::iterator<> in the hierarchy under | ||||||
|  | // MSVC6, and that we can compute all the traits for a standard-conforming UDT | ||||||
|  | // iterator. | ||||||
|  | struct my_iterator2 | ||||||
|  |     : boost::equality_comparable<my_iterator2 | ||||||
|  |     , boost::incrementable<my_iterator2 | ||||||
|  |     , boost::dereferenceable<my_iterator2,const char*> > > | ||||||
|  | { | ||||||
|  |     typedef char value_type; | ||||||
|  |     typedef long difference_type; | ||||||
|  |     typedef const char* pointer; | ||||||
|  |     typedef const char& reference; | ||||||
|  |     typedef std::forward_iterator_tag iterator_category; | ||||||
|  |      | ||||||
|  |     my_iterator2(const char* p) : m_p(p) {} | ||||||
|  |      | ||||||
|  |     bool operator==(const my_iterator2& rhs) const | ||||||
|  |         { return this->m_p == rhs.m_p; } | ||||||
|  |  | ||||||
|  |     my_iterator2& operator++() { ++this->m_p; return *this; } | ||||||
|  |     const char& operator*() { return *m_p; } | ||||||
|  |  private: | ||||||
|  |     const char* m_p; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Used to prove that we're not overly confused by the existence of | ||||||
|  | // std::iterator<> in the hierarchy under MSVC6 - we should find that | ||||||
|  | // boost::detail::iterator_traits<my_iterator3>::difference_type is int. | ||||||
|  | struct my_iterator3 : my_iterator1 | ||||||
|  | { | ||||||
|  |     typedef int difference_type; | ||||||
|  |     my_iterator3(const char* p) | ||||||
|  |         : my_iterator1(p) {} | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // | ||||||
|  | // Assertion tools.  Used instead of BOOST_STATIC_ASSERT because that | ||||||
|  | // doesn't give us a nice stack backtrace | ||||||
|  | // | ||||||
|  | template <bool = false> struct assertion; | ||||||
|  |  | ||||||
|  | template <> struct assertion<true> | ||||||
|  | { | ||||||
|  |     typedef char type; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class T, class U> | ||||||
|  | struct assert_same | ||||||
|  |     : assertion<(::boost::is_same<T,U>::value)> | ||||||
|  | { | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Iterator tests | ||||||
|  | template <class Iterator, | ||||||
|  |     class value_type, class difference_type, class pointer, class reference, class category> | ||||||
|  | struct non_portable_tests | ||||||
|  | { | ||||||
|  |     typedef typename boost::detail::iterator_traits<Iterator>::pointer test_pt; | ||||||
|  |     typedef typename boost::detail::iterator_traits<Iterator>::reference test_rt; | ||||||
|  |     typedef typename assert_same<test_pt, pointer>::type a1; | ||||||
|  |     typedef typename assert_same<test_rt, reference>::type a2; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class Iterator, | ||||||
|  |     class value_type, class difference_type, class pointer, class reference, class category> | ||||||
|  | struct portable_tests | ||||||
|  | { | ||||||
|  |     typedef typename boost::detail::iterator_traits<Iterator>::difference_type test_dt; | ||||||
|  |     typedef typename boost::detail::iterator_traits<Iterator>::iterator_category test_cat; | ||||||
|  |     typedef typename assert_same<test_dt, difference_type>::type a1; | ||||||
|  |     typedef typename assert_same<test_cat, category>::type a2; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // Test iterator_traits | ||||||
|  | template <class Iterator, | ||||||
|  |     class value_type, class difference_type, class pointer, class reference, class category> | ||||||
|  | struct input_iterator_test | ||||||
|  |     : portable_tests<Iterator,value_type,difference_type,pointer,reference,category> | ||||||
|  | { | ||||||
|  |     typedef typename boost::detail::iterator_traits<Iterator>::value_type test_vt; | ||||||
|  |     typedef typename assert_same<test_vt, value_type>::type a1; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class Iterator, | ||||||
|  |     class value_type, class difference_type, class pointer, class reference, class category> | ||||||
|  | struct non_pointer_test | ||||||
|  |     : input_iterator_test<Iterator,value_type,difference_type,pointer,reference,category> | ||||||
|  |       , non_portable_tests<Iterator,value_type,difference_type,pointer,reference,category> | ||||||
|  | { | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class Iterator, | ||||||
|  |     class value_type, class difference_type, class pointer, class reference, class category> | ||||||
|  | struct maybe_pointer_test | ||||||
|  |     : portable_tests<Iterator,value_type,difference_type,pointer,reference,category> | ||||||
|  | #ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION | ||||||
|  |       , non_portable_tests<Iterator,value_type,difference_type,pointer,reference,category> | ||||||
|  | #endif | ||||||
|  | { | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | input_iterator_test<std::istream_iterator<int>, int, std::ptrdiff_t, int*, int&, std::input_iterator_tag> | ||||||
|  |         istream_iterator_test; | ||||||
|  |  | ||||||
|  | #if defined(__BORLANDC__) && !defined(__SGI_STL_PORT) | ||||||
|  | typedef ::std::char_traits<char>::off_type distance; | ||||||
|  | non_pointer_test<std::ostream_iterator<int>,int, | ||||||
|  |     distance,int*,int&,std::output_iterator_tag> ostream_iterator_test; | ||||||
|  | #elif defined(BOOST_MSVC_STD_ITERATOR) | ||||||
|  | non_pointer_test<std::ostream_iterator<int>, | ||||||
|  |     int, void, int*, int&, std::output_iterator_tag> | ||||||
|  |         ostream_iterator_test; | ||||||
|  | #else | ||||||
|  | non_pointer_test<std::ostream_iterator<int>, | ||||||
|  |     void, void, void, void, std::output_iterator_tag> | ||||||
|  |         ostream_iterator_test; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #ifdef __KCC | ||||||
|  |   typedef long std_list_diff_type; | ||||||
|  | #else | ||||||
|  |   typedef std::ptrdiff_t std_list_diff_type; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | non_pointer_test<std::list<int>::iterator, int, std_list_diff_type, int*, int&, std::bidirectional_iterator_tag> | ||||||
|  |         list_iterator_test; | ||||||
|  |  | ||||||
|  | maybe_pointer_test<std::vector<int>::iterator, int, std::ptrdiff_t, int*, int&, std::random_access_iterator_tag> | ||||||
|  |         vector_iterator_test; | ||||||
|  |  | ||||||
|  | maybe_pointer_test<int*, int, std::ptrdiff_t, int*, int&, std::random_access_iterator_tag> | ||||||
|  |         int_pointer_test; | ||||||
|  |  | ||||||
|  | non_pointer_test<my_iterator1, char, long, const char*, const char&, std::forward_iterator_tag> | ||||||
|  |        my_iterator1_test; | ||||||
|  |                      | ||||||
|  | non_pointer_test<my_iterator2, char, long, const char*, const char&, std::forward_iterator_tag> | ||||||
|  |        my_iterator2_test; | ||||||
|  |  | ||||||
|  | non_pointer_test<my_iterator3, char, int, const char*, const char&, std::forward_iterator_tag> | ||||||
|  |        my_iterator3_test; | ||||||
|  |  | ||||||
|  | int main() | ||||||
|  | { | ||||||
|  |     char chars[100]; | ||||||
|  |     int ints[100]; | ||||||
|  |  | ||||||
|  |     for (int length = 3; length < 100; length += length / 3) | ||||||
|  |     { | ||||||
|  |         std::list<int> l(length); | ||||||
|  |         assert(boost::detail::distance(l.begin(), l.end()) == length); | ||||||
|  |          | ||||||
|  |         std::vector<int> v(length); | ||||||
|  |         assert(boost::detail::distance(v.begin(), v.end()) == length); | ||||||
|  |  | ||||||
|  |         assert(boost::detail::distance(&ints[0], ints + length) == length); | ||||||
|  |         assert(boost::detail::distance(my_iterator1(chars), my_iterator1(chars + length)) == length); | ||||||
|  |         assert(boost::detail::distance(my_iterator2(chars), my_iterator2(chars + length)) == length); | ||||||
|  |         assert(boost::detail::distance(my_iterator3(chars), my_iterator3(chars + length)) == length); | ||||||
|  |     } | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
| @@ -1,9 +1,10 @@ | |||||||
| //  Demonstrate and test boost/operators.hpp on std::iterators  --------------// | //  Demonstrate and test boost/operators.hpp on std::iterators  --------------// | ||||||
|  |  | ||||||
| //  (C) Copyright Jeremy Siek 1999. | //  (C) Copyright Jeremy Siek 1999. Permission to copy, use, modify, | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | //  sell and distribute this software is granted provided this | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | //  copyright notice appears in all copies. This software is provided | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | //  "as is" without express or implied warranty, and with no claim as | ||||||
|  | //  to its suitability for any purpose. | ||||||
|  |  | ||||||
| //  See http://www.boost.org for most recent version including documentation. | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| @@ -23,7 +24,7 @@ | |||||||
| #include <cstring>    // for std::strcmp | #include <cstring>    // for std::strcmp | ||||||
| #include <iostream>   // for std::cout (std::endl, ends, and flush indirectly) | #include <iostream>   // for std::cout (std::endl, ends, and flush indirectly) | ||||||
| #include <string>     // for std::string | #include <string>     // for std::string | ||||||
| #include <sstream>    // for std::stringstream | #include <strstream>  // for std::ostrstream | ||||||
|  |  | ||||||
| # ifdef BOOST_NO_STDC_NAMESPACE | # ifdef BOOST_NO_STDC_NAMESPACE | ||||||
|     namespace std { using ::strcmp; } |     namespace std { using ::strcmp; } | ||||||
| @@ -64,16 +65,20 @@ class test_opr_base | |||||||
| protected: | protected: | ||||||
|     // Test data and types |     // Test data and types | ||||||
|     BOOST_STATIC_CONSTANT( std::size_t, fruit_length = 6u ); |     BOOST_STATIC_CONSTANT( std::size_t, fruit_length = 6u ); | ||||||
|  |     BOOST_STATIC_CONSTANT( std::size_t, scratch_length = 40u ); | ||||||
|  |  | ||||||
|     typedef std::string  fruit_array_type[ fruit_length ]; |     typedef std::string  fruit_array_type[ fruit_length ]; | ||||||
|  |     typedef char         scratch_array_type[ scratch_length ]; | ||||||
|  |  | ||||||
|     static  fruit_array_type    fruit; |     static  fruit_array_type    fruit; | ||||||
|  |     static  scratch_array_type  scratch; | ||||||
|  |  | ||||||
| };  // test_opr_base | };  // test_opr_base | ||||||
|  |  | ||||||
| #ifndef BOOST_NO_INCLASS_MEMBER_INITIALIZATION | #ifndef BOOST_NO_INCLASS_MEMBER_INITIALIZATION | ||||||
| //  A definition is required even for integral static constants | //  A definition is required even for integral static constants | ||||||
| const std::size_t test_opr_base::fruit_length; | const std::size_t test_opr_base::fruit_length; | ||||||
|  | const std::size_t test_opr_base::scratch_length; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| template <typename T, typename R = T&, typename P = T*> | template <typename T, typename R = T&, typename P = T*> | ||||||
| @@ -115,6 +120,9 @@ private: | |||||||
| test_opr_base::fruit_array_type | test_opr_base::fruit_array_type | ||||||
|  test_opr_base::fruit = { "apple", "orange", "pear", "peach", "grape", "plum" }; |  test_opr_base::fruit = { "apple", "orange", "pear", "peach", "grape", "plum" }; | ||||||
|  |  | ||||||
|  | test_opr_base::scratch_array_type | ||||||
|  |  test_opr_base::scratch = ""; | ||||||
|  |  | ||||||
| template <typename T, typename R, typename P> | template <typename T, typename R, typename P> | ||||||
|   typename test_opr<T, R, P>::iter_type const |   typename test_opr<T, R, P>::iter_type const | ||||||
|  test_opr<T, R, P>::fruit_begin = test_iter<T,R,P>( fruit ); |  test_opr<T, R, P>::fruit_begin = test_iter<T,R,P>( fruit ); | ||||||
| @@ -168,13 +176,15 @@ test_opr<T, R, P>::post_increment_test | |||||||
| { | { | ||||||
|     std::cout << "\tDoing post-increment test." << std::endl; |     std::cout << "\tDoing post-increment test." << std::endl; | ||||||
|  |  | ||||||
|     std::stringstream oss; |     std::ostrstream  oss( scratch, scratch_length ); | ||||||
|     for ( iter_type i = fruit_begin ; i != fruit_end ; ) |     for ( iter_type i = fruit_begin ; i != fruit_end ; ) | ||||||
|     { |     { | ||||||
|         oss << *i++ << ' '; |         oss << *i++ << ' '; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( oss.str() == "apple orange pear peach grape plum "); |     oss << std::ends; | ||||||
|  |     BOOST_TEST( std::strcmp(oss.str(), "apple orange pear peach grape plum ") | ||||||
|  |      == 0 ); | ||||||
| } | } | ||||||
|  |  | ||||||
| // Test post-decrement | // Test post-decrement | ||||||
| @@ -186,14 +196,16 @@ test_opr<T, R, P>::post_decrement_test | |||||||
| { | { | ||||||
|     std::cout << "\tDoing post-decrement test." << std::endl; |     std::cout << "\tDoing post-decrement test." << std::endl; | ||||||
|  |  | ||||||
|     std::stringstream oss; |     std::ostrstream  oss( scratch, scratch_length ); | ||||||
|     for ( iter_type i = fruit_end ; i != fruit_begin ; ) |     for ( iter_type i = fruit_end ; i != fruit_begin ; ) | ||||||
|     { |     { | ||||||
|         i--; |         i--; | ||||||
|         oss << *i << ' '; |         oss << *i << ' '; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( oss.str() == "plum grape peach pear orange apple "); |     oss << std::ends; | ||||||
|  |     BOOST_TEST( std::strcmp(oss.str(), "plum grape peach pear orange apple ") | ||||||
|  |      == 0 ); | ||||||
| } | } | ||||||
|  |  | ||||||
| // Test indirect structure referral | // Test indirect structure referral | ||||||
| @@ -205,13 +217,14 @@ test_opr<T, R, P>::indirect_referral_test | |||||||
| { | { | ||||||
|     std::cout << "\tDoing indirect reference test." << std::endl; |     std::cout << "\tDoing indirect reference test." << std::endl; | ||||||
|  |  | ||||||
|     std::stringstream oss; |     std::ostrstream  oss( scratch, scratch_length ); | ||||||
|     for ( iter_type i = fruit_begin ; i != fruit_end ; ++i ) |     for ( iter_type i = fruit_begin ; i != fruit_end ; ++i ) | ||||||
|     { |     { | ||||||
|         oss << i->size() << ' '; |         oss << i->size() << ' '; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( oss.str() == "5 6 4 5 5 4 "); |     oss << std::ends; | ||||||
|  |     BOOST_TEST( std::strcmp(oss.str(), "5 6 4 5 5 4 ") == 0 ); | ||||||
| } | } | ||||||
|  |  | ||||||
| // Test offset addition | // Test offset addition | ||||||
| @@ -224,13 +237,14 @@ test_opr<T, R, P>::offset_addition_test | |||||||
|     std::cout << "\tDoing offset addition test." << std::endl; |     std::cout << "\tDoing offset addition test." << std::endl; | ||||||
|  |  | ||||||
|     std::ptrdiff_t const  two = 2; |     std::ptrdiff_t const  two = 2; | ||||||
|     std::stringstream oss; |     std::ostrstream       oss( scratch, scratch_length ); | ||||||
|     for ( iter_type i = fruit_begin ; i != fruit_end ; i = i + two ) |     for ( iter_type i = fruit_begin ; i != fruit_end ; i = i + two ) | ||||||
|     { |     { | ||||||
|         oss << *i << ' '; |         oss << *i << ' '; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( oss.str() == "apple pear grape "); |     oss << std::ends; | ||||||
|  |     BOOST_TEST( std::strcmp(oss.str(), "apple pear grape ") == 0 ); | ||||||
| } | } | ||||||
|  |  | ||||||
| // Test offset addition, in reverse order | // Test offset addition, in reverse order | ||||||
| @@ -243,13 +257,14 @@ test_opr<T, R, P>::reverse_offset_addition_test | |||||||
|     std::cout << "\tDoing reverse offset addition test." << std::endl; |     std::cout << "\tDoing reverse offset addition test." << std::endl; | ||||||
|  |  | ||||||
|     std::ptrdiff_t const  two = 2; |     std::ptrdiff_t const  two = 2; | ||||||
|     std::stringstream oss; |     std::ostrstream       oss( scratch, scratch_length ); | ||||||
|     for ( iter_type i = fruit_begin ; i != fruit_end ; i = two + i ) |     for ( iter_type i = fruit_begin ; i != fruit_end ; i = two + i ) | ||||||
|     { |     { | ||||||
|         oss << *i << ' '; |         oss << *i << ' '; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( oss.str() == "apple pear grape "); |     oss << std::ends; | ||||||
|  |     BOOST_TEST( std::strcmp(oss.str(), "apple pear grape ") == 0 ); | ||||||
| } | } | ||||||
|  |  | ||||||
| // Test offset subtraction | // Test offset subtraction | ||||||
| @@ -262,7 +277,7 @@ test_opr<T, R, P>::offset_subtraction_test | |||||||
|     std::cout << "\tDoing offset subtraction test." << std::endl; |     std::cout << "\tDoing offset subtraction test." << std::endl; | ||||||
|  |  | ||||||
|     std::ptrdiff_t const  two = 2; |     std::ptrdiff_t const  two = 2; | ||||||
|     std::stringstream oss; |     std::ostrstream       oss( scratch, scratch_length ); | ||||||
|     for ( iter_type i = fruit_end ; fruit_begin < i ; ) |     for ( iter_type i = fruit_end ; fruit_begin < i ; ) | ||||||
|     { |     { | ||||||
|         i = i - two; |         i = i - two; | ||||||
| @@ -272,7 +287,8 @@ test_opr<T, R, P>::offset_subtraction_test | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( oss.str() == "grape pear apple "); |     oss << std::ends; | ||||||
|  |     BOOST_TEST( std::strcmp(oss.str(), "grape pear apple ") == 0 ); | ||||||
| } | } | ||||||
|  |  | ||||||
| // Test comparisons | // Test comparisons | ||||||
| @@ -296,10 +312,10 @@ test_opr<T, R, P>::comparison_test | |||||||
|         { |         { | ||||||
|             ptrdiff_t const  j_offset = j - fruit_begin; |             ptrdiff_t const  j_offset = j - fruit_begin; | ||||||
|  |  | ||||||
|             BOOST_CHECK( (i != j) == (i_offset != j_offset) ); |             BOOST_TEST( (i != j) == (i_offset != j_offset) ); | ||||||
|             BOOST_CHECK( (i > j) == (i_offset > j_offset) ); |             BOOST_TEST( (i > j) == (i_offset > j_offset) ); | ||||||
|             BOOST_CHECK( (i <= j) == (i_offset <= j_offset) ); |             BOOST_TEST( (i <= j) == (i_offset <= j_offset) ); | ||||||
|             BOOST_CHECK( (i >= j) == (i_offset >= j_offset) ); |             BOOST_TEST( (i >= j) == (i_offset >= j_offset) ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     cout << std::endl; |     cout << std::endl; | ||||||
| @@ -314,11 +330,13 @@ test_opr<T, R, P>::indexing_test | |||||||
| { | { | ||||||
|     std::cout << "\tDoing indexing test." << std::endl; |     std::cout << "\tDoing indexing test." << std::endl; | ||||||
|  |  | ||||||
|     std::stringstream oss; |     std::ostrstream  oss( scratch, scratch_length ); | ||||||
|     for ( std::size_t k = 0u ; k < fruit_length ; ++k ) |     for ( std::size_t k = 0u ; k < fruit_length ; ++k ) | ||||||
|     { |     { | ||||||
|         oss << fruit_begin[ k ] << ' '; |         oss << fruit_begin[ k ] << ' '; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     BOOST_CHECK( oss.str() == "apple orange pear peach grape plum "); |     oss << std::ends; | ||||||
|  |     BOOST_TEST( std::strcmp(oss.str(), "apple orange pear peach grape plum ") | ||||||
|  |      == 0 ); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,8 +1,10 @@ | |||||||
| //  boost class noncopyable test program  ------------------------------------// | //  boost class noncopyable test program  ------------------------------------// | ||||||
|  |  | ||||||
| //  (C) Copyright Beman Dawes 1999. Distributed under the Boost | //  (C) Copyright boost.org 1999. Permission to copy, use, modify, sell | ||||||
| //  Software License, Version 1.0. (See accompanying file | //  and distribute this software is granted provided this copyright | ||||||
| //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | //  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. | ||||||
|  |  | ||||||
| //  See http://www.boost.org for most recent version including documentation. | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,8 @@ | |||||||
| //  (C) Copyright David Abrahams 2001. | //  (C) Copyright David Abrahams 2001. Permission to copy, use, modify, | ||||||
| // Distributed under the Boost Software License, Version 1.0. (See | //  sell and distribute this software is granted provided this | ||||||
| // accompanying file LICENSE_1_0.txt or copy at | //  copyright notice appears in all copies. This software is provided | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) | //  "as is" without express or implied warranty, and with no claim as | ||||||
|  | //  to its suitability for any purpose. | ||||||
|  |  | ||||||
| //  See http://www.boost.org for most recent version including documentation. | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| @@ -57,22 +58,14 @@ struct complement | |||||||
|     struct traits |     struct traits | ||||||
|     { |     { | ||||||
|      private: |      private: | ||||||
|         // indirection through complement_traits_aux necessary to keep MSVC happy |         // indirection through complement_traits_aux neccessary to keep MSVC happy | ||||||
|         typedef complement_traits_aux<Number, size - 1> prev; |         typedef complement_traits_aux<Number, size - 1> prev; | ||||||
|      public: |      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 = |         BOOST_STATIC_CONSTANT(Number, max = | ||||||
|                             Number(Number(prev::max) << CHAR_BIT) |                             Number(Number(prev::max) << CHAR_BIT) | ||||||
|                             + Number(UCHAR_MAX)); |                             + Number(UCHAR_MAX)); | ||||||
|         BOOST_STATIC_CONSTANT(Number, min = Number(Number(prev::min) << CHAR_BIT)); |  | ||||||
| #endif |  | ||||||
|          |          | ||||||
|  |         BOOST_STATIC_CONSTANT(Number, min = Number(Number(prev::min) << CHAR_BIT)); | ||||||
|     }; |     }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -221,7 +214,7 @@ struct signed_tag {}; | |||||||
| // Tests for unsigned numbers. The extra default Number parameter works around | // Tests for unsigned numbers. The extra default Number parameter works around | ||||||
| // an MSVC bug. | // an MSVC bug. | ||||||
| template <class Number> | template <class Number> | ||||||
| void test_aux(unsigned_tag, Number*) | void test_aux(unsigned_tag, Number* = 0) | ||||||
| { | { | ||||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; |     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||||
|     BOOST_STATIC_ASSERT(!boost::detail::is_signed<Number>::value); |     BOOST_STATIC_ASSERT(!boost::detail::is_signed<Number>::value); | ||||||
| @@ -229,15 +222,9 @@ void test_aux(unsigned_tag, Number*) | |||||||
|         (sizeof(Number) < sizeof(boost::intmax_t)) |         (sizeof(Number) < sizeof(boost::intmax_t)) | ||||||
|         | (boost::is_same<difference_type, boost::intmax_t>::value)); |         | (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 |     // 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>::max) > Number(0)); | ||||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) == Number(0)); |     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) == Number(0)); | ||||||
| #endif |  | ||||||
|      |      | ||||||
|     const Number max = complement_traits<Number>::max; |     const Number max = complement_traits<Number>::max; | ||||||
|     const Number min = complement_traits<Number>::min; |     const Number min = complement_traits<Number>::min; | ||||||
| @@ -269,7 +256,7 @@ struct in_range_tag {}; | |||||||
| // This test morsel gets executed for numbers whose difference will always be | // This test morsel gets executed for numbers whose difference will always be | ||||||
| // representable in intmax_t | // representable in intmax_t | ||||||
| template <class Number> | template <class Number> | ||||||
| void signed_test(in_range_tag, Number*) | void signed_test(in_range_tag, Number* = 0) | ||||||
| { | { | ||||||
|     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); |     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); | ||||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; |     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||||
| @@ -290,7 +277,7 @@ void signed_test(in_range_tag, Number*) | |||||||
| // This test morsel gets executed for numbers whose difference may exceed the | // This test morsel gets executed for numbers whose difference may exceed the | ||||||
| // capacity of intmax_t. | // capacity of intmax_t. | ||||||
| template <class Number> | template <class Number> | ||||||
| void signed_test(out_of_range_tag, Number*) | void signed_test(out_of_range_tag, Number* = 0) | ||||||
| { | { | ||||||
|     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); |     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); | ||||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; |     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||||
| @@ -314,7 +301,7 @@ void signed_test(out_of_range_tag, Number*) | |||||||
| } | } | ||||||
|  |  | ||||||
| template <class Number> | template <class Number> | ||||||
| void test_aux(signed_tag, Number*) | void test_aux(signed_tag, Number* = 0) | ||||||
| { | { | ||||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; |     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||||
|     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); |     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); | ||||||
| @@ -322,15 +309,10 @@ void test_aux(signed_tag, Number*) | |||||||
|         (sizeof(Number) < sizeof(boost::intmax_t)) |         (sizeof(Number) < sizeof(boost::intmax_t)) | ||||||
|         | (boost::is_same<difference_type, Number>::value)); |         | (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 |     // 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>::max) > Number(0)); | ||||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) < Number(0)); |     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) < Number(0)); | ||||||
| #endif     |      | ||||||
|     const Number max = complement_traits<Number>::max; |     const Number max = complement_traits<Number>::max; | ||||||
|     const Number min = complement_traits<Number>::min; |     const Number min = complement_traits<Number>::min; | ||||||
|      |      | ||||||
| @@ -346,7 +328,7 @@ void test_aux(signed_tag, Number*) | |||||||
|                           out_of_range_tag |                           out_of_range_tag | ||||||
|                         >::type |                         >::type | ||||||
|         range_tag; |         range_tag; | ||||||
|     signed_test<Number>(range_tag(), 0); |     signed_test<Number>(range_tag()); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -376,7 +358,7 @@ void test(Number* = 0) | |||||||
|         boost::detail::is_signed<Number>::value |         boost::detail::is_signed<Number>::value | ||||||
|         >::template then<signed_tag, unsigned_tag>::type signedness; |         >::template then<signed_tag, unsigned_tag>::type signedness; | ||||||
|      |      | ||||||
|     test_aux<Number>(signedness(), 0); |     test_aux<Number>(signedness()); | ||||||
|     std::cout << "passed" << std::endl; |     std::cout << "passed" << std::endl; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -393,8 +375,8 @@ int main() | |||||||
|     test<long>(); |     test<long>(); | ||||||
|     test<unsigned long>(); |     test<unsigned long>(); | ||||||
| #if defined(BOOST_HAS_LONG_LONG) && !defined(BOOST_NO_INTEGRAL_INT64_T) | #if defined(BOOST_HAS_LONG_LONG) && !defined(BOOST_NO_INTEGRAL_INT64_T) | ||||||
|     test< ::boost::long_long_type>(); |     test<long long>(); | ||||||
|     test< ::boost::ulong_long_type>(); |     test<unsigned long long>(); | ||||||
| #elif defined(BOOST_MSVC) | #elif defined(BOOST_MSVC) | ||||||
|     // The problem of not having compile-time static class constants other than |     // The problem of not having compile-time static class constants other than | ||||||
|     // enums prevents this from working, since values get truncated. |     // enums prevents this from working, since values get truncated. | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
|   </head> |   </head> | ||||||
|  |  | ||||||
|   <body text="black" bgcolor="white" link="blue" vlink="purple" alink="red"> |   <body text="black" bgcolor="white" link="blue" vlink="purple" alink="red"> | ||||||
|     <h1><img src="../../boost.png" alt="boost.png (6897 bytes)" align= |     <h1><img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" align= | ||||||
|     "middle" width="277" height="86">Header <cite><<a href= |     "middle" width="277" height="86">Header <cite><<a href= | ||||||
|     "../../boost/operators.hpp">boost/operators.hpp</a>></cite></h1> |     "../../boost/operators.hpp">boost/operators.hpp</a>></cite></h1> | ||||||
|  |  | ||||||
| @@ -344,15 +344,6 @@ class MyInt | |||||||
|       above</li> |       above</li> | ||||||
|     </ul> |     </ul> | ||||||
|  |  | ||||||
|     <p>As Daniel Krügler pointed out, this technique violates 14.6.5/2 |  | ||||||
|     and is thus non-portable. The reasoning is, that the operators injected |  | ||||||
|     by the instantiation of e.g. |  | ||||||
|     <code>less_than_comparable<myclass></code> can not be found |  | ||||||
|     by ADL according to the rules given by 3.4.2/2, since myclass is |  | ||||||
|     not an associated class of |  | ||||||
|     <code>less_than_comparable<myclass></code>. |  | ||||||
|     Thus only use this technique if all else fails.</p> |  | ||||||
|  |  | ||||||
|     <h3>Requirement <a name="portability">Portability</a></h3> |     <h3>Requirement <a name="portability">Portability</a></h3> | ||||||
|  |  | ||||||
|     <p>Many compilers (<i>e.g.</i> MSVC 6.3, GCC 2.95.2) will not enforce the |     <p>Many compilers (<i>e.g.</i> MSVC 6.3, GCC 2.95.2) will not enforce the | ||||||
| @@ -445,9 +436,6 @@ const point<float> pi_over_4_normalized = pi_over_4 / length(pi_over_4); | |||||||
|     optional template parameter <code>B</code>, which is not shown, for the |     optional template parameter <code>B</code>, which is not shown, for the | ||||||
|     <a href="#chaining">base class chaining</a> technique.</p> |     <a href="#chaining">base class chaining</a> technique.</p> | ||||||
|  |  | ||||||
|     <p>The primary operand type <code>T</code> needs to be of class type, |  | ||||||
|     built-in types are not supported.</p> |  | ||||||
|  |  | ||||||
|     <table cellpadding="5" border="1" align="center"> |     <table cellpadding="5" border="1" align="center"> | ||||||
|       <caption> |       <caption> | ||||||
|         Simple Arithmetic Operator Template Classes |         Simple Arithmetic Operator Template Classes | ||||||
| @@ -986,6 +974,7 @@ T operator+( T lhs, const T& rhs ) | |||||||
|     that don't implement the NRVO. <br> |     that don't implement the NRVO. <br> | ||||||
|      <br> |      <br> | ||||||
|       |       | ||||||
|  |  | ||||||
|     <h3><a name="grpd_oprs">Grouped Arithmetic Operators</a></h3> |     <h3><a name="grpd_oprs">Grouped Arithmetic Operators</a></h3> | ||||||
|  |  | ||||||
|     <p>The following templates provide common groups of related operations. |     <p>The following templates provide common groups of related operations. | ||||||
| @@ -1423,9 +1412,9 @@ T operator+( T lhs, const T& rhs ) | |||||||
|  |  | ||||||
|       <tr> |       <tr> | ||||||
|         <td><code><a name= |         <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> |         <td> | ||||||
|           <ul> |           <ul> | ||||||
| @@ -1442,9 +1431,9 @@ T operator+( T lhs, const T& rhs ) | |||||||
|  |  | ||||||
|       <tr> |       <tr> | ||||||
|         <td><code><a name= |         <td><code><a name= | ||||||
|         "euclidean_ring_operators2">euclidean_ring_operators<T, |         "euclidian_ring_operators2">euclidian_ring_operators<T, | ||||||
|         U></a></code><br> |         U></a></code><br> | ||||||
|          <code>euclidean_ring_operators2<T, U></code></td> |          <code>euclidian_ring_operators2<T, U></code></td> | ||||||
|  |  | ||||||
|         <td> |         <td> | ||||||
|           <ul> |           <ul> | ||||||
| @@ -1467,14 +1456,14 @@ T operator+( T lhs, const T& rhs ) | |||||||
|  |  | ||||||
|       <tr> |       <tr> | ||||||
|         <td><code><a name= |         <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> |         <td> | ||||||
|           <ul> |           <ul> | ||||||
|             <li><code><a href= |             <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= |             <li><code><a href= | ||||||
|             "#totally_ordered1">totally_ordered<T></a></code></li> |             "#totally_ordered1">totally_ordered<T></a></code></li> | ||||||
| @@ -1484,14 +1473,14 @@ T operator+( T lhs, const T& rhs ) | |||||||
|  |  | ||||||
|       <tr> |       <tr> | ||||||
|         <td><code><a name= |         <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> |         U></a></code><br> | ||||||
|          <code>ordered_euclidean_ring_operators2<T, U></code></td> |          <code>ordered_euclidian_ring_operators2<T, U></code></td> | ||||||
|  |  | ||||||
|         <td> |         <td> | ||||||
|           <ul> |           <ul> | ||||||
|             <li><code><a href= |             <li><code><a href= | ||||||
|             "#euclidean_ring_operators2">euclidean_ring_operators<T, |             "#euclidian_ring_operators2">euclidian_ring_operators<T, | ||||||
|             U></a></code></li> |             U></a></code></li> | ||||||
|  |  | ||||||
|             <li><code><a href="#totally_ordered2">totally_ordered<T, |             <li><code><a href="#totally_ordered2">totally_ordered<T, | ||||||
| @@ -1501,15 +1490,6 @@ T operator+( T lhs, const T& rhs ) | |||||||
|       </tr> |       </tr> | ||||||
|     </table> |     </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> |     <h3><a name="ex_oprs">Example</a> Templates</h3> | ||||||
|  |  | ||||||
|     <p>The arithmetic operator class templates <code><a href= |     <p>The arithmetic operator class templates <code><a href= | ||||||
| @@ -1588,8 +1568,9 @@ T operator+( T lhs, const T& rhs ) | |||||||
|  |  | ||||||
|     <p>The <cite><a href="operators_test.cpp">operators_test.cpp</a></cite> |     <p>The <cite><a href="operators_test.cpp">operators_test.cpp</a></cite> | ||||||
|     program demonstrates the use of the arithmetic operator templates, and |     program demonstrates the use of the arithmetic operator templates, and | ||||||
|     can also be used to verify correct operation. Check the compiler status |     can also be used to verify correct operation. Check the <a href= | ||||||
|     report for the test results with selected platforms.</p> |     "../../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> |     <h2><a name="deref">Dereference</a> Operators and Iterator Helpers</h2> | ||||||
|  |  | ||||||
| @@ -1966,7 +1947,7 @@ T operator+( T lhs, const T& rhs ) | |||||||
|     output iterator to writing just two member functions - an appropriate |     output iterator to writing just two member functions - an appropriate | ||||||
|     constructor and a copy-assignment operator. For example, here is a |     constructor and a copy-assignment operator. For example, here is a | ||||||
|     possible implementation of <code><a href= |     possible implementation of <code><a href= | ||||||
|     "../iterator/doc/function_output_iterator.html">boost::function_output_iterator</a></code> |     "function_output_iterator.htm">boost::function_output_iterator</a></code> | ||||||
|     adaptor:</p> |     adaptor:</p> | ||||||
| <pre> | <pre> | ||||||
| template<class UnaryFunction> | template<class UnaryFunction> | ||||||
| @@ -2033,20 +2014,20 @@ public: | |||||||
| </pre> | </pre> | ||||||
|     </blockquote> |     </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> |     report</a> for the test results with selected platforms.</p> | ||||||
|     <hr> |     <hr> | ||||||
|  |  | ||||||
|     <h2><a name="contributors">Contributors</a></h2> |     <h2><a name="contributors">Contributors</a></h2> | ||||||
|  |  | ||||||
|     <dl> |     <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 |       <dd>Started the library and contributed the arithmetic operators in | ||||||
|       <cite><a href= |       <cite><a href= | ||||||
|       "../../boost/operators.hpp">boost/operators.hpp</a></cite>.</dd> |       "../../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 |       <dd>Contributed the <a href="#deref">dereference operators and iterator | ||||||
|       helpers</a> in <cite><a href= |       helpers</a> in <cite><a href= | ||||||
| @@ -2054,19 +2035,19 @@ public: | |||||||
|       contributed <cite><a href= |       contributed <cite><a href= | ||||||
|       "iterators_test.cpp">iterators_test.cpp</a></cite>.</dd> |       "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> |       Gurtovoy</a></dt> | ||||||
|  |  | ||||||
|       <dd>Contributed the code to support <a href="#chaining">base class |       <dd>Contributed the code to support <a href="#chaining">base class | ||||||
|       chaining</a> while remaining backward-compatible with old versions of |       chaining</a> while remaining backward-compatible with old versions of | ||||||
|       the library.</dd> |       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= |       <dd>Contributed <cite><a href= | ||||||
|       "operators_test.cpp">operators_test.cpp</a></cite>.</dd> |       "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 |       <dd>Contributed classes for the shift operators, equivalence, partial | ||||||
|       ordering, and arithmetic conversions. Added the grouped operator |       ordering, and arithmetic conversions. Added the grouped operator | ||||||
| @@ -2081,7 +2062,6 @@ public: | |||||||
|  |  | ||||||
|       <dd>Contributed the NRVO-friendly and symmetric implementation of |       <dd>Contributed the NRVO-friendly and symmetric implementation of | ||||||
|       arithmetic operators.</dd> |       arithmetic operators.</dd> | ||||||
|  |  | ||||||
|     </dl> |     </dl> | ||||||
|  |  | ||||||
|     <h2>Note for Users of <a name="old_lib_note">Older Versions</a></h2> |     <h2>Note for Users of <a name="old_lib_note">Older Versions</a></h2> | ||||||
| @@ -2130,15 +2110,13 @@ public: | |||||||
|     backward-compatible.</p> |     backward-compatible.</p> | ||||||
|     <hr> |     <hr> | ||||||
|  |  | ||||||
|     <p>Revised: 7 Aug 2008</p> |     <p>Revised: 30 Oct 2001</p> | ||||||
|  |  | ||||||
|     <p>Copyright © Beman Dawes, David Abrahams, 1999-2001.</p> |     <p>Copyright © David Abrahams and Beman Dawes 1999-2001. Permission | ||||||
|     <p>Copyright © Daniel Frey, 2002-2009.</p> |     to copy, use, modify, sell and distribute this document is granted | ||||||
|     <p>Use, modification, and distribution is subject to the Boost Software |     provided this copyright notice appears in all copies. This document is | ||||||
|     License, Version 1.0. (See accompanying file |     provided "as is" without express or implied warranty, and with no claim | ||||||
|     <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or copy at |     as to its suitability for any purpose.</p> | ||||||
|     <a href="http://www.boost.org/LICENSE_1_0.txt"> |  | ||||||
|     www.boost.org/LICENSE_1_0.txt</a>)</p> |  | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,13 +1,13 @@ | |||||||
| //  Demonstrate and test boost/operators.hpp  -------------------------------// | //  Demonstrate and test boost/operators.hpp  -------------------------------// | ||||||
|  |  | ||||||
| //  Copyright Beman Dawes 1999.  Distributed under the Boost | //  (C) Copyright Beman Dawes 1999. Permission to copy, use, modify, sell and | ||||||
| //  Software License, Version 1.0. (See accompanying file | //  distribute this software is granted provided this copyright notice appears | ||||||
| //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | //  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. | ||||||
|  |  | ||||||
| //  See http://www.boost.org/libs/utility for documentation. | //  See http://www.boost.org for most recent version including documentation. | ||||||
|  |  | ||||||
| //  Revision History | //  Revision History | ||||||
| //  03 Apr 08 Added convertible_to_bool (Daniel Frey) |  | ||||||
| //  01 Oct 01 Added tests for "left" operators | //  01 Oct 01 Added tests for "left" operators | ||||||
| //            and new grouped operators. (Helmut Zeisel) | //            and new grouped operators. (Helmut Zeisel) | ||||||
| //  20 May 01 Output progress messages.  Added tests for new operator | //  20 May 01 Output progress messages.  Added tests for new operator | ||||||
| @@ -44,23 +44,6 @@ namespace | |||||||
|     unsigned char true_value(unsigned char x) { return x; } |     unsigned char true_value(unsigned char x) { return x; } | ||||||
|     unsigned short true_value(unsigned short 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 |     // The use of operators<> here tended to obscure | ||||||
|     // interactions with certain compiler bugs |     // interactions with certain compiler bugs | ||||||
|     template <class T> |     template <class T> | ||||||
| @@ -72,10 +55,8 @@ namespace | |||||||
|         explicit Wrapped1( T v = T() ) : _value(v) {} |         explicit Wrapped1( T v = T() ) : _value(v) {} | ||||||
|         T value() const { return _value; } |         T value() const { return _value; } | ||||||
|  |  | ||||||
|         convertible_to_bool operator<(const Wrapped1& x) const |         bool operator<(const Wrapped1& x) const { return _value < x._value; } | ||||||
|           { return _value < x._value; } |         bool operator==(const Wrapped1& x) const { return _value == x._value; } | ||||||
|         convertible_to_bool operator==(const Wrapped1& x) const |  | ||||||
|           { return _value == x._value; } |  | ||||||
|          |          | ||||||
|         Wrapped1& operator+=(const Wrapped1& x) |         Wrapped1& operator+=(const Wrapped1& x) | ||||||
|           { _value += x._value; return *this; } |           { _value += x._value; return *this; } | ||||||
| @@ -117,10 +98,8 @@ namespace | |||||||
|         explicit Wrapped2( T v = T() ) : _value(v) {} |         explicit Wrapped2( T v = T() ) : _value(v) {} | ||||||
|         T value() const { return _value; } |         T value() const { return _value; } | ||||||
|  |  | ||||||
|         convertible_to_bool operator<(const Wrapped2& x) const |         bool operator<(const Wrapped2& x) const { return _value < x._value; } | ||||||
|           { return _value < x._value; } |         bool operator==(const Wrapped2& x) const { return _value == x._value; } | ||||||
|         convertible_to_bool operator==(const Wrapped2& x) const |  | ||||||
|           { return _value == x._value; } |  | ||||||
|          |          | ||||||
|         Wrapped2& operator+=(const Wrapped2& x) |         Wrapped2& operator+=(const Wrapped2& x) | ||||||
|           { _value += x._value; return *this; } |           { _value += x._value; return *this; } | ||||||
| @@ -145,13 +124,9 @@ namespace | |||||||
|         Wrapped2& operator++()                { ++_value; return *this; } |         Wrapped2& operator++()                { ++_value; return *this; } | ||||||
|         Wrapped2& operator--()                { --_value; return *this; } |         Wrapped2& operator--()                { --_value; return *this; } | ||||||
|           |           | ||||||
|         convertible_to_bool operator<(U u) const |         bool operator<(U u) const { return _value < u; } | ||||||
|           { return _value < u; } |         bool operator>(U u) const { return _value > u; } | ||||||
|         convertible_to_bool operator>(U u) const |         bool operator==(U u) const { return _value == u; } | ||||||
|           { return _value > u; } |  | ||||||
|         convertible_to_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; } |         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 +154,7 @@ namespace | |||||||
|         explicit Wrapped3( T v = T() ) : _value(v) {} |         explicit Wrapped3( T v = T() ) : _value(v) {} | ||||||
|         T value() const { return _value; } |         T value() const { return _value; } | ||||||
|  |  | ||||||
|         convertible_to_bool operator<(const Wrapped3& x) const |         bool operator<(const Wrapped3& x) const { return _value < x._value; } | ||||||
|           { return _value < x._value; } |  | ||||||
|          |          | ||||||
|     private: |     private: | ||||||
|         T _value; |         T _value; | ||||||
| @@ -201,13 +175,10 @@ namespace | |||||||
|         explicit Wrapped4( T v = T() ) : _value(v) {} |         explicit Wrapped4( T v = T() ) : _value(v) {} | ||||||
|         T value() const { return _value; } |         T value() const { return _value; } | ||||||
|  |  | ||||||
|         convertible_to_bool operator<(const Wrapped4& x) const |         bool operator<(const Wrapped4& x) const { return _value < x._value; } | ||||||
|           { return _value < x._value; } |  | ||||||
|           |           | ||||||
|         convertible_to_bool operator<(U u) const |         bool operator<(U u) const { return _value < u; } | ||||||
|           { return _value < u; } |         bool operator>(U u) const { return _value > u; } | ||||||
|         convertible_to_bool operator>(U u) const |  | ||||||
|           { return _value > u; } |  | ||||||
|  |  | ||||||
|     private: |     private: | ||||||
|         T _value; |         T _value; | ||||||
| @@ -228,18 +199,11 @@ namespace | |||||||
|         Wrapped5(U u) : _value(u) {} |         Wrapped5(U u) : _value(u) {} | ||||||
|  |  | ||||||
|         T value() const { return _value; } |         T value() const { return _value; } | ||||||
|  |         bool operator<(const Wrapped5& x) const { return _value < x._value; } | ||||||
|         convertible_to_bool operator<(const Wrapped5& x) const |         bool operator<(U u) const { return _value < u; } | ||||||
|           { return _value < x._value; } |         bool operator>(U u) const { return _value > u; } | ||||||
|         convertible_to_bool operator<(U u) const |         bool operator==(const Wrapped5& u) const { return _value == u._value; } | ||||||
|           { return _value < u; } |         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; } |  | ||||||
|  |  | ||||||
|         Wrapped5& operator/=(const Wrapped5& u) { _value /= u._value; return *this;} |         Wrapped5& operator/=(const Wrapped5& u) { _value /= u._value; return *this;} | ||||||
|         Wrapped5& operator/=(U u) { _value /= u; return *this;} |         Wrapped5& operator/=(U u) { _value /= u; return *this;} | ||||||
|         Wrapped5& operator*=(const Wrapped5& u) { _value *= u._value; return *this;} |         Wrapped5& operator*=(const Wrapped5& u) { _value *= u._value; return *this;} | ||||||
| @@ -258,8 +222,8 @@ namespace | |||||||
|     // U must be convertible to T |     // U must be convertible to T | ||||||
|     template <class T, class U> |     template <class T, class U> | ||||||
|     class Wrapped6 |     class Wrapped6 | ||||||
|         : boost::ordered_euclidean_ring_operators2<Wrapped6<T, U>, U> |         : boost::ordered_euclidian_ring_operators2<Wrapped6<T, U>, U> | ||||||
|         , boost::ordered_euclidean_ring_operators1<Wrapped6<T, U> > |         , boost::ordered_euclidian_ring_operators1<Wrapped6<T, U> > | ||||||
|     { |     { | ||||||
|     public: |     public: | ||||||
|         explicit Wrapped6( T v = T() ) : _value(v) {} |         explicit Wrapped6( T v = T() ) : _value(v) {} | ||||||
| @@ -268,18 +232,11 @@ namespace | |||||||
|         Wrapped6(U u) : _value(u) {} |         Wrapped6(U u) : _value(u) {} | ||||||
|  |  | ||||||
|         T value() const { return _value; } |         T value() const { return _value; } | ||||||
|  |         bool operator<(const Wrapped6& x) const { return _value < x._value; } | ||||||
|         convertible_to_bool operator<(const Wrapped6& x) const |         bool operator<(U u) const { return _value < u; } | ||||||
|           { return _value < x._value; } |         bool operator>(U u) const { return _value > u; } | ||||||
|         convertible_to_bool operator<(U u) const |         bool operator==(const Wrapped6& u) const { return _value == u._value; } | ||||||
|           { return _value < u; } |         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; } |  | ||||||
|  |  | ||||||
|         Wrapped6& operator%=(const Wrapped6& u) { _value %= u._value; return *this;} |         Wrapped6& operator%=(const Wrapped6& u) { _value %= u._value; return *this;} | ||||||
|         Wrapped6& operator%=(U u) { _value %= u; return *this;} |         Wrapped6& operator%=(U u) { _value %= u; return *this;} | ||||||
|         Wrapped6& operator/=(const Wrapped6& u) { _value /= u._value; return *this;} |         Wrapped6& operator/=(const Wrapped6& u) { _value /= u._value; return *this;} | ||||||
| @@ -313,17 +270,17 @@ namespace | |||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void sanity_check(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void sanity_check(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         BOOST_CHECK( true_value(y1) == true_value(y2) ); |         BOOST_TEST( true_value(y1) == true_value(y2) ); | ||||||
|         BOOST_CHECK( true_value(x1) == true_value(x2) ); |         BOOST_TEST( true_value(x1) == true_value(x2) ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_less_than_comparable_aux(X1 x1, Y1 y1, X2 x2, Y2 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_TEST( (x1 < y1) == (x2 < y2) ); | ||||||
|         BOOST_CHECK( static_cast<bool>(x1 <= y1) == static_cast<bool>(x2 <= y2) ); |         BOOST_TEST( (x1 <= y1) == (x2 <= y2) ); | ||||||
|         BOOST_CHECK( static_cast<bool>(x1 >= y1) == static_cast<bool>(x2 >= y2) ); |         BOOST_TEST( (x1 >= y1) == (x2 >= y2) ); | ||||||
|         BOOST_CHECK( static_cast<bool>(x1 > y1) == static_cast<bool>(x2 > y2) ); |         BOOST_TEST( (x1 > y1) == (x2 > y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -337,8 +294,8 @@ namespace | |||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_equality_comparable_aux(X1 x1, Y1 y1, X2 x2, Y2 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_TEST( (x1 == y1) == (x2 == y2) ); | ||||||
|         BOOST_CHECK( static_cast<bool>(x1 != y1) == static_cast<bool>(x2 != y2) ); |         BOOST_TEST( (x1 != y1) == (x2 != y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -352,7 +309,7 @@ namespace | |||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_multipliable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_multipliable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         BOOST_CHECK( (x1 * y1).value() == (x2 * y2) ); |         BOOST_TEST( (x1 * y1).value() == (x2 * y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -363,19 +320,10 @@ namespace | |||||||
|         test_multipliable_aux( y1, x1, y2, x2 ); |         test_multipliable_aux( y1, x1, y2, x2 ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|   template <class A, class B> |  | ||||||
|   void test_value_equality(A a, B b) |  | ||||||
|   { |  | ||||||
|       BOOST_CHECK(a.value() == b); |  | ||||||
|   } |  | ||||||
|    |  | ||||||
| #define TEST_OP_R(op) test_value_equality(x1 op y1, x2 op y2) |  | ||||||
| #define TEST_OP_L(op) test_value_equality(y1 op x1, y2 op x2) |  | ||||||
|    |  | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_addable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_addable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         TEST_OP_R(+); |         BOOST_TEST( (x1 + y1).value() == (x2 + y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -390,14 +338,14 @@ namespace | |||||||
|     void test_subtractable(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_subtractable(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         TEST_OP_R(-); |         BOOST_TEST( (x1 - y1).value() == (x2 - y2) ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_subtractable_left(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_subtractable_left(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         TEST_OP_L(-); |         BOOST_TEST( (y1 - x1).value() == (y2 - x2) ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -405,7 +353,7 @@ namespace | |||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         if ( y2 != 0 ) |         if ( y2 != 0 ) | ||||||
|             TEST_OP_R(/); |             BOOST_TEST( (x1 / y1).value() == (x2 / y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -413,7 +361,7 @@ namespace | |||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         if ( x2 != 0 ) |         if ( x2 != 0 ) | ||||||
|             TEST_OP_L(/); |             BOOST_TEST( (y1 / x1).value() == (y2 / x2) ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -421,7 +369,7 @@ namespace | |||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         if ( y2 != 0 ) |         if ( y2 != 0 ) | ||||||
|             TEST_OP_R(%); |             BOOST_TEST( (x1 % y1).value() == (x2 % y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -429,13 +377,13 @@ namespace | |||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         if ( x2 != 0 ) |         if ( x2 != 0 ) | ||||||
|             TEST_OP_L(%); |             BOOST_TEST( (y1 % x1).value() == (y2 % x2) ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_xorable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_xorable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         TEST_OP_R(^); |         BOOST_TEST( (x1 ^ y1).value() == (x2 ^ y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -449,7 +397,7 @@ namespace | |||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_andable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_andable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         TEST_OP_R(&); |         BOOST_TEST( (x1 & y1).value() == (x2 & y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -463,7 +411,7 @@ namespace | |||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_orable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_orable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         TEST_OP_R(|); |         BOOST_TEST( (x1 | y1).value() == (x2 | y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -478,30 +426,30 @@ namespace | |||||||
|     void test_left_shiftable(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_left_shiftable(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         TEST_OP_R(<<); |         BOOST_TEST( (x1 << y1).value() == (x2 << y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
|     void test_right_shiftable(X1 x1, Y1 y1, X2 x2, Y2 y2) |     void test_right_shiftable(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||||
|     { |     { | ||||||
|         sanity_check( x1, y1, x2, y2 ); |         sanity_check( x1, y1, x2, y2 ); | ||||||
|         TEST_OP_R(>>); |         BOOST_TEST( (x1 >> y1).value() == (x2 >> y2) ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class X2> |     template <class X1, class X2> | ||||||
|     void test_incrementable(X1 x1, X2 x2) |     void test_incrementable(X1 x1, X2 x2) | ||||||
|     { |     { | ||||||
|         sanity_check( x1, x1, x2, x2 ); |         sanity_check( x1, x1, x2, x2 ); | ||||||
|         BOOST_CHECK( (x1++).value() == x2++ ); |         BOOST_TEST( (x1++).value() == x2++ ); | ||||||
|         BOOST_CHECK( x1.value() == x2 ); |         BOOST_TEST( x1.value() == x2 ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class X2> |     template <class X1, class X2> | ||||||
|     void test_decrementable(X1 x1, X2 x2) |     void test_decrementable(X1 x1, X2 x2) | ||||||
|     { |     { | ||||||
|         sanity_check( x1, x1, x2, x2 ); |         sanity_check( x1, x1, x2, x2 ); | ||||||
|         BOOST_CHECK( (x1--).value() == x2-- ); |         BOOST_TEST( (x1--).value() == x2-- ); | ||||||
|         BOOST_CHECK( x1.value() == x2 ); |         BOOST_TEST( x1.value() == x2 ); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class X1, class Y1, class X2, class Y2> |     template <class X1, class Y1, class X2, class Y2> | ||||||
| @@ -580,7 +528,7 @@ namespace | |||||||
| // inherited operator templates at the moment it must, so the following | // inherited operator templates at the moment it must, so the following | ||||||
| // explicit instantiations force it to do that. | // 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<int>; | ||||||
| template Wrapped1<long>; | template Wrapped1<long>; | ||||||
| template Wrapped1<unsigned int>; | template Wrapped1<unsigned int>; | ||||||
| @@ -605,7 +553,8 @@ template Wrapped6<unsigned long, unsigned char>; | |||||||
| template Wrapped6<unsigned int, unsigned char>; | template Wrapped6<unsigned int, unsigned char>; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define PRIVATE_EXPR_TEST(e, t)  BOOST_CHECK( ((e), (t)) ) | #define PRIVATE_EXPR_TEST(e, t)  BOOST_TEST( ((e), (t)) ) | ||||||
|  |  | ||||||
|  |  | ||||||
| int | int | ||||||
| test_main( int , char * [] ) | test_main( int , char * [] ) | ||||||
| @@ -650,22 +599,22 @@ test_main( int , char * [] ) | |||||||
|     MyInt i2(2); |     MyInt i2(2); | ||||||
|     MyInt i; |     MyInt i; | ||||||
|  |  | ||||||
|     BOOST_CHECK( i1.value() == 1 ); |     BOOST_TEST( i1.value() == 1 ); | ||||||
|     BOOST_CHECK( i2.value() == 2 ); |     BOOST_TEST( i2.value() == 2 ); | ||||||
|     BOOST_CHECK( i.value() == 0 ); |     BOOST_TEST( i.value() == 0 ); | ||||||
|  |  | ||||||
|     cout << "Created MyInt objects.\n"; |     cout << "Created MyInt objects.\n"; | ||||||
|  |  | ||||||
|     PRIVATE_EXPR_TEST( (i = i2), (i.value() == 2) ); |     PRIVATE_EXPR_TEST( (i = i2), (i.value() == 2) ); | ||||||
|  |  | ||||||
|     BOOST_CHECK( static_cast<bool>(i2 == i) ); |     BOOST_TEST( i2 == i ); | ||||||
|     BOOST_CHECK( static_cast<bool>(i1 != i2) ); |     BOOST_TEST( i1 != i2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(i1 <  i2) ); |     BOOST_TEST( i1 <  i2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(i1 <= i2) ); |     BOOST_TEST( i1 <= i2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(i <= i2) ); |     BOOST_TEST( i <= i2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(i2 >  i1) ); |     BOOST_TEST( i2 >  i1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(i2 >= i1) ); |     BOOST_TEST( i2 >= i1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(i2 >= i) ); |     BOOST_TEST( i2 >= i ); | ||||||
|  |  | ||||||
|     PRIVATE_EXPR_TEST( (i = i1 + i2), (i.value() == 3) ); |     PRIVATE_EXPR_TEST( (i = i1 + i2), (i.value() == 3) ); | ||||||
|     PRIVATE_EXPR_TEST( (i = i + i2), (i.value() == 5) ); |     PRIVATE_EXPR_TEST( (i = i + i2), (i.value() == 5) ); | ||||||
| @@ -689,86 +638,86 @@ test_main( int , char * [] ) | |||||||
|     MyLong j2(2); |     MyLong j2(2); | ||||||
|     MyLong j; |     MyLong j; | ||||||
|  |  | ||||||
|     BOOST_CHECK( j1.value() == 1 ); |     BOOST_TEST( j1.value() == 1 ); | ||||||
|     BOOST_CHECK( j2.value() == 2 ); |     BOOST_TEST( j2.value() == 2 ); | ||||||
|     BOOST_CHECK( j.value() == 0 ); |     BOOST_TEST( j.value() == 0 ); | ||||||
|  |  | ||||||
|     cout << "Created MyLong objects.\n"; |     cout << "Created MyLong objects.\n"; | ||||||
|  |  | ||||||
|     PRIVATE_EXPR_TEST( (j = j2), (j.value() == 2) ); |     PRIVATE_EXPR_TEST( (j = j2), (j.value() == 2) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 == j) ); |     BOOST_TEST( j2 == j ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 == j) ); |     BOOST_TEST( 2 == j ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 == 2) ); |     BOOST_TEST( j2 == 2 );     | ||||||
|     BOOST_CHECK( static_cast<bool>(j == j2) ); |     BOOST_TEST( j == j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j1 != j2) ); |     BOOST_TEST( j1 != j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j1 != 2) ); |     BOOST_TEST( j1 != 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 != j2) ); |     BOOST_TEST( 1 != j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j1 <  j2) ); |     BOOST_TEST( j1 <  j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 <  j2) ); |     BOOST_TEST( 1 <  j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j1 <  2) ); |     BOOST_TEST( j1 <  2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j1 <= j2) ); |     BOOST_TEST( j1 <= j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 <= j2) ); |     BOOST_TEST( 1 <= j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j1 <= j) ); |     BOOST_TEST( j1 <= j ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j <= j2) ); |     BOOST_TEST( j <= j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 <= j2) ); |     BOOST_TEST( 2 <= j2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j <= 2) ); |     BOOST_TEST( j <= 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 >  j1) ); |     BOOST_TEST( j2 >  j1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 >  j1) ); |     BOOST_TEST( 2 >  j1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 >  1) ); |     BOOST_TEST( j2 >  1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 >= j1) ); |     BOOST_TEST( j2 >= j1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 >= j1) ); |     BOOST_TEST( 2 >= j1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 >= 1) ); |     BOOST_TEST( j2 >= 1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 >= j) ); |     BOOST_TEST( j2 >= j ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 >= j) ); |     BOOST_TEST( 2 >= j ); | ||||||
|     BOOST_CHECK( static_cast<bool>(j2 >= 2) ); |     BOOST_TEST( j2 >= 2 ); | ||||||
|  |  | ||||||
|     BOOST_CHECK( static_cast<bool>((j1 + 2) == 3) ); |     BOOST_TEST( (j1 + 2) == 3 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((1 + j2) == 3) ); |     BOOST_TEST( (1 + j2) == 3 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j1 + j2), (j.value() == 3) ); |     PRIVATE_EXPR_TEST( (j = j1 + j2), (j.value() == 3) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((j + 2) == 5) ); |     BOOST_TEST( (j + 2) == 5 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((3 + j2) == 5) ); |     BOOST_TEST( (3 + j2) == 5 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j + j2), (j.value() == 5) ); |     PRIVATE_EXPR_TEST( (j = j + j2), (j.value() == 5) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((j - 1) == 4) ); |     BOOST_TEST( (j - 1) == 4 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j - j1), (j.value() == 4) ); |     PRIVATE_EXPR_TEST( (j = j - j1), (j.value() == 4) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((j * 2) == 8) ); |     BOOST_TEST( (j * 2) == 8 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((4 * j2) == 8) ); |     BOOST_TEST( (4 * j2) == 8 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j * j2), (j.value() == 8) ); |     PRIVATE_EXPR_TEST( (j = j * j2), (j.value() == 8) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((j / 2) == 4) ); |     BOOST_TEST( (j / 2) == 4 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j / j2), (j.value() == 4) ); |     PRIVATE_EXPR_TEST( (j = j / j2), (j.value() == 4) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((j % 3) == 1) ); |     BOOST_TEST( (j % 3) == 1 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j % ( j - j1 )), (j.value() == 1) ); |     PRIVATE_EXPR_TEST( (j = j % ( j - j1 )), (j.value() == 1) ); | ||||||
|      |      | ||||||
|     PRIVATE_EXPR_TEST( (j = j2 + j2), (j.value() == 4) ); |     PRIVATE_EXPR_TEST( (j = j2 + j2), (j.value() == 4) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((1 | j2 | j) == 7) ); |     BOOST_TEST( (1 | j2 | j) == 7 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((j1 | 2 | j) == 7) ); |     BOOST_TEST( (j1 | 2 | j) == 7 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((j1 | j2 | 4) == 7) ); |     BOOST_TEST( (j1 | j2 | 4) == 7 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j1 | j2 | j), (j.value() == 7) ); |     PRIVATE_EXPR_TEST( (j = j1 | j2 | j), (j.value() == 7) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((7 & j2) == 2) ); |     BOOST_TEST( (7 & j2) == 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((j & 2) == 2) ); |     BOOST_TEST( (j & 2) == 2 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j & j2), (j.value() == 2) ); |     PRIVATE_EXPR_TEST( (j = j & j2), (j.value() == 2) ); | ||||||
|      |      | ||||||
|     PRIVATE_EXPR_TEST( (j = j | j1), (j.value() == 3) ); |     PRIVATE_EXPR_TEST( (j = j | j1), (j.value() == 3) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>((3 ^ j1) == 2) ); |     BOOST_TEST( (3 ^ j1) == 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((j ^ 1) == 2) ); |     BOOST_TEST( (j ^ 1) == 2 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j ^ j1), (j.value() == 2) ); |     PRIVATE_EXPR_TEST( (j = j ^ j1), (j.value() == 2) ); | ||||||
|      |      | ||||||
|     PRIVATE_EXPR_TEST( (j = ( j + j1 ) * ( j2 | j1 )), (j.value() == 9) ); |     PRIVATE_EXPR_TEST( (j = ( j + j1 ) * ( j2 | j1 )), (j.value() == 9) ); | ||||||
|  |  | ||||||
|     BOOST_CHECK( static_cast<bool>((j1 << 2) == 4) ); |     BOOST_TEST( (j1 << 2) == 4 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((j2 << 1) == 4) ); |     BOOST_TEST( (j2 << 1) == 4 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j1 << j2), (j.value() == 4) ); |     PRIVATE_EXPR_TEST( (j = j1 << j2), (j.value() == 4) ); | ||||||
|  |  | ||||||
|     BOOST_CHECK( static_cast<bool>((j >> 2) == 1) ); |     BOOST_TEST( (j >> 2) == 1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>((j2 >> 1) == 1) ); |     BOOST_TEST( (j2 >> 1) == 1 ); | ||||||
|     PRIVATE_EXPR_TEST( (j = j2 >> j1), (j.value() == 1) ); |     PRIVATE_EXPR_TEST( (j = j2 >> j1), (j.value() == 1) ); | ||||||
|      |      | ||||||
|     cout << "Performed tests on MyLong objects.\n"; |     cout << "Performed tests on MyLong objects.\n"; | ||||||
| @@ -777,22 +726,22 @@ test_main( int , char * [] ) | |||||||
|     MyChar k2(2); |     MyChar k2(2); | ||||||
|     MyChar k; |     MyChar k; | ||||||
|  |  | ||||||
|     BOOST_CHECK( k1.value() == 1 ); |     BOOST_TEST( k1.value() == 1 ); | ||||||
|     BOOST_CHECK( k2.value() == 2 ); |     BOOST_TEST( k2.value() == 2 ); | ||||||
|     BOOST_CHECK( k.value() == 0 ); |     BOOST_TEST( k.value() == 0 ); | ||||||
|  |  | ||||||
|     cout << "Created MyChar objects.\n"; |     cout << "Created MyChar objects.\n"; | ||||||
|  |  | ||||||
|     PRIVATE_EXPR_TEST( (k = k2), (k.value() == 2) ); |     PRIVATE_EXPR_TEST( (k = k2), (k.value() == 2) ); | ||||||
|  |  | ||||||
|     BOOST_CHECK( static_cast<bool>(k2 == k) ); |     BOOST_TEST( k2 == k ); | ||||||
|     BOOST_CHECK( static_cast<bool>(k1 != k2) ); |     BOOST_TEST( k1 != k2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(k1 <  k2) ); |     BOOST_TEST( k1 <  k2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(k1 <= k2) ); |     BOOST_TEST( k1 <= k2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(k <= k2) ); |     BOOST_TEST( k <= k2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(k2 >  k1) ); |     BOOST_TEST( k2 >  k1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(k2 >= k1) ); |     BOOST_TEST( k2 >= k1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(k2 >= k) ); |     BOOST_TEST( k2 >= k ); | ||||||
|      |      | ||||||
|     cout << "Performed tests on MyChar objects.\n"; |     cout << "Performed tests on MyChar objects.\n"; | ||||||
|  |  | ||||||
| @@ -800,39 +749,39 @@ test_main( int , char * [] ) | |||||||
|     MyShort l2(2); |     MyShort l2(2); | ||||||
|     MyShort l; |     MyShort l; | ||||||
|  |  | ||||||
|     BOOST_CHECK( l1.value() == 1 ); |     BOOST_TEST( l1.value() == 1 ); | ||||||
|     BOOST_CHECK( l2.value() == 2 ); |     BOOST_TEST( l2.value() == 2 ); | ||||||
|     BOOST_CHECK( l.value() == 0 ); |     BOOST_TEST( l.value() == 0 ); | ||||||
|  |  | ||||||
|     cout << "Created MyShort objects.\n"; |     cout << "Created MyShort objects.\n"; | ||||||
|  |  | ||||||
|     PRIVATE_EXPR_TEST( (l = l2), (l.value() == 2) ); |     PRIVATE_EXPR_TEST( (l = l2), (l.value() == 2) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 == l) ); |     BOOST_TEST( l2 == l ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 == l) ); |     BOOST_TEST( 2 == l ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 == 2) ); |     BOOST_TEST( l2 == 2 );     | ||||||
|     BOOST_CHECK( static_cast<bool>(l == l2) ); |     BOOST_TEST( l == l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l1 != l2) ); |     BOOST_TEST( l1 != l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l1 != 2) ); |     BOOST_TEST( l1 != 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 != l2) ); |     BOOST_TEST( 1 != l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l1 <  l2) ); |     BOOST_TEST( l1 <  l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 <  l2) ); |     BOOST_TEST( 1 <  l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l1 <  2) ); |     BOOST_TEST( l1 <  2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l1 <= l2) ); |     BOOST_TEST( l1 <= l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 <= l2) ); |     BOOST_TEST( 1 <= l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l1 <= l) ); |     BOOST_TEST( l1 <= l ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l <= l2) ); |     BOOST_TEST( l <= l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 <= l2) ); |     BOOST_TEST( 2 <= l2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l <= 2) ); |     BOOST_TEST( l <= 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 >  l1) ); |     BOOST_TEST( l2 >  l1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 >  l1) ); |     BOOST_TEST( 2 >  l1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 >  1) ); |     BOOST_TEST( l2 >  1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 >= l1) ); |     BOOST_TEST( l2 >= l1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 >= l1) ); |     BOOST_TEST( 2 >= l1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 >= 1) ); |     BOOST_TEST( l2 >= 1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 >= l) ); |     BOOST_TEST( l2 >= l ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 >= l) ); |     BOOST_TEST( 2 >= l ); | ||||||
|     BOOST_CHECK( static_cast<bool>(l2 >= 2) ); |     BOOST_TEST( l2 >= 2 ); | ||||||
|      |      | ||||||
|     cout << "Performed tests on MyShort objects.\n"; |     cout << "Performed tests on MyShort objects.\n"; | ||||||
|      |      | ||||||
| @@ -842,46 +791,46 @@ test_main( int , char * [] ) | |||||||
|     MyDoubleInt di; |     MyDoubleInt di; | ||||||
|     MyDoubleInt tmp; |     MyDoubleInt tmp; | ||||||
|  |  | ||||||
|     BOOST_CHECK( di1.value() == 1 ); |     BOOST_TEST( di1.value() == 1 ); | ||||||
|     BOOST_CHECK( di2.value() == 2 ); |     BOOST_TEST( di2.value() == 2 ); | ||||||
|     BOOST_CHECK( di2.value() == 2 ); |     BOOST_TEST( di2.value() == 2 ); | ||||||
|     BOOST_CHECK( di.value() == 0 ); |     BOOST_TEST( di.value() == 0 ); | ||||||
|  |  | ||||||
|     cout << "Created MyDoubleInt objects.\n"; |     cout << "Created MyDoubleInt objects.\n"; | ||||||
|  |  | ||||||
|     PRIVATE_EXPR_TEST( (di = di2), (di.value() == 2) ); |     PRIVATE_EXPR_TEST( (di = di2), (di.value() == 2) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>(di2 == di) ); |     BOOST_TEST( di2 == di ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 == di) ); |     BOOST_TEST( 2 == di ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di == 2) ); |     BOOST_TEST( di == 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 < di2) ); |     BOOST_TEST( di1 < di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 < di2) ); |     BOOST_TEST( 1 < di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 <= di2) ); |     BOOST_TEST( di1 <= di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 <= di2) ); |     BOOST_TEST( 1 <= di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di2 > di1) ); |     BOOST_TEST( di2 > di1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di2 > 1) ); |     BOOST_TEST( di2 > 1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di2 >= di1) ); |     BOOST_TEST( di2 >= di1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di2 >= 1) ); |     BOOST_TEST( di2 >= 1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 / di2 == half) ); |     BOOST_TEST( di1 / di2 == half ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 / 2 == half) ); |     BOOST_TEST( di1 / 2 == half ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 / di2 == half) ); |     BOOST_TEST( 1 / di2 == half ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp/=2) == half) ); |     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=2) == half) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp/=di2) == half) ); |     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=di2) == half) ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 * di2 == di2) ); |     BOOST_TEST( di1 * di2 == di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 * 2 == di2) ); |     BOOST_TEST( di1 * 2 == di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 * di2 == di2) ); |     BOOST_TEST( 1 * di2 == di2 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp*=2) == di2) ); |     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=2) == di2) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp*=di2) == di2) ); |     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=di2) == di2) ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di2 - di1 == di1) ); |     BOOST_TEST( di2 - di1 == di1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di2 - 1 == di1) ); |     BOOST_TEST( di2 - 1 == di1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 - di1 == di1) ); |     BOOST_TEST( 2 - di1 == di1 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di2), static_cast<bool>((tmp-=1) == di1) ); |     PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=1) == di1) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di2), static_cast<bool>((tmp-=di1) == di1) ); |     PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=di1) == di1) ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 + di1 == di2) ); |     BOOST_TEST( di1 + di1 == di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(di1 + 1 == di2) ); |     BOOST_TEST( di1 + 1 == di2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 + di1 == di2) ); |     BOOST_TEST( 1 + di1 == di2 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp+=1) == di2) ); |     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=1) == di2) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp+=di1) == di2) ); |     PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=di1) == di2) ); | ||||||
|  |  | ||||||
|     cout << "Performed tests on MyDoubleInt objects.\n"; |     cout << "Performed tests on MyDoubleInt objects.\n"; | ||||||
|  |  | ||||||
| @@ -890,50 +839,50 @@ test_main( int , char * [] ) | |||||||
|     MyLongInt li; |     MyLongInt li; | ||||||
|     MyLongInt tmp2; |     MyLongInt tmp2; | ||||||
|  |  | ||||||
|     BOOST_CHECK( li1.value() == 1 ); |     BOOST_TEST( li1.value() == 1 ); | ||||||
|     BOOST_CHECK( li2.value() == 2 ); |     BOOST_TEST( li2.value() == 2 ); | ||||||
|     BOOST_CHECK( li.value() == 0 ); |     BOOST_TEST( li.value() == 0 ); | ||||||
|  |  | ||||||
|     cout << "Created MyLongInt objects.\n"; |     cout << "Created MyLongInt objects.\n"; | ||||||
|  |  | ||||||
|     PRIVATE_EXPR_TEST( (li = li2), (li.value() == 2) ); |     PRIVATE_EXPR_TEST( (li = li2), (li.value() == 2) ); | ||||||
|      |      | ||||||
|     BOOST_CHECK( static_cast<bool>(li2 == li) ); |     BOOST_TEST( li2 == li ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 == li) ); |     BOOST_TEST( 2 == li ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li == 2) ); |     BOOST_TEST( li == 2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 < li2) ); |     BOOST_TEST( li1 < li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 < li2) ); |     BOOST_TEST( 1 < li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 <= li2) ); |     BOOST_TEST( li1 <= li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 <= li2) ); |     BOOST_TEST( 1 <= li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li2 > li1) ); |     BOOST_TEST( li2 > li1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li2 > 1) ); |     BOOST_TEST( li2 > 1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li2 >= li1) ); |     BOOST_TEST( li2 >= li1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li2 >= 1) ); |     BOOST_TEST( li2 >= 1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 % li2 == li1) ); |     BOOST_TEST( li1 % li2 == li1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 % 2 == li1) ); |     BOOST_TEST( li1 % 2 == li1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 % li2 == li1) ); |     BOOST_TEST( 1 % li2 == li1 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2%=2) == li1) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=2) == li1) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2%=li2) == li1) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=li2) == li1) ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 / li2 == 0) ); |     BOOST_TEST( li1 / li2 == 0 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 / 2 == 0) ); |     BOOST_TEST( li1 / 2 == 0 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 / li2 == 0) ); |     BOOST_TEST( 1 / li2 == 0 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2/=2) == 0) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=2) == 0) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2/=li2) == 0) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=li2) == 0) ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 * li2 == li2) ); |     BOOST_TEST( li1 * li2 == li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 * 2 == li2) ); |     BOOST_TEST( li1 * 2 == li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 * li2 == li2) ); |     BOOST_TEST( 1 * li2 == li2 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2*=2) == li2) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=2) == li2) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2*=li2) == li2) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=li2) == li2) ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li2 - li1 == li1) ); |     BOOST_TEST( li2 - li1 == li1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li2 - 1 == li1) ); |     BOOST_TEST( li2 - 1 == li1 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(2 - li1 == li1) ); |     BOOST_TEST( 2 - li1 == li1 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), static_cast<bool>((tmp2-=1) == li1) ); |     PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=1) == li1) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), static_cast<bool>((tmp2-=li1) == li1) ); |     PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=li1) == li1) ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 + li1 == li2) ); |     BOOST_TEST( li1 + li1 == li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(li1 + 1 == li2) ); |     BOOST_TEST( li1 + 1 == li2 ); | ||||||
|     BOOST_CHECK( static_cast<bool>(1 + li1 == li2) ); |     BOOST_TEST( 1 + li1 == li2 ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2+=1) == li2) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=1) == li2) ); | ||||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2+=li1) == li2) ); |     PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=li1) == li2) ); | ||||||
|  |  | ||||||
|     cout << "Performed tests on MyLongInt objects.\n"; |     cout << "Performed tests on MyLongInt objects.\n"; | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										177
									
								
								permutation_iterator.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										177
									
								
								permutation_iterator.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,177 @@ | |||||||
|  | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN"> | ||||||
|  |  | ||||||
|  | <html> | ||||||
|  | <head> | ||||||
|  | <title>Permutation Iterator Adaptor Documentation</title> | ||||||
|  | </head> | ||||||
|  |  | ||||||
|  | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  |          | ||||||
|  | <h1>Permutation Iterator Adaptor</h1> | ||||||
|  | <p>Defined in header <a href="../../boost/permutation_iterator.hpp">boost/permutation_iterator.hpp</a></p> | ||||||
|  | <p>The permutation iterator adaptor provides an iterator to a permutation of a given range. | ||||||
|  | (<a href="http://www.cut-the-knot.com/do_you_know/permutation.html">see definition of permutation</a>). | ||||||
|  | The adaptor takes two arguments | ||||||
|  | <ul> | ||||||
|  | <li>an iterator to the range V on which the <a href="http://www.cut-the-knot.com/do_you_know/permutation.html">permutation</a> will be applied</li> | ||||||
|  | <li>the reindexing scheme that defines how the elements of V will be permuted.</li> | ||||||
|  | </ul> | ||||||
|  |  | ||||||
|  | <p>Note that the permutation iterator is not limited to strict permutations of the given range V.  | ||||||
|  | The distance between begin and end of the reindexing iterators is allowed to be smaller compared to the  | ||||||
|  | size of the range V, in which case the permutation iterator only provides a permutation of a subrange of V.  | ||||||
|  | The indexes neither need to be unique. In this same context, it must be noted that the past the end permutation iterator is  | ||||||
|  | completely defined by means of the past-the-end iterator to the indices</p>  | ||||||
|  |  | ||||||
|  | <h2>Synopsis</h2> | ||||||
|  |  | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  | namespace boost { | ||||||
|  |   template <class IndexIterator> | ||||||
|  |   class permutation_iterator_policies; | ||||||
|  |  | ||||||
|  |   template <class ElementIterator, class IndexIterator> | ||||||
|  |   class permutation_iterator_generator; | ||||||
|  |  | ||||||
|  |   template <class ElementIterator, class IndexIterator> | ||||||
|  |   typename permutation_iterator_generator<ElementIterator, IndexIterator>::type | ||||||
|  |   make_permutation_iterator(ElementIterator& base, IndexIterator& indexing); | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  | </blockquote> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h2>The Permutation Iterator Generator Class Template</h2> | ||||||
|  |  | ||||||
|  | <p>The <code>permutation_iterator_generator</code> is a helper class whose purpose | ||||||
|  | is to construct a permutation iterator <strong>type</strong>. This class has | ||||||
|  | two template arguments, the first being the iterator type over the range V, the | ||||||
|  | second being the type of the iterator over the indices. | ||||||
|  |  | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class ElementIterator, class IndexIterator> | ||||||
|  | class permutation_iterator_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   typedef <a href="iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...> type; // the resulting permutation iterator type  | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  | </blockquote> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  | <table border> | ||||||
|  | <tr> | ||||||
|  | <th>Parameter</th> | ||||||
|  | <th>Description</th> | ||||||
|  | </tr> | ||||||
|  |  | ||||||
|  | <tr> | ||||||
|  | <td><tt>ElementIterator</tt></td> | ||||||
|  | <td>The iterator over the elements to be permuted. This type must be a model | ||||||
|  | of <a href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">RandomAccessIterator</a></td> | ||||||
|  | </td> | ||||||
|  |  | ||||||
|  | <tr> | ||||||
|  | <td><tt>IndexIterator</tt></td> | ||||||
|  | <td>The iterator over the new indexing scheme. This type must at least be a model | ||||||
|  | of <a href="http://www.sgi.com/tech/stl/ForwardIterator.html">ForwardIterator</a>. | ||||||
|  | The <code>IndexIterator::value_type</code> must be convertible to the  | ||||||
|  | <code>ElementIterator::difference_type</code>.</td> | ||||||
|  | </table> | ||||||
|  |  | ||||||
|  | <h3>Concept Model</h3> | ||||||
|  | The permutation iterator is always a model of the same concept as the IndexIterator. | ||||||
|  |  | ||||||
|  | <h3>Members</h3> | ||||||
|  | The permutation iterator implements the member functions | ||||||
|  | and operators required for the  | ||||||
|  | <a href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random Access Iterator</a> | ||||||
|  | concept. However, the permutation iterator can only meet the complexity guarantees  | ||||||
|  | of the same concept as the IndexIterator. Thus for instance, although the permutation | ||||||
|  | iterator provides <code>operator+=(distance)</code>, this operation will take linear time | ||||||
|  | in case the IndexIterator is a model of ForwardIterator instead of amortized constant time. | ||||||
|  |  | ||||||
|  | <br> | ||||||
|  |  | ||||||
|  | <h2><a name="make_generator_iterator">The Permutation Iterator Object Generator</a></h2> | ||||||
|  |  | ||||||
|  | The <code>make_permutation_iterator()</code> function provides a | ||||||
|  | convenient way to create permutation iterator objects. The function | ||||||
|  | saves the user the trouble of explicitly writing out the iterator | ||||||
|  | types. | ||||||
|  |  | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class ElementIterator, class IndexIterator > | ||||||
|  | typename permutation_iterator_generator<ElementIterator, IndexIterator>::type | ||||||
|  | make_permutation_iterator(ElementIterator& base, IndexIterator& indices); | ||||||
|  | </pre> | ||||||
|  | </blockquote> | ||||||
|  |  | ||||||
|  | <h2>Example</h2> | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  |   using namespace boost; | ||||||
|  |   int i = 0; | ||||||
|  |  | ||||||
|  |   typedef std::vector< int > element_range_type; | ||||||
|  |   typedef std::list< int > index_type; | ||||||
|  |  | ||||||
|  |   static const int element_range_size = 10; | ||||||
|  |   static const int index_size = 4; | ||||||
|  |  | ||||||
|  |   element_range_type elements( element_range_size ); | ||||||
|  |   for(element_range_type::iterator el_it = elements.begin() ; el_it != elements.end() ; ++el_it) *el_it = std::distance(elements.begin(), el_it); | ||||||
|  |  | ||||||
|  |   index_type indices( index_size ); | ||||||
|  |   for(index_type::iterator i_it = indices.begin() ; i_it != indices.end() ; ++i_it ) *i_it = element_range_size - index_size + std::distance(indices.begin(), i_it); | ||||||
|  |   std::reverse( indices.begin(), indices.end() ); | ||||||
|  |  | ||||||
|  |   typedef permutation_iterator_generator< element_range_type::iterator, index_type::iterator >::type permutation_type; | ||||||
|  |   permutation_type begin = make_permutation_iterator( elements.begin(), indices.begin() ); | ||||||
|  |   permutation_type it = begin; | ||||||
|  |   permutation_type end = make_permutation_iterator( elements.begin(), indices.end() ); | ||||||
|  |  | ||||||
|  |   std::cout << "The original range is : "; | ||||||
|  |   std::copy( elements.begin(), elements.end(), std::ostream_iterator< int >( std::cout, " " ) ); | ||||||
|  |   std::cout << "\n"; | ||||||
|  |  | ||||||
|  |   std::cout << "The reindexing scheme is : "; | ||||||
|  |   std::copy( indices.begin(), indices.end(), std::ostream_iterator< int >( std::cout, " " ) ); | ||||||
|  |   std::cout << "\n"; | ||||||
|  |  | ||||||
|  |   std::cout << "The permutated range is : "; | ||||||
|  |   std::copy( begin, end, std::ostream_iterator< int >( std::cout, " " ) ); | ||||||
|  |   std::cout << "\n"; | ||||||
|  |  | ||||||
|  |   std::cout << "Elements at even indices in the permutation : "; | ||||||
|  |   it = begin; | ||||||
|  |   for(i = 0; i < index_size / 2 ; ++i, it+=2 ) std::cout << *it << " "; | ||||||
|  |   std::cout << "\n"; | ||||||
|  |  | ||||||
|  |   std::cout << "Permutation backwards : "; | ||||||
|  |   it = begin + (index_size); | ||||||
|  |   assert( it != begin ); | ||||||
|  |   for( ; it-- != begin ; ) std::cout << *it << " "; | ||||||
|  |   std::cout << "\n"; | ||||||
|  |  | ||||||
|  |   std::cout << "Iterate backward with stride 2 : "; | ||||||
|  |   it = begin + (index_size - 1); | ||||||
|  |   for(i = 0 ; i < index_size / 2 ; ++i, it-=2 ) std::cout << *it << " "; | ||||||
|  |   std::cout << "\n"; | ||||||
|  | </pre> | ||||||
|  | </blockquote> | ||||||
|  |  | ||||||
|  | <br><br><br><hr> | ||||||
|  | Thanks: The permutation iterator is only a small addition to the superb iterator adaptors | ||||||
|  | library of David Abrahams and Jeremy Siek. | ||||||
|  | <br><br> | ||||||
|  |  | ||||||
|  | Copyright 2001 Toon Knapen. | ||||||
|  |  | ||||||
|  | </body> | ||||||
|  | </html> | ||||||
							
								
								
									
										391
									
								
								projection_iterator.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										391
									
								
								projection_iterator.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,391 @@ | |||||||
|  | <html> | ||||||
|  |  | ||||||
|  | <head> | ||||||
|  | <meta http-equiv="Content-Type" content="text/html; charset=windows-1252"> | ||||||
|  | <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> | ||||||
|  | <meta name="ProgId" content="FrontPage.Editor.Document"> | ||||||
|  | <title>Projection Iterator Adaptor Documentation</title> | ||||||
|  | </head> | ||||||
|  |  | ||||||
|  | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  |  | ||||||
|  | <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" | ||||||
|  | align="center" width="277" height="86"> | ||||||
|  |  | ||||||
|  | <h1>Projection Iterator Adaptor</h1> | ||||||
|  |  | ||||||
|  | Defined in header | ||||||
|  | <a href="../../boost/iterator_adaptors.hpp">boost/iterator_adaptors.hpp</a> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | The projection iterator adaptor is similar to the <a | ||||||
|  | href="./transform_iterator.htm">transform iterator adaptor</a> in that | ||||||
|  | its <tt>operator*()</tt> applies some function to the result of | ||||||
|  | dereferencing the base iterator and then returns the result. The | ||||||
|  | difference is that the function must return a reference to some | ||||||
|  | existing object (for example, a data member within the | ||||||
|  | <tt>value_type</tt> of the base iterator). The following | ||||||
|  | <b>pseudo-code</b> gives the basic idea. The data member <tt>p</tt> is | ||||||
|  | the function object. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  |   reference projection_iterator::operator*() const { | ||||||
|  |     return this->p(*this->base_iterator); | ||||||
|  |   } | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <h2>Synopsis</h2> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | namespace boost { | ||||||
|  |   template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>, class BaseIterator> | ||||||
|  |   struct projection_iterator_generator; | ||||||
|  |    | ||||||
|  |   template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>,  | ||||||
|  |             class BaseIterator, class ConstBaseIterator> | ||||||
|  |   struct projection_iterator_pair_generator; | ||||||
|  |  | ||||||
|  |   template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>, class BaseIterator> | ||||||
|  |   typename projection_iterator_generator<AdaptableUnaryFunction, BaseIterator>::type | ||||||
|  |   make_projection_iterator(BaseIterator base, | ||||||
|  | 			   const AdaptableUnaryFunction& p = AdaptableUnaryFunction()) | ||||||
|  |  | ||||||
|  |   template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>, class ConstBaseIterator> | ||||||
|  |   typename projection_iterator_generator<AdaptableUnaryFunction, ConstBaseIterator>::type | ||||||
|  |   make_const_projection_iterator(ConstBaseIterator base, | ||||||
|  |                                  const AdaptableUnaryFunction& p = AdaptableUnaryFunction())   | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  |  | ||||||
|  | <h2><a name="projection_iterator_generator">The Projection Iterator Type | ||||||
|  | Generator</a></h2> | ||||||
|  |  | ||||||
|  | The class <tt>projection_iterator_generator</tt> is a helper class | ||||||
|  | whose purpose is to construct an projection iterator type.  The main | ||||||
|  | template parameter for this class is the <a | ||||||
|  | href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html"><tt>AdaptableUnaryFunction</tt></a> | ||||||
|  | function object type and the <tt>BaseIterator</tt> type that is being | ||||||
|  | wrapped. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>, class BaseIterator> | ||||||
|  | class projection_iterator_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   typedef <tt><a href="./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> type; // the resulting projection iterator type  | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <h3>Example</h3> | ||||||
|  |  | ||||||
|  | In the following example we have a list of personnel records. Each | ||||||
|  | record has an employee's name and ID number. We want to be able to | ||||||
|  | traverse through the list accessing either the name or the ID numbers | ||||||
|  | of the employees using the projection iterator so we create the | ||||||
|  | function object classes <tt>select_name</tt> and | ||||||
|  | <tt>select_ID</tt>. We then use the | ||||||
|  | <tt>projection_iterator_generator</tt> class to create a projection | ||||||
|  | iterator and use it to print out the names of the employees. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <list> | ||||||
|  | #include <iostream> | ||||||
|  | #include <iterator> | ||||||
|  | #include <algorithm> | ||||||
|  | #include <string> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | struct personnel_record { | ||||||
|  |   personnel_record(std::string n, int id) : m_name(n), m_ID(id) { } | ||||||
|  |   std::string m_name; | ||||||
|  |   int m_ID; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | struct select_name { | ||||||
|  |   typedef personnel_record argument_type; | ||||||
|  |   typedef std::string result_type; | ||||||
|  |   const std::string& operator()(const personnel_record& r) const { | ||||||
|  |     return r.m_name; | ||||||
|  |   } | ||||||
|  |   std::string& operator()(personnel_record& r) const { | ||||||
|  |     return r.m_name; | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | struct select_ID { | ||||||
|  |   typedef personnel_record argument_type; | ||||||
|  |   typedef int result_type; | ||||||
|  |   const int& operator()(const personnel_record& r) const { | ||||||
|  |     return r.m_ID; | ||||||
|  |   } | ||||||
|  |   int& operator()(personnel_record& r) const { | ||||||
|  |     return r.m_ID; | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   std::list<personnel_record> personnel_list; | ||||||
|  |  | ||||||
|  |   personnel_list.push_back(personnel_record("Barney", 13423)); | ||||||
|  |   personnel_list.push_back(personnel_record("Fred", 12343)); | ||||||
|  |   personnel_list.push_back(personnel_record("Wilma", 62454)); | ||||||
|  |   personnel_list.push_back(personnel_record("Betty", 20490)); | ||||||
|  |  | ||||||
|  |   // Example of using projection_iterator_generator | ||||||
|  |   // to print out the names in the personnel list. | ||||||
|  |  | ||||||
|  |   boost::projection_iterator_generator<select_name, | ||||||
|  |     std::list<personnel_record>::iterator>::type | ||||||
|  |     personnel_first(personnel_list.begin()), | ||||||
|  |     personnel_last(personnel_list.end()); | ||||||
|  |  | ||||||
|  |   std::copy(personnel_first, personnel_last, | ||||||
|  |             std::ostream_iterator<std::string>(std::cout, "\n")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // to be continued... | ||||||
|  | </pre> | ||||||
|  | The output for this part is: | ||||||
|  | <pre> | ||||||
|  | Barney | ||||||
|  | Fred | ||||||
|  | Wilma | ||||||
|  | Betty | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  | <Table border> | ||||||
|  | <TR> | ||||||
|  | <TH>Parameter</TH><TH>Description</TH> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html"><tt>AdaptableUnaryFunction</tt></a></TD> | ||||||
|  | <TD>The type of the function object. The <tt>argument_type</tt> of the | ||||||
|  | function must match the value type of the base iterator. The function | ||||||
|  | should return a reference to the function's <tt>result_type</tt>. | ||||||
|  | The <tt>result_type</tt> will be the resulting iterator's <tt>value_type</tt>. | ||||||
|  | </TD> | ||||||
|  | </TD> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>BaseIterator</tt></TD> | ||||||
|  | <TD>The iterator type being wrapped.</TD> | ||||||
|  | </TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | </Table> | ||||||
|  |  | ||||||
|  | <h3>Model of</h3> | ||||||
|  |  | ||||||
|  | If the base iterator is a model of <a | ||||||
|  | href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  | Access Iterator</a> then so is the resulting projection iterator.  If | ||||||
|  | the base iterator supports less functionality than this the resulting | ||||||
|  | projection iterator will also support less functionality. | ||||||
|  |  | ||||||
|  | <h3>Members</h3> | ||||||
|  |  | ||||||
|  | The projection iterator type implements the member functions and | ||||||
|  | operators required of the <a | ||||||
|  | href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  | Access Iterator</a> concept. | ||||||
|  | In addition it has the following constructor: | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | projection_iterator_generator::type(const BaseIterator& it, | ||||||
|  |                                     const AdaptableUnaryFunction& p = AdaptableUnaryFunction()) | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | <hr> | ||||||
|  | <p> | ||||||
|  |  | ||||||
|  | <h2><a name="projection_iterator_pair_generator">The Projection Iterator Pair | ||||||
|  | Generator</a></h2> | ||||||
|  |  | ||||||
|  | Sometimes a mutable/const pair of iterator types is needed, such as | ||||||
|  | when implementing a container type. The | ||||||
|  | <tt>projection_iterator_pair_generator</tt> class makes it more | ||||||
|  | convenient to create this pair of iterator types. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>, class BaseIterator, class ConstBaseIterator> | ||||||
|  | class projection_iterator_pair_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   typedef <tt><a href="./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> iterator;       // the mutable projection iterator type  | ||||||
|  |   typedef <tt><a href="./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> const_iterator; // the immutable projection iterator type  | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <h3>Example</h3> | ||||||
|  |  | ||||||
|  | In this part of the example we use the | ||||||
|  | <tt>projection_iterator_pair_generator</tt> to create a mutable/const | ||||||
|  | pair of projection iterators that access the ID numbers of the | ||||||
|  | personnel. We use the mutable iterator to re-index the ID numbers from | ||||||
|  | zero. We then use the constant iterator to print the ID numbers out. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  |   // continuing from the last example... | ||||||
|  |  | ||||||
|  |   typedef boost::projection_iterator_pair_generator<select_ID, | ||||||
|  |     std::list<personnel_record>::iterator, | ||||||
|  |     std::list<personnel_record>::const_iterator> PairGen; | ||||||
|  |  | ||||||
|  |   PairGen::iterator ID_first(personnel_list.begin()), | ||||||
|  |     ID_last(personnel_list.end()); | ||||||
|  |  | ||||||
|  |   int new_id = 0; | ||||||
|  |   while (ID_first != ID_last) { | ||||||
|  |     *ID_first = new_id++; | ||||||
|  |     ++ID_first; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   PairGen::const_iterator const_ID_first(personnel_list.begin()), | ||||||
|  |     const_ID_last(personnel_list.end()); | ||||||
|  |  | ||||||
|  |   std::copy(const_ID_first, const_ID_last, | ||||||
|  |             std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |   std::cout << std::endl; | ||||||
|  |    | ||||||
|  |   // to be continued... | ||||||
|  | </pre> | ||||||
|  | The output is: | ||||||
|  | <pre> | ||||||
|  | 0 1 2 3  | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  | <Table border> | ||||||
|  | <TR> | ||||||
|  | <TH>Parameter</TH><TH>Description</TH> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html"><tt>AdaptableUnaryFunction</tt></a></TD> | ||||||
|  | <TD>The type of the function object. The <tt>argument_type</tt> of the | ||||||
|  | function must match the value type of the base iterator. The function | ||||||
|  | should return a true reference to the function's <tt>result_type</tt>. | ||||||
|  | The <tt>result_type</tt> will be the resulting iterator's <tt>value_type</tt>. | ||||||
|  | </TD> | ||||||
|  | </TD> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>BaseIterator</tt></TD> | ||||||
|  | <TD>The mutable iterator type being wrapped.</TD> | ||||||
|  | </TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | <TR> | ||||||
|  | <TD><tt>ConstBaseIterator</tt></TD> | ||||||
|  | <TD>The constant iterator type being wrapped.</TD> | ||||||
|  | </TD> | ||||||
|  | </TR> | ||||||
|  |  | ||||||
|  | </Table> | ||||||
|  |  | ||||||
|  | <h3>Model of</h3> | ||||||
|  |  | ||||||
|  | If the base iterator types model the <a | ||||||
|  | href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  | Access Iterator</a> then so do the resulting projection iterator | ||||||
|  | types.  If the base iterators support less functionality the | ||||||
|  | resulting projection iterator types will also support less | ||||||
|  | functionality.  The resulting <tt>iterator</tt> type is mutable, and | ||||||
|  | the resulting <tt>const_iterator</tt> type is constant. | ||||||
|  |  | ||||||
|  | <h3>Members</h3> | ||||||
|  |  | ||||||
|  | The resulting <tt>iterator</tt> and <tt>const_iterator</tt> types | ||||||
|  | implements the member functions and operators required of the <a | ||||||
|  | href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random | ||||||
|  | Access Iterator</a> concept.  In addition they support the following | ||||||
|  | constructors: | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | projection_iterator_pair_generator::iterator(const BaseIterator& it, | ||||||
|  |                                              const AdaptableUnaryFunction& p = AdaptableUnaryFunction())</pre> | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | projection_iterator_pair_generator::const_iterator(const BaseIterator& it, | ||||||
|  |                                                    const AdaptableUnaryFunction& p = AdaptableUnaryFunction()) | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <p> | ||||||
|  | <hr> | ||||||
|  | <p> | ||||||
|  |  | ||||||
|  | <h2><a name="make_projection_iterator">The Projection Iterator Object Generators</a></h2> | ||||||
|  |  | ||||||
|  | The <tt>make_projection_iterator()</tt> and | ||||||
|  | <tt>make_const_projection_iterator()</tt> functions provide a more | ||||||
|  | convenient way to create projection iterator objects. The functions | ||||||
|  | save the user the trouble of explicitly writing out the iterator | ||||||
|  | types. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>, class BaseIterator> | ||||||
|  | typename projection_iterator_generator<AdaptableUnaryFunction, BaseIterator>::type | ||||||
|  | make_projection_iterator(BaseIterator base, | ||||||
|  | 			 const AdaptableUnaryFunction& p = AdaptableUnaryFunction())   | ||||||
|  |  | ||||||
|  | template <class <a href="http://www.sgi.com/tech/stl/AdaptableUnaryFunction.html">AdaptableUnaryFunction</a>, class ConstBaseIterator> | ||||||
|  | typename projection_iterator_generator<AdaptableUnaryFunction, ConstBaseIterator>::type | ||||||
|  | make_const_projection_iterator(ConstBaseIterator base, | ||||||
|  | 			       const AdaptableUnaryFunction& p = AdaptableUnaryFunction())   | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <h3>Example</h3> | ||||||
|  |  | ||||||
|  | In this part of the example, we again print out the names of the | ||||||
|  | personnel, but this time we use the | ||||||
|  | <tt>make_const_projection_iterator()</tt> function to save some typing. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  |   // continuing from the last example... | ||||||
|  |  | ||||||
|  |   std::copy | ||||||
|  |     (boost::make_const_projection_iterator<select_name>(personnel_list.begin()), | ||||||
|  |      boost::make_const_projection_iterator<select_name>(personnel_list.end()), | ||||||
|  |      std::ostream_iterator<std::string>(std::cout, "\n")); | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  | The output is: | ||||||
|  | <pre> | ||||||
|  | Barney | ||||||
|  | Fred | ||||||
|  | Wilma | ||||||
|  | Betty | ||||||
|  | </pre> | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  | <p>Revised <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %b %Y" startspan -->19 Aug 2001<!--webbot bot="Timestamp" endspan i-checksum="14767" --></p> | ||||||
|  | <p><EFBFBD> Copyright Jeremy Siek 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> | ||||||
|  |  | ||||||
|  | </body> | ||||||
|  |  | ||||||
|  | </html> | ||||||
|  | <!--  LocalWords:  html charset alt gif hpp BaseIterator const namespace struct | ||||||
|  |  --> | ||||||
|  | <!--  LocalWords:  ConstPointer ConstReference typename iostream int abcdefg | ||||||
|  |  --> | ||||||
|  | <!--  LocalWords:  sizeof  PairGen pre Siek htm AdaptableUnaryFunction | ||||||
|  |  --> | ||||||
|  | <!--  LocalWords:  ConstBaseIterator | ||||||
|  |  --> | ||||||
							
								
								
									
										96
									
								
								projection_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								projection_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,96 @@ | |||||||
|  | // (C) Copyright Jeremy Siek 2000. 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. | ||||||
|  |  | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <list> | ||||||
|  | #include <iostream> | ||||||
|  | #include <iterator> | ||||||
|  | #include <algorithm> | ||||||
|  | #include <string> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | struct personnel_record { | ||||||
|  |   personnel_record(std::string n, int id) : m_name(n), m_ID(id) { } | ||||||
|  |   std::string m_name; | ||||||
|  |   int m_ID; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | struct select_name { | ||||||
|  |   typedef personnel_record argument_type; | ||||||
|  |   typedef std::string result_type; | ||||||
|  |   const std::string& operator()(const personnel_record& r) const { | ||||||
|  |     return r.m_name; | ||||||
|  |   } | ||||||
|  |   std::string& operator()(personnel_record& r) const { | ||||||
|  |     return r.m_name; | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | struct select_ID { | ||||||
|  |   typedef personnel_record argument_type; | ||||||
|  |   typedef int result_type; | ||||||
|  |   const int& operator()(const personnel_record& r) const { | ||||||
|  |     return r.m_ID; | ||||||
|  |   } | ||||||
|  |   int& operator()(personnel_record& r) const { | ||||||
|  |     return r.m_ID; | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   std::list<personnel_record> personnel_list; | ||||||
|  |  | ||||||
|  |   personnel_list.push_back(personnel_record("Barney", 13423)); | ||||||
|  |   personnel_list.push_back(personnel_record("Fred", 12343)); | ||||||
|  |   personnel_list.push_back(personnel_record("Wilma", 62454)); | ||||||
|  |   personnel_list.push_back(personnel_record("Betty", 20490)); | ||||||
|  |  | ||||||
|  |   // Example of using projection_iterator_generator | ||||||
|  |   // to print out the names in the personnel list. | ||||||
|  |  | ||||||
|  |   boost::projection_iterator_generator<select_name, | ||||||
|  |     std::list<personnel_record>::iterator>::type | ||||||
|  |     personnel_first(personnel_list.begin()), | ||||||
|  |     personnel_last(personnel_list.end()); | ||||||
|  |  | ||||||
|  |   std::copy(personnel_first, personnel_last, | ||||||
|  |             std::ostream_iterator<std::string>(std::cout, "\n")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |    | ||||||
|  |   // Example of using projection_iterator_pair_generator | ||||||
|  |   // to assign new ID numbers to the personnel. | ||||||
|  |    | ||||||
|  |   typedef boost::projection_iterator_pair_generator<select_ID, | ||||||
|  |     std::list<personnel_record>::iterator, | ||||||
|  |     std::list<personnel_record>::const_iterator> PairGen; | ||||||
|  |  | ||||||
|  |   PairGen::iterator ID_first(personnel_list.begin()), | ||||||
|  |     ID_last(personnel_list.end()); | ||||||
|  |  | ||||||
|  |   int new_id = 0; | ||||||
|  |   while (ID_first != ID_last) { | ||||||
|  |     *ID_first = new_id++; | ||||||
|  |     ++ID_first; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   PairGen::const_iterator const_ID_first(personnel_list.begin()), | ||||||
|  |     const_ID_last(personnel_list.end()); | ||||||
|  |  | ||||||
|  |   std::copy(const_ID_first, const_ID_last, | ||||||
|  |             std::ostream_iterator<int>(std::cout, " ")); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |   std::cout << std::endl; | ||||||
|  |    | ||||||
|  |   // Example of using make_const_projection_iterator() | ||||||
|  |   // to print out the names in the personnel list again. | ||||||
|  |    | ||||||
|  |   std::copy | ||||||
|  |     (boost::make_const_projection_iterator<select_name>(personnel_list.begin()), | ||||||
|  |      boost::make_const_projection_iterator<select_name>(personnel_list.end()), | ||||||
|  |      std::ostream_iterator<std::string>(std::cout, "\n")); | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -1,18 +1,9 @@ | |||||||
| // Copyright David Abrahams and Aleksey Gurtovoy |  | ||||||
| // 2002-2004. 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) |  | ||||||
|  |  | ||||||
| // compile-time test for "boost/ref.hpp" header content | // compile-time test for "boost/ref.hpp" header content | ||||||
| // see 'ref_test.cpp' for run-time part | // see 'ref_test.cpp' for run-time part | ||||||
|  |  | ||||||
| #include <boost/ref.hpp> | #include <boost/ref.hpp> | ||||||
| #include <boost/type_traits/is_same.hpp> | #include <boost/type_traits/same_traits.hpp> | ||||||
| #include <boost/type_traits/remove_const.hpp> |  | ||||||
| #include <boost/static_assert.hpp> | #include <boost/static_assert.hpp> | ||||||
| #include <boost/detail/workaround.hpp> |  | ||||||
|  |  | ||||||
| #include <boost/mpl/assert.hpp> |  | ||||||
|  |  | ||||||
| namespace { | namespace { | ||||||
|  |  | ||||||
| @@ -39,23 +30,13 @@ void is_reference_wrapper_test(T) | |||||||
| template< typename R, typename Ref > | template< typename R, typename Ref > | ||||||
| void cxx_reference_test(Ref) | void cxx_reference_test(Ref) | ||||||
| { | { | ||||||
| #if BOOST_WORKAROUND(__BORLANDC__, < 0x600) |  | ||||||
|     typedef typename boost::remove_const<Ref>::type ref; |  | ||||||
|     BOOST_STATIC_ASSERT((boost::is_same<R,ref>::value)); |  | ||||||
| #else |  | ||||||
|     BOOST_STATIC_ASSERT((boost::is_same<R,Ref>::value)); |     BOOST_STATIC_ASSERT((boost::is_same<R,Ref>::value)); | ||||||
| #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| template< typename R, typename Ref > | template< typename R, typename Ref > | ||||||
| void unwrap_reference_test(Ref) | void unwrap_reference_test(Ref) | ||||||
| { | { | ||||||
| #if BOOST_WORKAROUND(__BORLANDC__, < 0x600) |  | ||||||
|     typedef typename boost::remove_const<Ref>::type ref; |  | ||||||
|     typedef typename boost::unwrap_reference<ref>::type type; |  | ||||||
| #else |  | ||||||
|     typedef typename boost::unwrap_reference<Ref>::type type; |     typedef typename boost::unwrap_reference<Ref>::type type; | ||||||
| #endif |  | ||||||
|     BOOST_STATIC_ASSERT((boost::is_same<R,type>::value)); |     BOOST_STATIC_ASSERT((boost::is_same<R,type>::value)); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										55
									
								
								ref_test.cpp
									
									
									
									
									
								
							
							
						
						
									
										55
									
								
								ref_test.cpp
									
									
									
									
									
								
							| @@ -1,7 +1,3 @@ | |||||||
| // Copyright David Abrahams and Aleksey Gurtovoy |  | ||||||
| // 2002-2004. 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) |  | ||||||
|  |  | ||||||
| // run-time test for "boost/ref.hpp" header content | // run-time test for "boost/ref.hpp" header content | ||||||
| // see 'ref_ct_test.cpp' for compile-time part | // see 'ref_ct_test.cpp' for compile-time part | ||||||
| @@ -60,62 +56,19 @@ struct ref_wrapper | |||||||
|  |  | ||||||
|     static void test(T x) |     static void test(T x) | ||||||
|     { |     { | ||||||
|         BOOST_CHECK(passthru(ref(x)) == &x); |         BOOST_TEST(passthru(ref(x)) == &x); | ||||||
|         BOOST_CHECK(&ref(x).get() == &x); |         BOOST_TEST(&ref(x).get() == &x); | ||||||
|  |  | ||||||
|         BOOST_CHECK(cref_passthru(cref(x)) == &x); |         BOOST_TEST(cref_passthru(cref(x)) == &x); | ||||||
|         BOOST_CHECK(&cref(x).get() == &x); |         BOOST_TEST(&cref(x).get() == &x); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| 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 | } // 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 * []) | int test_main(int, char * []) | ||||||
| { | { | ||||||
|     ref_wrapper<int>::test(1); |     ref_wrapper<int>::test(1); | ||||||
|     ref_wrapper<int const>::test(1); |     ref_wrapper<int const>::test(1); | ||||||
|     unwrap_test(); |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										331
									
								
								reverse_iterator.htm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										331
									
								
								reverse_iterator.htm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,331 @@ | |||||||
|  | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN"> | ||||||
|  |  | ||||||
|  | <html> | ||||||
|  | <head> | ||||||
|  |     <meta name="generator" content="HTML Tidy, see www.w3.org"> | ||||||
|  |     <meta http-equiv="Content-Type" content="text/html; charset=windows-1252"> | ||||||
|  |     <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> | ||||||
|  |     <meta name="ProgId" content="FrontPage.Editor.Document"> | ||||||
|  |  | ||||||
|  |     <title>Reverse Iterator Adaptor Documentation</title> | ||||||
|  | </head> | ||||||
|  |  | ||||||
|  | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  |     <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" align= | ||||||
|  |     "center" width="277" height="86">  | ||||||
|  |  | ||||||
|  |     <h1>Reverse Iterator Adaptor</h1> | ||||||
|  |     Defined in header <a href= | ||||||
|  |     "../../boost/iterator_adaptors.hpp">boost/iterator_adaptors.hpp</a>  | ||||||
|  |  | ||||||
|  |     <p>The reverse iterator adaptor flips the direction of a base iterator's | ||||||
|  |     motion. Invoking <tt>operator++()</tt> moves the base iterator backward and | ||||||
|  |     invoking <tt>operator--()</tt> moves the base iterator forward. The Boost | ||||||
|  |     reverse iterator adaptor is better to use than the | ||||||
|  |     <tt>std::reverse_iterator</tt> class in situations where pairs of | ||||||
|  |     mutable/constant iterators are needed (e.g., in containers) because | ||||||
|  |     comparisons and conversions between the mutable and const versions are | ||||||
|  |     implemented correctly. | ||||||
|  |  | ||||||
|  |     <h2>Synopsis</h2> | ||||||
|  | <pre> | ||||||
|  | namespace boost { | ||||||
|  |   template <class <a href= | ||||||
|  | "http://www.sgi.com/tech/stl/BidirectionalIterator.html">BidirectionalIterator</a>, | ||||||
|  |             class Value, class Reference, class Pointer, class Category, class Distance> | ||||||
|  |   struct reverse_iterator_generator; | ||||||
|  |    | ||||||
|  |   template <class <a href= | ||||||
|  | "http://www.sgi.com/tech/stl/BidirectionalIterator.html">BidirectionalIterator</a>> | ||||||
|  |   typename reverse_iterator_generator<BidirectionalIterator>::type | ||||||
|  |   make_reverse_iterator(BidirectionalIterator base)   | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <h2><a name="reverse_iterator_generator">The Reverse Iterator Type | ||||||
|  |     Generator</a></h2> | ||||||
|  |     The <tt>reverse_iterator_generator</tt> template is a <a href= | ||||||
|  |     "../../more/generic_programming.html#type_generator">generator</a> of | ||||||
|  |     reverse iterator types. The main template parameter for this class is the | ||||||
|  |     base <tt>BidirectionalIterator</tt> type that is being adapted. In most | ||||||
|  |     cases the associated types of the base iterator can be deduced using | ||||||
|  |     <tt>std::iterator_traits</tt>, but in some situations the user may want to | ||||||
|  |     override these types, so there are also template parameters for the base | ||||||
|  |     iterator's associated types.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class <a href= | ||||||
|  | "http://www.sgi.com/tech/stl/BidirectionalIterator.html">BidirectionalIterator</a>, | ||||||
|  |           class Value, class Reference, class Pointer, class Category, class Distance> | ||||||
|  | class reverse_iterator_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   typedef <tt><a href= | ||||||
|  | "./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...></tt> type; // the resulting reverse iterator type  | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Example</h3> | ||||||
|  |     In this example we sort a sequence of letters and then output the sequence | ||||||
|  |     in descending order using reverse iterators.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <iostream> | ||||||
|  | #include <algorithm> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   char letters[] = "hello world!"; | ||||||
|  |   const int N = sizeof(letters)/sizeof(char) - 1; | ||||||
|  |   std::cout << "original sequence of letters:\t" | ||||||
|  |       << letters << std::endl; | ||||||
|  |  | ||||||
|  |   std::sort(letters, letters + N); | ||||||
|  |  | ||||||
|  |   // Use reverse_iterator_generator to print a sequence | ||||||
|  |   // of letters in reverse order. | ||||||
|  |    | ||||||
|  |   boost::reverse_iterator_generator<char*>::type | ||||||
|  |     reverse_letters_first(letters + N), | ||||||
|  |     reverse_letters_last(letters); | ||||||
|  |  | ||||||
|  |   std::cout << "letters in descending order:\t"; | ||||||
|  |   std::copy(reverse_letters_first, reverse_letters_last, | ||||||
|  |       std::ostream_iterator<char>(std::cout)); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // to be continued... | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |     The output is:  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | original sequence of letters: hello world! | ||||||
|  | letters in descending order:  wroolllhed!  | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Template Parameters</h3> | ||||||
|  |  | ||||||
|  |     <table border> | ||||||
|  |       <tr> | ||||||
|  |         <th>Parameter | ||||||
|  |  | ||||||
|  |         <th>Description | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt><a href= | ||||||
|  |         "http://www.sgi.com/tech/stl/BidirectionalIterator.html">BidirectionalIterator</a></tt> | ||||||
|  |          | ||||||
|  |  | ||||||
|  |         <td>The iterator type being wrapped. | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Value</tt>  | ||||||
|  |  | ||||||
|  |         <td>The value-type of the base iterator and the resulting reverse | ||||||
|  |         iterator.<br> | ||||||
|  |          <b>Default:</b><tt>std::iterator_traits<BidirectionalIterator>::value_type</tt> | ||||||
|  |          | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Reference</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>reference</tt> type of the resulting iterator, and in | ||||||
|  |         particular, the result type of <tt>operator*()</tt>.<br> | ||||||
|  |          <b>Default:</b> If <tt>Value</tt> is supplied, <tt>Value&</tt> is | ||||||
|  |         used. Otherwise | ||||||
|  |         <tt>std::iterator_traits<BidirectionalIterator>::reference</tt> | ||||||
|  |         is used. | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Pointer</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>pointer</tt> type of the resulting iterator, and in | ||||||
|  |         particular, the result type of <tt>operator->()</tt>.<br> | ||||||
|  |          <b>Default:</b> If <tt>Value</tt> was supplied, then <tt>Value*</tt>, | ||||||
|  |         otherwise | ||||||
|  |         <tt>std::iterator_traits<BidirectionalIterator>::pointer</tt>. | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Category</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>iterator_category</tt> type for the resulting iterator.<br> | ||||||
|  |          <b>Default:</b> | ||||||
|  |         <tt>std::iterator_traits<BidirectionalIterator>::iterator_category</tt> | ||||||
|  |          | ||||||
|  |  | ||||||
|  |       <tr> | ||||||
|  |         <td><tt>Distance</tt>  | ||||||
|  |  | ||||||
|  |         <td>The <tt>difference_type</tt> for the resulting iterator.<br> | ||||||
|  |          <b>Default:</b> | ||||||
|  |         <tt>std::iterator_traits<BidirectionalIterator&gt::difference_type</tt> | ||||||
|  |          | ||||||
|  |     </table> | ||||||
|  |  | ||||||
|  |     <h3>Concept Model</h3> | ||||||
|  |     The indirect iterator will model whichever <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/Iterators.html">standard iterator concept | ||||||
|  |     category</a> is modeled by the base iterator. Thus, if the base iterator is | ||||||
|  |     a model of <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random Access | ||||||
|  |     Iterator</a> then so is the resulting indirect iterator. If the base | ||||||
|  |     iterator models a more restrictive concept, the resulting indirect iterator | ||||||
|  |     will model the same concept. The base iterator must be at least a <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/BidirectionalIterator.html">Bidirectional | ||||||
|  |     Iterator</a>  | ||||||
|  |  | ||||||
|  |     <h3>Members</h3> | ||||||
|  |     The reverse iterator type implements the member functions and operators | ||||||
|  |     required of the <a href= | ||||||
|  |     "http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random Access | ||||||
|  |     Iterator</a> concept. In addition it has the following constructor:  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | reverse_iterator_generator::type(const BidirectionalIterator& it) | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <br> | ||||||
|  |      <br> | ||||||
|  |       | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <p> | ||||||
|  |  | ||||||
|  |     <h2><a name="make_reverse_iterator">The Reverse Iterator Object | ||||||
|  |     Generator</a></h2> | ||||||
|  |     The <tt>make_reverse_iterator()</tt> function provides a more convenient | ||||||
|  |     way to create reverse iterator objects. The function saves the user the | ||||||
|  |     trouble of explicitly writing out the iterator types.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | template <class BidirectionalIterator> | ||||||
|  | typename reverse_iterator_generator<BidirectionalIterator>::type | ||||||
|  | make_reverse_iterator(BidirectionalIterator base); | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |  | ||||||
|  |     <h3>Example</h3> | ||||||
|  |     In this part of the example we use <tt>make_reverse_iterator()</tt> to | ||||||
|  |     print the sequence of letters in reverse-reverse order, which is the | ||||||
|  |     original order.  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  |   // continuing from the previous example... | ||||||
|  |  | ||||||
|  |   std::cout << "letters in ascending order:\t"; | ||||||
|  |   std::copy(boost::make_reverse_iterator(reverse_letters_last), | ||||||
|  |       boost::make_reverse_iterator(reverse_letters_first), | ||||||
|  |       std::ostream_iterator<char>(std::cout)); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |     The output is:  | ||||||
|  |  | ||||||
|  |     <blockquote> | ||||||
|  | <pre> | ||||||
|  | letters in ascending order:  !dehllloorw | ||||||
|  | </pre> | ||||||
|  |     </blockquote> | ||||||
|  |     <hr> | ||||||
|  |  | ||||||
|  |     <h2><a name="interactions">Constant/Mutable Iterator Interactions</a></h2> | ||||||
|  |  | ||||||
|  |     <p>One failing of the standard <tt><a | ||||||
|  |     href="http://www.sgi.com/tech/stl/ReverseIterator.html">reverse_iterator</a></tt> | ||||||
|  |     adaptor is that it doesn't properly support interactions between adapted | ||||||
|  |     <tt>const</tt> and non-<tt>const</tt> iterators. For example: | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  | #include <vector> | ||||||
|  |  | ||||||
|  | template <class T> void convert(T x) {} | ||||||
|  |  | ||||||
|  | // Test interactions of a matched pair of random access iterators | ||||||
|  | template <class Iterator, class ConstIterator> | ||||||
|  | void test_interactions(Iterator i, ConstIterator ci) | ||||||
|  | { | ||||||
|  |   bool eq = i == ci;               // comparisons | ||||||
|  |   bool ne = i != ci;             | ||||||
|  |   bool lt = i < ci; | ||||||
|  |   bool le = i <= ci; | ||||||
|  |   bool gt = i > ci; | ||||||
|  |   bool ge = i >= ci; | ||||||
|  |   std::size_t distance = i - ci;   // difference | ||||||
|  |   ci = i;                          // assignment | ||||||
|  |   ConstIterator ci2(i);            // construction | ||||||
|  |   convert<ConstIterator>(i);       // implicit conversion | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void f() | ||||||
|  | { | ||||||
|  |   typedef std::vector<int> vec; | ||||||
|  |   vec v; | ||||||
|  |   const vec& cv; | ||||||
|  |  | ||||||
|  |   test_interactions(v.begin(), cv.begin());   // <font color="#007F00">OK</font> | ||||||
|  |   test_interactions(v.rbegin(), cv.rbegin()); // <font color="#FF0000">ERRORS ON EVERY TEST!!</font> | ||||||
|  | </pre> | ||||||
|  | </blockquote> | ||||||
|  | Reverse iterators created with <tt>boost::reverse_iterator_generator</tt> don't have this problem, though: | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  |   typedef boost::reverse_iterator_generator<vec::iterator>::type ri; | ||||||
|  |   typedef boost::reverse_iterator_generator<vec::const_iterator>::type cri; | ||||||
|  |   test_interactions(ri(v.begin()), cri(cv.begin()));   // <font color="#007F00">OK!!</font> | ||||||
|  | </pre> | ||||||
|  | </blockquote> | ||||||
|  | Or, more simply, | ||||||
|  | <blockquote> | ||||||
|  | <pre> | ||||||
|  |   test_interactions( | ||||||
|  |     boost::make_reverse_iterator(v.begin()),  | ||||||
|  |     boost::make_reverse_iterator(cv.begin()));   // <font color="#007F00">OK!!</font> | ||||||
|  | } | ||||||
|  | </pre> | ||||||
|  | </blockquote> | ||||||
|  |  | ||||||
|  | <p>If you are wondering why there is no | ||||||
|  | <tt>reverse_iterator_pair_generator</tt> in the manner of <tt><a | ||||||
|  | href="projection_iterator.htm#projection_iterator_pair_generator">projection_iterator_pair_generator</a></tt>, | ||||||
|  | the answer is simple: we tried it, but found that in practice it took | ||||||
|  | <i>more</i> typing to use <tt>reverse_iterator_pair_generator</tt> than to | ||||||
|  | simply use <tt>reverse_iterator_generator</tt> twice!<br><br> | ||||||
|  |  | ||||||
|  | <hr> | ||||||
|  |  | ||||||
|  |      | ||||||
|  |     <p>Revised  | ||||||
|  |     <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %b %Y" startspan -->19 Aug 2001<!--webbot bot="Timestamp" endspan i-checksum="14767" --> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <p>© Copyright Jeremy Siek 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.  | ||||||
|  |     <!--  LocalWords:  html charset alt gif hpp BidirectionalIterator const namespace struct | ||||||
|  |          --> | ||||||
|  |       | ||||||
|  |     <!--  LocalWords:  ConstPointer ConstReference typename iostream int abcdefg | ||||||
|  |          --> | ||||||
|  |      <!--  LocalWords:  sizeof  PairGen pre Siek wroolllhed dehllloorw | ||||||
|  |          --> | ||||||
|  | </body> | ||||||
|  | </html> | ||||||
|  |  | ||||||
							
								
								
									
										51
									
								
								reverse_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								reverse_iterator_example.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | // (C) Copyright Jeremy Siek 2000. 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. | ||||||
|  |  | ||||||
|  | #include <boost/config.hpp> | ||||||
|  | #include <iostream> | ||||||
|  | #include <algorithm> | ||||||
|  | #include <boost/iterator_adaptors.hpp> | ||||||
|  |  | ||||||
|  | int main(int, char*[]) | ||||||
|  | { | ||||||
|  |   char letters_[] = "hello world!"; | ||||||
|  |   const int N = sizeof(letters_)/sizeof(char) - 1; | ||||||
|  | #ifdef BOOST_NO_STD_ITERATOR_TRAITS | ||||||
|  |   // Assume there won't be proper iterator traits for pointers. This | ||||||
|  |   // is just a wrapper for char* which has the right traits. | ||||||
|  |   typedef boost::iterator_adaptor<char*, boost::default_iterator_policies, char> base_iterator; | ||||||
|  | #else | ||||||
|  |   typedef char* base_iterator; | ||||||
|  | #endif | ||||||
|  |   base_iterator letters(letters_); | ||||||
|  |    | ||||||
|  |   std::cout << "original sequence of letters:\t" | ||||||
|  |             << letters_ << std::endl; | ||||||
|  |  | ||||||
|  |   std::sort(letters, letters + N); | ||||||
|  |  | ||||||
|  |   // Use reverse_iterator_generator to print a sequence | ||||||
|  |   // of letters in reverse order. | ||||||
|  |    | ||||||
|  |   boost::reverse_iterator_generator<base_iterator>::type | ||||||
|  |     reverse_letters_first(letters + N), | ||||||
|  |     reverse_letters_last(letters); | ||||||
|  |  | ||||||
|  |   std::cout << "letters in descending order:\t"; | ||||||
|  |   std::copy(reverse_letters_first, reverse_letters_last, | ||||||
|  |             std::ostream_iterator<char>(std::cout)); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   // Use make_reverse_iterator() to print the sequence | ||||||
|  |   // of letters in reverse-reverse order. | ||||||
|  |  | ||||||
|  |   std::cout << "letters in ascending order:\t"; | ||||||
|  |   std::copy(boost::make_reverse_iterator(reverse_letters_last), | ||||||
|  |             boost::make_reverse_iterator(reverse_letters_first), | ||||||
|  |             std::ostream_iterator<char>(std::cout)); | ||||||
|  |   std::cout << std::endl; | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
| @@ -9,7 +9,7 @@ | |||||||
|  |  | ||||||
| <body bgcolor="#FFFFFF" text="#000000"> | <body bgcolor="#FFFFFF" text="#000000"> | ||||||
|  |  | ||||||
| <img src="../../boost.png" alt="boost.png (6897 bytes)" | <img src="../../c++boost.gif" alt="c++boost.gif (8819 bytes)" | ||||||
| align="center" width="277" height="86"> | align="center" width="277" height="86"> | ||||||
|  |  | ||||||
| <h1>Shared Container Iterator</h1> | <h1>Shared Container Iterator</h1> | ||||||
| @@ -19,22 +19,21 @@ Defined in header | |||||||
|  |  | ||||||
| <p> | <p> | ||||||
| The purpose of the shared container iterator is to attach the lifetime  | The purpose of the shared container iterator is to attach the lifetime  | ||||||
| of a container to the lifetime of its iterators. In other words, the | of a container to the lifetime of its iterators. In other words,  | ||||||
| container will not be deleted until after all its iterators are | the container will be deleted after the last iterator is destroyed.    | ||||||
| destroyed.  The shared container iterator is typically used to | The shared container iterator is typically used to implement functions  | ||||||
| implement functions that return iterators over a range of objects that | that return iterators over a | ||||||
| only need to exist for the lifetime of the iterators.  By returning a | range of objects that will only be needed for the lifetime of | ||||||
| pair of shared iterators from a function, the callee can return a | the iterators.  By returning a pair of shared iterators from a | ||||||
| heap-allocated range of objects whose lifetime is automatically managed. | function, the callee can ensure that the underlying container's  | ||||||
|  | lifetime will be properly managed. | ||||||
| <p> | <p> | ||||||
| The shared container iterator augments an iterator over a shared | The shared container iterator augments an iterator into a shared | ||||||
| container.  It maintains a reference count on the shared  | container with a reference counted pointer to the container.  | ||||||
| container. If only shared container iterators hold references to | Assuming no other references exist to the container, it will be | ||||||
| the container, the container's lifetime will end when the last shared | destroyed when the last shared container iterator is destroyed. | ||||||
| container iterator over it is destroyed.  In any case, the shared | In all other ways, the shared container iterator | ||||||
| container is guaranteed to persist beyond the lifetime of all | behaves the same as its base iterator. | ||||||
| the iterators. In all other ways, the |  | ||||||
| shared container iterator behaves the same as its base iterator. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <h2>Synopsis</h2> | <h2>Synopsis</h2> | ||||||
| @@ -42,44 +41,49 @@ shared container iterator behaves the same as its base iterator. | |||||||
| <pre> | <pre> | ||||||
| namespace boost { | namespace boost { | ||||||
|   template <typename <a href="http://www.sgi.com/tech/stl/Container.html">Container</a>> |   template <typename <a href="http://www.sgi.com/tech/stl/Container.html">Container</a>> | ||||||
|   class shared_container_iterator; |   class shared_container_iterator_generator; | ||||||
|  |  | ||||||
|   template <typename <a href="http://www.sgi.com/tech/stl/Container.html">Container</a>> |   template <typename <a href="http://www.sgi.com/tech/stl/Container.html">Container</a>> | ||||||
|   shared_container_iterator<Container> |   typename shared_container_iterator_generator<Container>::type | ||||||
|   make_shared_container_iterator(typename Container::iterator base,  |   make_shared_container_iterator(typename Container::iterator base,  | ||||||
|     boost::shared_ptr<Container> const& container); |     boost::shared_ptr<Container> const& container); | ||||||
|  |  | ||||||
|   std::pair< |   std::pair< | ||||||
|     typename shared_container_iterator<Container>, |     typename shared_container_iterator_generator<Container>::type, | ||||||
|     typename shared_container_iterator<Container> |     typename shared_container_iterator_generator<Container>::type | ||||||
|   > |   > | ||||||
|   make_shared_container_range(boost::shared_ptr<Container> const& container); |   make_shared_container_range(boost::shared_ptr<Container> const& container); | ||||||
|  |  | ||||||
| } | } | ||||||
| </pre> | </pre> | ||||||
|  |  | ||||||
| <hr> | <hr> | ||||||
|  |  | ||||||
| <h2><a name="generator">The Shared Container Iterator Type</a></h2> | <h2><a name="generator">The Shared Container Iterator Type Generator</a></h2> | ||||||
|  |  | ||||||
| <pre> | The class <tt>shared_container_iterator_generator</tt> is a helper | ||||||
| template <typename Container> class shared_container_iterator; | class to construct a shared container iterator type.  The template | ||||||
| </pre> | parameter for this class is a type that models the  | ||||||
|  |  | ||||||
| The class template <tt>shared_container_iterator</tt>  |  | ||||||
| is the shared container iterator type.  The <tt>Container</tt> template |  | ||||||
| type argument must model the |  | ||||||
| <a href="http://www.sgi.com/tech/stl/Container.html">Container</a> | <a href="http://www.sgi.com/tech/stl/Container.html">Container</a> | ||||||
| concept. | concept. | ||||||
|  |  | ||||||
|  | <pre> | ||||||
|  | template <typename Container> | ||||||
|  | class shared_container_iterator_generator | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     typedef <a href="./iterator_adaptors.htm#iterator_adaptor">iterator_adaptor</a><...> type; | ||||||
|  | }; | ||||||
|  | </pre> | ||||||
|  |  | ||||||
| <h3>Example</h3> | <h3>Example</h3> | ||||||
|  |  | ||||||
| <p> | <p> | ||||||
| The following example illustrates how to create an iterator that  | The following example illustrates how to use the | ||||||
|  | <tt>shared_counter_iterator_generator</tt> to create an iterator that  | ||||||
| regulates the lifetime of a reference counted <tt>std::vector</tt>. | regulates the lifetime of a reference counted <tt>std::vector</tt>. | ||||||
| Though the original shared pointer <tt>ints</tt> ceases to exist | Though the original <tt>shared_ptr</tt> to the vector ceases to exist, the | ||||||
| after <tt>set_range()</tt> returns, the | <tt>shared_counter_iterator</tt>s extend the lifetime of the container. | ||||||
| <tt>shared_counter_iterator</tt> objects maintain references to the |  | ||||||
|       underlying vector and thereby extend the container's lifetime. |  | ||||||
| <p> | <p> | ||||||
| <a href="./shared_iterator_example1.cpp">shared_iterator_example1.cpp</a>: | <a href="./shared_iterator_example1.cpp">shared_iterator_example1.cpp</a>: | ||||||
| <PRE> | <PRE> | ||||||
| @@ -89,7 +93,7 @@ after <tt>set_range()</tt> returns, the | |||||||
| <font color="#008040">#include <iostream></font> | <font color="#008040">#include <iostream></font> | ||||||
| <font color="#008040">#include <vector></font> | <font color="#008040">#include <vector></font> | ||||||
|  |  | ||||||
| <B>typedef</B> boost::shared_container_iterator< std::vector<<B>int</B>> > iterator; | <B>typedef</B> boost::shared_container_iterator_generator< std::vector<<B>int</B>> >::type iterator; | ||||||
|  |  | ||||||
|  |  | ||||||
| <B>void</B> set_range(iterator& i, iterator& end)  { | <B>void</B> set_range(iterator& i, iterator& end)  { | ||||||
| @@ -146,9 +150,12 @@ concept. | |||||||
|  |  | ||||||
| <h3>Model of</h3> | <h3>Model of</h3> | ||||||
|  |  | ||||||
| The <tt>shared_container_iterator<Container></tt> type models the | The shared container iterator adaptor (the type | ||||||
|  | <tt>shared_container_iterator_generator<...>::type</tt>) models the | ||||||
| same iterator concept as the base iterator | same iterator concept as the base iterator | ||||||
|     (<tt>Container::iterator</tt>). |     (<tt>Container::iterator</tt>) up to  | ||||||
|  | <a href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random  | ||||||
|  |       Access Iterator</a>. | ||||||
|  |  | ||||||
| <h3>Members</h3> | <h3>Members</h3> | ||||||
|  |  | ||||||
| @@ -159,7 +166,7 @@ concept, though only operations defined for the base iterator will be valid. | |||||||
| In addition it has the following constructor: | In addition it has the following constructor: | ||||||
|  |  | ||||||
| <pre> | <pre> | ||||||
| shared_container_iterator(Container::iterator const& it, | shared_container_iterator_generator::type(Container::iterator const& it, | ||||||
|                                           boost::shared_ptr<Container> const& container) |                                           boost::shared_ptr<Container> const& container) | ||||||
| </pre> | </pre> | ||||||
|  |  | ||||||
| @@ -172,15 +179,16 @@ shared_container_iterator(Container::iterator const& it, | |||||||
|  |  | ||||||
| <pre> | <pre> | ||||||
| template <typename Container> | template <typename Container> | ||||||
| shared_container_iterator<Container> | typename shared_container_iterator_generator<AdaptableUnaryFunction,BaseIterator>::type | ||||||
| make_shared_container_iterator(Container::iterator base, | make_shared_container_iterator(Container::iterator base, | ||||||
|                                boost::shared_ptr<Container> const& container) |                                boost::shared_ptr<Container> const& container) | ||||||
| </pre> | </pre> | ||||||
|  |  | ||||||
| This function provides an alternative to directly constructing a | This function provides an alternative to using the shared container | ||||||
| shared container iterator.  Using the object generator, a shared | iterator type generator to create the iterator type before | ||||||
| container iterator can be created and passed to a function without | construction. Using the object generator, a shared container iterator | ||||||
| explicitly specifying its type. | can be created and passed to a function without explicitly specifying | ||||||
|  | its type. | ||||||
|  |  | ||||||
| <h3>Example</h3> | <h3>Example</h3> | ||||||
|  |  | ||||||
| @@ -238,16 +246,16 @@ explicitly named. The output from this example is the same as the previous. | |||||||
| <pre> | <pre> | ||||||
| template <typename Container> | template <typename Container> | ||||||
| std::pair< | std::pair< | ||||||
|   shared_container_iterator<Container>, |   typename shared_container_iterator_generator<Container>::type, | ||||||
|   shared_container_iterator<Container> |   typename shared_container_iterator_generator<Container>::type | ||||||
| > | > | ||||||
| make_shared_container_range(boost::shared_ptr<Container> const& container); | make_shared_container_range(boost::shared_ptr<Container> const& container); | ||||||
| </pre> | </pre> | ||||||
|  |  | ||||||
| Class <tt>shared_container_iterator</tt> is meant primarily to return, | Class <tt>shared_container_iterator</tt> is meant primarily to return | ||||||
| using iterators, a range of values that we can guarantee will be alive as  | via iterators a range of values that we can guarantee will be alive as  | ||||||
| long as the iterators are. This is a convenience | long as the iterators are. This is a convenience | ||||||
| function to do just that. It is equivalent to | function to do just that. This function is equivalent to | ||||||
|  |  | ||||||
| <pre> | <pre> | ||||||
| std::make_pair(make_shared_container_iterator(container->begin(),container), | std::make_pair(make_shared_container_iterator(container->begin(),container), | ||||||
| @@ -257,7 +265,7 @@ std::make_pair(make_shared_container_iterator(container->begin(),container), | |||||||
| <h3>Example</h3> | <h3>Example</h3> | ||||||
|  |  | ||||||
| In the following example, a range of values is returned as a pair of | In the following example, a range of values is returned as a pair of | ||||||
| <tt>shared_container_iterator</tt> objects.   | <tt>shared_container_iterator</tt>s.   | ||||||
|  |  | ||||||
|  |  | ||||||
| <p> | <p> | ||||||
| @@ -272,9 +280,10 @@ In the following example, a range of values is returned as a pair of | |||||||
| <font color="#008040">#include <vector></font> | <font color="#008040">#include <vector></font> | ||||||
|  |  | ||||||
|  |  | ||||||
| <B>typedef</B> boost::shared_container_iterator< std::vector<<B>int</B>> > iterator;  | <B>typedef</B> boost::shared_container_iterator_generator< std::vector<<B>int</B>> >::type  | ||||||
|  |   function_iterator; | ||||||
|  |  | ||||||
| std::pair<iterator,iterator> | std::pair<function_iterator,function_iterator> | ||||||
| return_range() { | return_range() { | ||||||
|   boost::shared_ptr< std::vector<<B>int</B>> > range(<B>new</B> std::vector<<B>int</B>>()); |   boost::shared_ptr< std::vector<<B>int</B>> > range(<B>new</B> std::vector<<B>int</B>>()); | ||||||
|   range->push_back(<font color="#0000A0">0</font>); |   range->push_back(<font color="#0000A0">0</font>); | ||||||
| @@ -290,7 +299,7 @@ return_range() { | |||||||
| <B>int</B> main() { | <B>int</B> main() { | ||||||
|  |  | ||||||
|  |  | ||||||
|   iterator i,end; |   function_iterator i,end; | ||||||
|    |    | ||||||
|   boost::tie(i,end) = return_range(); |   boost::tie(i,end) = return_range(); | ||||||
|  |  | ||||||
| @@ -310,12 +319,13 @@ the previous two. | |||||||
|  |  | ||||||
| <hr> | <hr> | ||||||
| <!-- hhmts start --> | <!-- hhmts start --> | ||||||
| Last modified: Mon Aug 11 11:27:03 EST 2003 | Last modified: Wed Sep  4 15:52:17 EST 2002 | ||||||
| <!-- hhmts end --> | <!-- hhmts end --> | ||||||
| <p><EFBFBD> Copyright 2003 The Trustees of Indiana University. | <p><EFBFBD> Copyright Ronald Garcia 2002. Permission to copy, use, | ||||||
|  Use, modification and distribution is subject to the Boost Software  | modify, sell and distribute this document is granted provided this copyright | ||||||
|  License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | notice appears in all copies. This document is provided "as is" | ||||||
|  http://www.boost.org/LICENSE_1_0.txt)</p> | without express or implied warranty, and with no claim as to its suitability for | ||||||
|  | any purpose.</p> | ||||||
|  |  | ||||||
| </body> | </body> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,8 +1,7 @@ | |||||||
| // Copyright 2003 The Trustees of Indiana University. | // (C) Copyright Ronald Garcia 2002. Permission to copy, use, modify, sell and | ||||||
|  | // distribute this software is granted provided this copyright notice appears | ||||||
| // Use, modification and distribution is subject to the Boost Software  | // in all copies. This software is provided "as is" without express or implied | ||||||
| // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | // warranty, and with no claim as to its suitability for any purpose. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
|  |  | ||||||
| #include "boost/shared_container_iterator.hpp" | #include "boost/shared_container_iterator.hpp" | ||||||
| #include "boost/shared_ptr.hpp" | #include "boost/shared_ptr.hpp" | ||||||
| @@ -10,7 +9,8 @@ | |||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <vector> | #include <vector> | ||||||
|  |  | ||||||
| typedef boost::shared_container_iterator< std::vector<int> > iterator; | typedef boost::shared_container_iterator_generator< std::vector<int> >::type | ||||||
|  |   iterator; | ||||||
|  |  | ||||||
|  |  | ||||||
| void set_range(iterator& i, iterator& end)  { | void set_range(iterator& i, iterator& end)  { | ||||||
|   | |||||||
| @@ -1,8 +1,7 @@ | |||||||
| // Copyright 2003 The Trustees of Indiana University. | // (C) Copyright Ronald Garcia 2002. Permission to copy, use, modify, sell and | ||||||
|  | // distribute this software is granted provided this copyright notice appears | ||||||
| // Use, modification and distribution is subject to the Boost Software  | // in all copies. This software is provided "as is" without express or implied | ||||||
| // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | // warranty, and with no claim as to its suitability for any purpose. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
|  |  | ||||||
| #include "boost/shared_container_iterator.hpp" | #include "boost/shared_container_iterator.hpp" | ||||||
| #include "boost/shared_ptr.hpp" | #include "boost/shared_ptr.hpp" | ||||||
|   | |||||||
| @@ -1,8 +1,7 @@ | |||||||
| // Copyright 2003 The Trustees of Indiana University. | // (C) Copyright Ronald Garcia 2002. Permission to copy, use, modify, sell and | ||||||
|  | // distribute this software is granted provided this copyright notice appears | ||||||
| // Use, modification and distribution is subject to the Boost Software  | // in all copies. This software is provided "as is" without express or implied | ||||||
| // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at | // warranty, and with no claim as to its suitability for any purpose. | ||||||
| // http://www.boost.org/LICENSE_1_0.txt) |  | ||||||
|  |  | ||||||
| #include "boost/shared_container_iterator.hpp" | #include "boost/shared_container_iterator.hpp" | ||||||
| #include "boost/shared_ptr.hpp" | #include "boost/shared_ptr.hpp" | ||||||
| @@ -12,9 +11,10 @@ | |||||||
| #include <vector> | #include <vector> | ||||||
|  |  | ||||||
|  |  | ||||||
| typedef boost::shared_container_iterator< std::vector<int> > iterator; | typedef boost::shared_container_iterator_generator< std::vector<int> >::type  | ||||||
|  |   function_iterator; | ||||||
|  |  | ||||||
| std::pair<iterator,iterator> | std::pair<function_iterator,function_iterator> | ||||||
| return_range() { | return_range() { | ||||||
|   boost::shared_ptr< std::vector<int> > range(new std::vector<int>()); |   boost::shared_ptr< std::vector<int> > range(new std::vector<int>()); | ||||||
|   range->push_back(0); |   range->push_back(0); | ||||||
| @@ -30,7 +30,7 @@ return_range() { | |||||||
| int main() { | int main() { | ||||||
|  |  | ||||||
|  |  | ||||||
|   iterator i,end; |   function_iterator i,end; | ||||||
|    |    | ||||||
|   boost::tie(i,end) = return_range(); |   boost::tie(i,end) = return_range(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,64 +0,0 @@ | |||||||
| // 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) |  | ||||||
|  |  | ||||||
| //  Shared container iterator adaptor  |  | ||||||
| //  Author: Ronald Garcia |  | ||||||
| //  See http://boost.org/libs/utility/shared_container_iterator.html  |  | ||||||
| //  for documentation.  |  | ||||||
|  |  | ||||||
| // |  | ||||||
| // shared_iterator_test.cpp - Regression tests for shared_container_iterator. |  | ||||||
| // |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "boost/shared_container_iterator.hpp" |  | ||||||
| #include "boost/shared_ptr.hpp" |  | ||||||
| #include <vector> |  | ||||||
| #include <cassert> |  | ||||||
|  |  | ||||||
| struct resource { |  | ||||||
|   static int count; |  | ||||||
|   resource() { ++count; } |  | ||||||
|   resource(resource const&) { ++count; } |  | ||||||
|   ~resource() { --count; } |  | ||||||
| }; |  | ||||||
| int resource::count = 0; |  | ||||||
|  |  | ||||||
| typedef std::vector<resource> resources_t; |  | ||||||
|  |  | ||||||
| typedef boost::shared_container_iterator< resources_t > iterator; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void set_range(iterator& i, iterator& end)  { |  | ||||||
|  |  | ||||||
|   boost::shared_ptr< resources_t > objs(new resources_t()); |  | ||||||
|  |  | ||||||
|   for (int j = 0; j != 6; ++j) |  | ||||||
|     objs->push_back(resource()); |  | ||||||
|    |  | ||||||
|   i = iterator(objs->begin(),objs); |  | ||||||
|   end = iterator(objs->end(),objs); |  | ||||||
|   assert(resource::count == 6); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| int main() { |  | ||||||
|  |  | ||||||
|   assert(resource::count == 0); |  | ||||||
|    |  | ||||||
|   { |  | ||||||
|     iterator i; |  | ||||||
|     { |  | ||||||
|       iterator end; |  | ||||||
|       set_range(i,end); |  | ||||||
|       assert(resource::count == 6); |  | ||||||
|     } |  | ||||||
|     assert(resource::count == 6); |  | ||||||
|   } |  | ||||||
|   assert(resource::count == 0); |  | ||||||
|    |  | ||||||
|   return 0; |  | ||||||
| } |  | ||||||
							
								
								
									
										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. |  | ||||||
							
								
								
									
										98
									
								
								swap.html
									
									
									
									
									
								
							
							
						
						
									
										98
									
								
								swap.html
									
									
									
									
									
								
							| @@ -1,98 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> |  | ||||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> |  | ||||||
| <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US" lang="en-US"> |  | ||||||
|   <head> |  | ||||||
|     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> |  | ||||||
|     <title>Boost: Swap Documentation</title> |  | ||||||
|    </head> |  | ||||||
|   <body> |  | ||||||
|     <!-- Page header --> |  | ||||||
|     <h2> |  | ||||||
|     <img src="../../boost.png" alt="C++ Boost" align="middle" width="277" height="86"/> |  | ||||||
|       Header <<a href="../../boost/swap.hpp">boost/swap.hpp</a>> |  | ||||||
|     </h2> |  | ||||||
|  |  | ||||||
|     <h1>Swap</h1> |  | ||||||
|      |  | ||||||
|     <p> |  | ||||||
|       <tt>template<class T> void swap(T& <em>left</em>, T& <em>right</em>);</tt> |  | ||||||
|     </p> |  | ||||||
|       |  | ||||||
|     <!-- Introduction --> |  | ||||||
|     <p> |  | ||||||
|       The template function <tt>boost::swap</tt> allows the values of two variables to be swapped, using argument dependent lookup to select a specialized swap function if available. If no specialized swap function is available, <tt>std::swap</tt> is used. |  | ||||||
|     </p> |  | ||||||
|      |  | ||||||
|     <!-- Rationale --> |  | ||||||
|     <h2>Rationale</h2> |  | ||||||
|     <p> |  | ||||||
|       The generic <tt>std::swap</tt> function requires that the elements to be swapped are assignable and copy constructible. It is usually implemented using one copy construction and two assignments - this is often both unnecessarily restrictive and unnecessarily slow. In addition, where the generic swap implementation provides only the basic guarantee, specialized swap functions are often able to provide the no-throw exception guarantee (and it is considered best practice to do so where possible<sup><a href="#ref1">1</a></sup>).</p> |  | ||||||
|     <p> |  | ||||||
|       The alternative to using argument dependent lookup in this situation is to provide a template specialization of <tt>std::swap</tt> for every type that requires a specialized swap. Although this is legal C++, no Boost libraries use this method, whereas many Boost libraries provide specialized swap functions in their own namespaces. |  | ||||||
|     </p> |  | ||||||
|     <p> |  | ||||||
|       <tt>boost::swap</tt> also supports swapping built-in arrays. Note that <tt>std::swap</tt> originally did not do so, but a request to add an overload of <tt>std::swap</tt> for built-in arrays has been accepted by the C++ Standards Committee<sup><a href="#ref2">2</a></sup>. |  | ||||||
|     </p> |  | ||||||
|      |  | ||||||
|     <!-- Exception Safety --> |  | ||||||
|     <h2>Exception Safety</h2> |  | ||||||
|     <p> |  | ||||||
|       <tt>boost::swap</tt> provides the same exception guarantee as the underlying swap function used, with one exception; for an array of type <tt>T[n]</tt>, where <tt>n > 1</tt> and the underlying swap function for <tt>T</tt> provides the strong exception guarantee, <tt>boost::swap</tt> provides only the basic exception guarantee. |  | ||||||
|     </p> |  | ||||||
|      |  | ||||||
|     <!-- Requirements --> |  | ||||||
|     <h2>Requirements</h2> |  | ||||||
|     <p>Either:</p> |  | ||||||
|     <ul>       |  | ||||||
|       <li>T must be assignable</li> |  | ||||||
|       <li>T must be copy constructible</li> |  | ||||||
|     </ul> |  | ||||||
|     <p>Or:</p> |  | ||||||
|     <ul> |  | ||||||
|       <li>A function with the signature <tt>swap(T&,T&)</tt> is available via argument dependent lookup</li> |  | ||||||
|     </ul> |  | ||||||
|     <p>Or:</p> |  | ||||||
|     <ul> |  | ||||||
|       <li>A template specialization of <tt>std::swap</tt> exists for T</li> |  | ||||||
|     </ul> |  | ||||||
|     <p>Or:</p> |  | ||||||
|     <ul> |  | ||||||
|       <li>T is a built-in array of swappable elements</li> |  | ||||||
|     </ul> |  | ||||||
|  |  | ||||||
|      |  | ||||||
|     <!-- Portability --> |  | ||||||
|     <h2>Portability</h2> |  | ||||||
|     <p> |  | ||||||
|       Several older compilers do not support argument dependent lookup ‒ on these compilers <tt>boost::swap</tt> will call <tt>std::swap</tt>, ignoring any specialized swap functions that could be found as a result of argument dependent lookup. |  | ||||||
|     </p> |  | ||||||
|      |  | ||||||
|     <!-- Credits --> |  | ||||||
|     <h2>Credits</h2> |  | ||||||
|     <ul> |  | ||||||
|       <li> |  | ||||||
|         <em>Niels Dekker</em> - for implementing and documenting support for built-in arrays |  | ||||||
|       </li> |  | ||||||
|       <li> |  | ||||||
|         <em><a href="mailto:Joseph.Gauterin@googlemail.com">Joseph Gauterin</a></em> - for the initial idea, implementation, tests, and documentation |  | ||||||
|       </li> |  | ||||||
|       <li> |  | ||||||
|         <em>Steven Watanabe</em> - for the idea to make <tt>boost::swap</tt> less specialized than <tt>std::swap</tt>, thereby allowing the function to have the name 'swap' without introducing ambiguity |  | ||||||
|       </li>       |  | ||||||
|     </ul> |  | ||||||
|  |  | ||||||
|     <!-- References --> |  | ||||||
|     <hr/> |  | ||||||
|     <p><sup><a id="ref1"/>[1]</sup>Scott Meyers, Effective C++ Third Edition, Item 25: "Consider support for a non-throwing swap"</p> |  | ||||||
|     <p><sup><a id="ref2"/>[2]</sup><a href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html#809">LWG Defect Report 809 (std::swap should be overloaded for array types)</a></p> |  | ||||||
|  |  | ||||||
|     <!-- Copyright info -->     |  | ||||||
|     <hr/> |  | ||||||
|     <p>Revised: 08 September 2009</p> |  | ||||||
|     <p> |  | ||||||
|       Copyright 2007 - 2009 Joseph Gauterin. Use, modification, and distribution are subject to the Boost Software License, Version 1.0. |  | ||||||
|       (See accompanying file <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or a copy at <<a href="http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>>.) |  | ||||||
|     </p> |  | ||||||
|      |  | ||||||
|   </body> |  | ||||||
| </html> |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user