Compare commits

..

11 Commits

Author SHA1 Message Date
nobody
b9caeee746 This commit was manufactured by cvs2svn to create tag
'Version_1_32_0'.

[SVN r26264]
2004-11-19 19:19:18 +00:00
Aleksey Gurtovoy
0650e4f164 fix www.boost.org links
[SVN r26093]
2004-11-02 23:30:52 +00:00
Aleksey Gurtovoy
7547fc7c8d remove moved test from jamfiles
[SVN r26079]
2004-11-02 06:51:22 +00:00
Aleksey Gurtovoy
1e283a16a6 bump MSVC workaround for 7.0
[SVN r26005]
2004-10-31 10:15:04 +00:00
Aleksey Gurtovoy
c64c6c2192 fix tabs
[SVN r25995]
2004-10-31 06:24:07 +00:00
Aleksey Gurtovoy
80277b7c28 move over iterator adaptor examples from 'utility'
[SVN r25979]
2004-10-30 12:52:40 +00:00
Aleksey Gurtovoy
3d90fc5e72 fix ref_ct_test.cpp for Borland
[SVN r25972]
2004-10-30 09:34:26 +00:00
Aleksey Gurtovoy
05cb94b311 fix reference wrapper metafunction to handle cv-qualified type
[SVN r25971]
2004-10-30 09:33:27 +00:00
Aleksey Gurtovoy
1b627a9875 make value_init_test pass for compilers with no ADL support
[SVN r25962]
2004-10-30 08:07:25 +00:00
Daniel Frey
9b95ea5675 Merged fix for link to function_output_iterator
[SVN r25950]
2004-10-29 19:27:28 +00:00
nobody
df37d2c47e This commit was manufactured by cvs2svn to create branch 'RC_1_32_0'.
[SVN r25797]
2004-10-20 08:26:43 +00:00
51 changed files with 2067 additions and 2335 deletions

View File

@@ -1,109 +1,116 @@
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <HTML>
<!--
-- Copyright (c) Jeremy Siek 2000
--
-- Permission to use, copy, modify, distribute and sell this software
-- and its documentation for any purpose is hereby granted without fee,
-- provided that the above copyright notice appears in all copies and
-- that both that copyright notice and this permission notice appear
-- in supporting documentation. Silicon Graphics makes no
-- representations about the suitability of this software for any
-- purpose. It is provided "as is" without express or implied warranty.
-->
<Head>
<Title>Assignable</Title>
</HEAD>
<BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"
ALINK="#ff0000">
<IMG SRC="../../boost.png"
ALT="C++ Boost" width="277" height="86">
<!--end header-->
<BR Clear>
<H1>Assignable</H1>
<html> <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&amp;</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 &copy 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&amp;</tt></td>
<td valign="top"><tt>t</tt> is equivalent to <tt>u</tt></td>
</tr>
</table>
<h3>Models</h3>
<ul>
<li><tt>int</tt></li>
<li><tt>std::pair</tt></li>
</ul>
<h3>See also</h3>
<p><a href=
"http://www.sgi.com/tech/stl/DefaultConstructible.html">DefaultConstructible</a>
and <a href="./CopyConstructible.html">CopyConstructible</a><br></p>
<hr>
<p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src=
"http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional"
height="31" width="88"></a></p>
<p>Revised
<!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %B, %Y" startspan -->05 December, 2006<!--webbot bot="Timestamp" endspan i-checksum="38516" --></p>
<table summary="">
<tr valign="top">
<td nowrap><i>Copyright &copy; 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>

File diff suppressed because it is too large Load Diff

View File

@@ -1,139 +1,178 @@
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <HTML>
<!--
-- Copyright (c) Jeremy Siek 2000
--
-- Permission to use, copy, modify, distribute and sell this software
-- and its documentation for any purpose is hereby granted without fee,
-- provided that the above copyright notice appears in all copies and
-- that both that copyright notice and this permission notice appear
-- in supporting documentation. Silicon Graphics makes no
-- representations about the suitability of this software for any
-- purpose. It is provided "as is" without express or implied warranty.
-->
<Head>
<Title>Copy Constructible</Title>
</HEAD>
<BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"
ALINK="#ff0000">
<IMG SRC="../../boost.png"
ALT="C++ Boost" width="277" height="86">
<!--end header-->
<BR Clear>
<H1>Copy Constructible</H1>
<html> <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>
&nbsp;
</TD>
</TR>
<td valign="top"><tt>T</tt></td> <TR>
<TD VAlign=top>
<td valign="top">&nbsp;</td> Address Operator
</tr> </TD>
<TD VAlign=top>
<tr> <pre>
<td valign="top">Address Operator</td>
<td valign="top">
<pre>
&amp;t &amp;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>
&amp;u &amp;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 &lt;class T&gt; template &lt;class T&gt;
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 &copy 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>
"http://www.w3.org/Icons/valid-html401" 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 &copy; 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>

View File

@@ -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="../../boost.png"
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&lt;</tt>, and
<tt>operator&lt;</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 &lt; y) &amp;&amp; !(y &lt; x)</tt>. If this relation is
transitive (that is, if <tt>!(x &lt; y) &amp;&amp; !(y &lt; x) &amp;&amp; !(y &lt; z) &amp;&amp; !(z &lt; y)</tt>
implies <tt>!(x &lt; z) &amp;&amp; !(z &lt; x)</tt>), then it satisfies the mathematical
definition of an equivalence relation. In this case, <tt>operator&lt;</tt>
is a <i>strict weak ordering</i>.
<P>
If <tt>operator&lt;</tt> is a strict weak ordering, and if each equivalence class
has only a single element, then <tt>operator&lt;</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 &lt; y</tt>
</TD>
<TD VAlign=top>
&nbsp;
</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&lt;</tt>, and <Table border>
<tt>operator&lt;</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 &lt; y</tt>
</TD>
<TD VAlign=top>
<tt>x</tt> and <tt>y</tt> are in the domain of <tt>&lt;</tt>
</TD>
<TD VAlign=top>
&nbsp;
</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 &lt; x</tt> must be false.
</TD>
</TR>
<TR>
<TD VAlign=top>
Antisymmetry
</TD>
<TD VAlign=top>
<tt>x &lt; y</tt> implies !(y &lt; x) <A href="#2">[2]</A>
</TD>
</TR>
<TR>
<TD VAlign=top>
Transitivity
</TD>
<TD VAlign=top>
<tt>x &lt; y</tt> and <tt>y &lt; z</tt> implies <tt>x &lt; 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&lt;</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&lt;</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 &copy 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 &lt; y) &amp;&amp; !(y &lt; x)</tt>. If
this relation is transitive (that is, if <tt>!(x &lt; y) &amp;&amp; !(y
&lt; x) &amp;&amp; !(y &lt; z) &amp;&amp; !(z &lt; y)</tt> implies <tt>!(x
&lt; z) &amp;&amp; !(z &lt; x)</tt>), then it satisfies the mathematical
definition of an equivalence relation. In this case, <tt>operator&lt;</tt>
is a <i>strict weak ordering</i>.</p>
<p>If <tt>operator&lt;</tt> is a strict weak ordering, and if each
equivalence class has only a single element, then <tt>operator&lt;</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 &lt; y</tt></td>
<td valign="top">&nbsp;</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 &lt; y</tt></td>
<td valign="top"><tt>x</tt> and <tt>y</tt> are in the domain of
<tt>&lt;</tt></td>
<td valign="top">&nbsp;</td>
</tr>
</table>
<h3>Complexity guarantees</h3>
<h3>Invariants</h3>
<table border summary="">
<tr>
<td valign="top">Irreflexivity</td>
<td valign="top"><tt>x &lt; x</tt> must be false.</td>
</tr>
<tr>
<td valign="top">Antisymmetry</td>
<td valign="top"><tt>x &lt; y</tt> implies !(y &lt; x) <a href=
"#n2">[2]</a></td>
</tr>
<tr>
<td valign="top">Transitivity</td>
<td valign="top"><tt>x &lt; y</tt> and <tt>y &lt; z</tt> implies <tt>x
&lt; 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&lt;</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&lt;</tt> always satisfies the definition of a <i>partial
ordering</i>. The definition of a <i>strict weak ordering</i> is stricter,
and the definition of a <i>total ordering</i> is stricter still.</p>
<h3>See also</h3>
<p><a href=
"http://www.sgi.com/tech/stl/EqualityComparable.html">EqualityComparable</a>,
<a href=
"http://www.sgi.com/tech/stl/StrictWeakOrdering.html">StrictWeakOrdering</a><br>
</p>
<hr>
<p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src=
"http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional"
height="31" width="88"></a></p>
<p>Revised
<!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %B, %Y" startspan -->05
December, 2006<!--webbot bot="Timestamp" endspan i-checksum="38516" --></p>
<table summary="">
<tr valign="top">
<td nowrap><i>Copyright &copy; 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>

View File

@@ -1,95 +1,92 @@
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <HTML>
<!--
-- Copyright (c) Jeremy Siek 2000
--
-- Permission to use, copy, modify, distribute and sell this software
-- and its documentation for any purpose is hereby granted without fee,
-- provided that the above copyright notice appears in all copies and
-- that both that copyright notice and this permission notice appear
-- in supporting documentation. Silicon Graphics makes no
-- representations about the suitability of this software for any
-- purpose. It is provided "as is" without express or implied warranty.
-->
<Head>
<Title>MultiPassInputIterator</Title>
<BODY BGCOLOR="#ffffff" LINK="#0000ee" TEXT="#000000" VLINK="#551a8b"
ALINK="#ff0000">
<IMG SRC="../../boost.png"
ALT="C++ Boost" width="277" height="86">
<html> <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&amp;</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&amp;</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 -&gt; ForwardIterator &amp; Lvalue Iterator<br> Note that in practice the only operation not allowed on my
std::Bidirectionnal Iterator -&gt; Bidirectionnal Iterator &amp; 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 -&gt; Random Access Iterator &amp; 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>&amp;*it</tt>. I reply by Jeremy Siek:
think that <tt>&amp;*</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>
"http://www.w3.org/Icons/valid-html401" alt="Valid HTML 4.01 Transitional" <HR>
height="31" width="88"></a></p> <TABLE>
<TR valign=top>
<TD nowrap>Copyright &copy 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 &copy; 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>

View File

@@ -145,20 +145,14 @@ objects are is implemented in <a href="../../boost/utility/compare_pointees.hpp"
so direct usage of relational operators with the implied aliasing of shallow semantics 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 &copy 2003</TD><TD> <TD nowrap>Copyright &copy 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>

View File

@@ -7,88 +7,35 @@
// 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:
void dummy(); // Silence GCC warning: all member of class are private
nonaddressable( int = 0 )
{
}
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;
} }

View File

@@ -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="../../boost.png" alt="boost.png (6897 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>&lt;cassert&gt;</STRONG>, <STRONG>&lt;boost/assert.hpp&gt;</STRONG> <P>As is the case with <STRONG>&lt;cassert&gt;</STRONG>, <STRONG>&lt;boost/assert.hpp&gt;</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>&lt;boost/assert.hpp&gt;</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>

View File

@@ -351,7 +351,7 @@ with the exact pointer type used in <code>switcher</code>'s constructor.</p>
<dt>Jonathan Turkanis <dt>Jonathan Turkanis
<dd>Supplied an implementation of generating the constructor templates that <dd>Supplied an implementation of generating the constructor templates that
can be controlled and automated with macros. The implementation uses can be controlled and automated with macros. The implementation uses
the <a href="../preprocessor/index.html">Preprocessor library</a>. the <a href="../preprocessor/">Preprocessor library</a>.
<dt><a href="../../people/daryle_walker.html">Daryle Walker</a> <dt><a href="../../people/daryle_walker.html">Daryle Walker</a>
<dd>Started the library. Contributed the test file <cite><a <dd>Started the library. Contributed the test file <cite><a

View File

@@ -606,7 +606,7 @@ template &lt;bool opt&gt;
struct filler struct filler
{ {
template &lt;typename I, typename T&gt; template &lt;typename I, typename T&gt;
static void do_fill(I first, I last, typename boost::call_traits&lt;T&gt;::param_type val) static void do_fill(I first, I last, typename boost::call_traits&lt;T&gt;::param_type val);
{ {
while(first != last) while(first != last)
{ {
@@ -762,4 +762,3 @@ href="http://www.yahoogroups.com/list/boost">www.yahoogroups.com/list/boost</a>.
<p>&nbsp;</p> <p>&nbsp;</p>
</body> </body>
</html> </html>

View File

@@ -12,14 +12,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>
// 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&) {}
@@ -121,9 +121,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;
@@ -145,11 +145,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;
@@ -167,7 +167,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);
} }
// //
@@ -178,8 +178,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;
} }
@@ -231,67 +231,73 @@ int main(int argc, char *argv[ ])
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
@@ -403,3 +409,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

View File

@@ -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="../../boost.png" alt="boost.png (6897 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&lt;class T&gt; 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>

View File

@@ -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 &lt;<a href="../../boost/detail/compressed_pair.hpp">boost/compressed_pair.hpp</a>&gt;</h2> <boost/compressed_pair.hpp>
<p>All of the contents of &lt;boost/compressed_pair.hpp&gt; 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 &lt;class T1, class T2&gt; <h2><img src="../../boost.png" width="276" height="86">Header
&lt;<a href="../../boost/detail/compressed_pair.hpp">boost/compressed_pair.hpp</a>&gt;</h2>
<p>All of the contents of &lt;boost/compressed_pair.hpp&gt; 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
&quot;empty base-class optimisation&quot; is applied to compress
the size of the pair.</p>
<pre>template &lt;class T1, class T2&gt;
class compressed_pair class compressed_pair
{ {
public: public:
@@ -41,36 +52,47 @@ public:
void swap(compressed_pair&amp; y); void swap(compressed_pair&amp; 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
</html> 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 &quot;do
nothing&quot; 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
&quot;as is&quot; without express or implied warranty, and with
no claim as to its suitability for any purpose.</p>
<p>Based on contributions by Steve Cleary, Beman Dawes, Howard
Hinnant and John Maddock.</p>
<p>Maintained by <a href="mailto:john@johnmaddock.co.uk">John
Maddock</a>, the latest version of this file can be found at <a
href="http://www.boost.org">www.boost.org</a>, and the boost
discussion list at <a
href="http://www.yahoogroups.com/list/boost">www.yahoogroups.com/list/boost</a>.</p>
<p>&nbsp;</p>
</body>
</html>

View File

@@ -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 *[])

View File

@@ -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="../../boost.png" alt="boost.png (6897 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>

33
enable_if/test/Jamfile Normal file
View File

@@ -0,0 +1,33 @@
# Copyright David Abrahams 2003.
# Distributed under the Boost Software License, Version 1.0.
# (See accompanying file LICENSE_1_0.txt or copy at
# http://www.boost.org/LICENSE_1_0.txt)
# For more information, see http://www.boost.org/
subproject libs/utility/enable_if/test ;
# bring in rules for testing
import testing ;
# Make tests run by default.
DEPENDS all : test ;
{
local test_monitor = <lib>@boost/libs/test/build/boost_test_exec_monitor ;
# look in BOOST_ROOT for sources first, just in this Jamfile
local SEARCH_SOURCE = $(BOOST_ROOT) $(SEARCH_SOURCE) ;
test-suite utility/enable_if
:
[ run libs/utility/enable_if/test/constructors.cpp $(test_monitor) ]
[ run libs/utility/enable_if/test/dummy_arg_disambiguation.cpp $(test_monitor) ]
[ run libs/utility/enable_if/test/lazy.cpp $(test_monitor) ]
[ run libs/utility/enable_if/test/lazy_test.cpp $(test_monitor) ]
[ run libs/utility/enable_if/test/member_templates.cpp $(test_monitor) ]
[ run libs/utility/enable_if/test/namespace_disambiguation.cpp $(test_monitor) ]
[ run libs/utility/enable_if/test/no_disambiguation.cpp $(test_monitor) ]
[ run libs/utility/enable_if/test/partial_specializations.cpp $(test_monitor) ]
;
}

View File

@@ -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 ]
;

View File

@@ -61,7 +61,7 @@ mult(const T& x, const U& y) {return x * y;}
#if 1 #if 1
template <class T, class U> template <class T, class U>
typename lazy_enable_if_c< typename lazy_enable_if_c<
is_int<T>::value & is_int<U>::value, is_int<T>::value && is_int<U>::value,
mult_traits<T, U> mult_traits<T, U>
>::type >::type
mult(const T& x, const U& y) {return x * y;} mult(const T& x, const U& y) {return x * y;}

View File

@@ -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"> <img src="../../boost.png" alt="boost.png (6897 bytes)" align="center" width="277" height="86">
<h1>Generator Iterator Adaptor</h1> <h1>Generator Iterator Adaptor</h1>
Defined in header <a href="../../boost/generator_iterator.hpp">boost/generator_iterator.hpp</a>
<p>
The generator iterator adaptor makes it easier to create custom input
iterators from 0-ary functions and function objects. The adaptor
takes a
<a href="http://www.sgi.com/tech/stl/Generator.html">Generator</a>
and creates a model of
<a href="http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>.
Each increment retrieves an item from the generator and makes it
available to be retrieved by dereferencing. The motivation for this
iterator is that some concepts can be more naturally expressed as a
generator, while most STL algorithms expect an iterator. An example
is the <a href="../random/index.html">Random Number</a> library.
<p>Defined in header <a href= <h2>Synopsis</h2>
"../../boost/generator_iterator.hpp">boost/generator_iterator.hpp</a></p>
<p>The generator iterator adaptor makes it easier to create custom input <blockquote>
iterators from 0-ary functions and function objects. The adaptor takes a <pre>
<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>
namespace boost { namespace boost {
template &lt;class Generator&gt; template &lt;class Generator&gt;
class generator_iterator_policies; class generator_iterator_policies;
@@ -44,85 +40,87 @@ namespace boost {
make_generator_iterator(Generator &amp; gen); make_generator_iterator(Generator &amp; 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 &lt;class Generator&gt; outlive the generator iterator adaptor constructed from it.
<pre>
template &lt;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>&lt...&gt; 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 &lt;class Generator&gt; template &lt;class Generator&gt;
typename generator_iterator_generator&lt;Generator&gt;::type typename generator_iterator_generator&lt;Generator&gt;::type
make_generator_iterator(Generator &amp; gen); make_generator_iterator(Generator &amp; 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 &lt;iostream&gt; The following program shows how <code>generator_iterator</code>
#include &lt;boost/generator_iterator.hpp&gt; transforms a generator into an input iterator.
<blockquote>
<pre>
#include &lt;iostream>
#include &lt;boost/generator_iterator.hpp>
class my_generator class my_generator
{ {
@@ -142,22 +140,11 @@ int main()
std::cout &lt;&lt; *it &lt;&lt; std::endl; std::cout &lt;&lt; *it &lt;&lt; std::endl;
} }
</pre> </pre>
</blockquote> </blockquote>
<hr>
<p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src= <hr>
"http://www.w3.org/Icons/valid-html401" 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 &copy; 2001 <a href=
"../../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>

View File

@@ -3,8 +3,9 @@
<HTML> <HTML>
<HEAD> <HEAD>
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=windows-1252"> <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
<TITLE>In_place_factory Documentation</TITLE> <LINK REL="stylesheet" TYPE="text/css" HREF="../../boost.css">
<TITLE>Header </TITLE>
</HEAD> </HEAD>
<BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#800080"> <BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#800080">
@@ -76,7 +77,7 @@ object is likely to be temporary and serve no purpose besides being the source</
</pre> </pre>
<p>A solution to this problem is to support direct construction of the contained <p>A solution to this problem is to support direct construction of the contained
object right in the container's storage.<br> object right in the container's storage.<br>
In this scheme, the user supplies the arguments for the X constructor In this shceme, the user supplies the arguments for the X constructor
directly to the container:</p> directly to the container:</p>
<pre>struct C <pre>struct C
{ {
@@ -116,6 +117,9 @@ From the user POV, it amounts to creating the right factory object to hold the p
The following simplified example shows the basic idea. A complete example follows the formal specification of the framework:</p> The following simplified example shows the basic idea. A complete example follows the formal specification of the framework:</p>
<pre>struct C <pre>struct C
{ {
C() : contained_(0) {}
C ( X const& v ) : contained_ ( new X(v) ) {}
template&lt;class InPlaceFactory&gt; template&lt;class InPlaceFactory&gt;
C ( InPlaceFactory const& aFactoty ) C ( InPlaceFactory const& aFactoty )
: :
@@ -124,20 +128,16 @@ The following simplified example shows the basic idea. A complete example follow
aFactory.template apply&lt;X&gt;(contained_); aFactory.template apply&lt;X&gt;(contained_);
} }
~C() ~C() { delete contained_ ; }
{
contained_ -> X::~X();
delete[] contained_ ;
}
char* uninitialized_storage() { return new char[sizeof(X)] ; } X* uninitialized_storage() { return static_cast&lt;X*&gt;(new char[sizeof(X)]) ; }
char* contained_ ; X* contained_ ;
} ; } ;
void foo() void foo()
{ {
C c( in_place(123,"hello") ) ; C c( in_place(123,"hello" ) ;
} }
</pre> </pre>

View File

@@ -2,7 +2,6 @@
// 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 // Distributed under the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or copy at // accompanying file LICENSE_1_0.txt or copy at
@@ -33,18 +32,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

View File

@@ -32,10 +32,6 @@ inline void current_function_helper()
# define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__ # define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__
#elif defined(__DMC__) && (__DMC__ >= 0x810)
# define BOOST_CURRENT_FUNCTION __PRETTY_FUNCTION__
#elif defined(__FUNCSIG__) #elif defined(__FUNCSIG__)
# define BOOST_CURRENT_FUNCTION __FUNCSIG__ # define BOOST_CURRENT_FUNCTION __FUNCSIG__

View File

@@ -25,7 +25,6 @@
#include <boost/type_traits/is_arithmetic.hpp> #include <boost/type_traits/is_arithmetic.hpp>
#include <boost/type_traits/is_pointer.hpp> #include <boost/type_traits/is_pointer.hpp>
#include <boost/detail/workaround.hpp>
namespace boost{ namespace boost{
@@ -58,7 +57,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 +75,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 +91,7 @@ struct call_traits<T&>
typedef T& param_type; // hh removed const typedef T& param_type; // hh removed const
}; };
#if BOOST_WORKAROUND( __BORLANDC__, BOOST_TESTED_AT( 0x581 ) ) #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,15 +120,6 @@ 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) #if !defined(BOOST_NO_ARRAY_TYPE_SPECIALIZATIONS)
template <typename T, std::size_t N> template <typename T, std::size_t N>

View File

@@ -27,10 +27,6 @@
#include <boost/type_traits/is_same.hpp> #include <boost/type_traits/is_same.hpp>
#include <boost/call_traits.hpp> #include <boost/call_traits.hpp>
#ifdef BOOST_MSVC
# pragma warning(push)
# pragma warning(disable:4512)
#endif
namespace boost namespace boost
{ {
@@ -136,7 +132,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 +174,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 +217,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 +253,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;
@@ -435,9 +428,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

View File

@@ -8,8 +8,6 @@
// 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
// 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)
@@ -92,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
@@ -121,7 +119,7 @@ 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 !(x > y); } friend bool operator<=(const T& x, const U& y) { return !(x > y); }
@@ -132,7 +130,7 @@ struct less_than_comparable2 : B
friend bool operator>=(const U& x, const T& y) { return !(y > x); } friend bool operator>=(const U& x, const T& y) { return !(y > x); }
}; };
template <class T, class B = ::boost::detail::empty_base<T> > template <class T, class B = ::boost::detail::empty_base>
struct less_than_comparable1 : B 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; }
@@ -140,7 +138,7 @@ struct less_than_comparable1 : B
friend bool operator>=(const T& x, const T& y) { return !(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; }
@@ -148,7 +146,7 @@ struct equality_comparable2 : B
friend bool operator!=(const T& y, const U& x) { return !(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 !(x == y); } friend bool operator!=(const T& x, const T& y) { return !(x == y); }
@@ -167,7 +165,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 ) \
@@ -176,33 +174,33 @@ 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 ) \
{ T nrv( lhs ); nrv OP##= rhs; return nrv; } \ { T nrv( lhs ); nrv OP##= rhs; return nrv; } \
}; };
#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 BOOST_OPERATOR2_LEFT(NAME) : 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 ) \
{ T nrv( lhs ); nrv OP##= rhs; return nrv; } \ { T nrv( lhs ); nrv OP##= rhs; return nrv; } \
}; };
#else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS)
@@ -212,35 +210,35 @@ struct NAME##1 : B \
// BOOST_OPERATOR2_LEFT(NAME) only looks cool, but doesn't provide // BOOST_OPERATOR2_LEFT(NAME) only looks cool, but doesn't 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 BOOST_OPERATOR2_LEFT(NAME) : 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; } \
@@ -263,7 +261,7 @@ BOOST_BINARY_OPERATOR_COMMUTATIVE( orable, | )
// 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)
@@ -276,7 +274,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)
@@ -291,7 +289,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
@@ -300,7 +298,7 @@ struct dereferenceable : B
} }
}; };
template <class T, class I, class R, class B = ::boost::detail::empty_base<T> > template <class T, class I, class R, class B = ::boost::detail::empty_base>
struct indexable : B struct indexable : B
{ {
R operator[](I n) const R operator[](I n) const
@@ -315,14 +313,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 ) \
@@ -332,13 +330,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; } \
@@ -351,7 +349,7 @@ 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)
@@ -360,7 +358,7 @@ struct equivalent2 : B
} }
}; };
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)
@@ -369,7 +367,7 @@ struct equivalent1 : 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 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)
@@ -386,7 +384,7 @@ struct partially_ordered2 : B
{ return (y < x) || (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)
@@ -399,161 +397,161 @@ struct partially_ordered1 : B
// 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
@@ -562,43 +560,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 P, class B = ::boost::detail::empty_base<T> > template <class T, class P, class B = ::boost::detail::empty_base>
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
@@ -608,7 +606,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
@@ -652,20 +650,20 @@ 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
@@ -676,7 +674,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
@@ -701,7 +699,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) \
@@ -710,7 +708,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) \
@@ -719,7 +717,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) \
@@ -728,7 +726,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) \
@@ -754,7 +752,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> {}; \
@@ -790,7 +788,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

View File

@@ -10,7 +10,6 @@
#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
@@ -34,7 +33,7 @@ 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) {}
@@ -55,7 +54,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

View File

@@ -13,6 +13,9 @@
# 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 {
@@ -20,14 +23,7 @@ namespace boost {
// VC7 strips const from nested classes unless we add indirection here // VC7 strips const from nested classes unless we add indirection here
# if BOOST_WORKAROUND(BOOST_MSVC, == 1300) # if BOOST_WORKAROUND(BOOST_MSVC, == 1300)
template <typename T> typename add_pointer<T>::type
template<class T> struct _addp
{
typedef T * type;
};
template <typename T> typename _addp<T>::type
# else # else
template <typename T> T* template <typename T> T*
# endif # endif
@@ -37,22 +33,6 @@ addressof(T& v)
&const_cast<char&>(reinterpret_cast<const volatile char &>(v))); &const_cast<char&>(reinterpret_cast<const volatile char &>(v)));
} }
// Borland doesn't like casting an array reference to a char reference
// but these overloads work around the problem.
# if 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
} }
#endif // BOOST_UTILITY_ADDRESSOF_HPP #endif // BOOST_UTILITY_ADDRESSOF_HPP

View File

@@ -1,5 +1,4 @@
// Copyright (C) 2003, Fernando Luis Cacciola Carballal. // Copyright (C) 2003, Fernando Luis Cacciola Carballal.
// Copyright (C) 2007, Tobias Schwinger.
// //
// Use, modification, and distribution is subject to the Boost Software // Use, modification, and distribution is subject to the Boost Software
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
@@ -10,27 +9,25 @@
// You are welcome to contact the author at: // You are welcome to contact the author at:
// fernando_cacciola@hotmail.com // fernando_cacciola@hotmail.com
// //
#ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_04APR2007_HPP #ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_25AGO2003_HPP
#define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_04APR2007_HPP #define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_25AGO2003_HPP
#include <new>
#include <cstddef>
#include <boost/config.hpp> #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.hpp>
#include <boost/preprocessor/repetition/enum_params.hpp> #include <boost/preprocessor/repetition/enum_params.hpp>
#include <boost/preprocessor/repetition/enum_binary_params.hpp> #include <boost/preprocessor/repetition/enum_binary_params.hpp>
#include <boost/preprocessor/repetition/enum_trailing_params.hpp> #include <boost/preprocessor/cat.hpp>
#include <boost/preprocessor/arithmetic/inc.hpp>
#include <boost/preprocessor/punctuation/paren.hpp>
#include <boost/preprocessor/facilities/empty.hpp>
#define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT(z,n,_) BOOST_PP_CAT(m_a,n) BOOST_PP_LPAREN() BOOST_PP_CAT(a,n) BOOST_PP_RPAREN() #define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT(z,n,_) BOOST_PP_CAT(m_a,n) BOOST_PP_LPAREN() BOOST_PP_CAT(a,n) BOOST_PP_RPAREN()
#define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL(z,n,_) BOOST_PP_CAT(A,n) const& BOOST_PP_CAT(m_a,n); #define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL(z,n,_) BOOST_PP_CAT(A,n) const& BOOST_PP_CAT(m_a,n);
#define BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_ARG(z,n,_) BOOST_PP_CAT(m_a,n)
#define BOOST_MAX_INPLACE_FACTORY_ARITY 10 #define BOOST_MAX_INPLACE_FACTORY_ARITY 10
#undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_04APR2007_HPP #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_25AGO2003_HPP
#endif #endif

View File

@@ -1,5 +1,4 @@
// Copyright (C) 2003, Fernando Luis Cacciola Carballal. // Copyright (C) 2003, Fernando Luis Cacciola Carballal.
// Copyright (C) 2007, Tobias Schwinger.
// //
// Use, modification, and distribution is subject to the Boost Software // Use, modification, and distribution is subject to the Boost Software
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
@@ -10,14 +9,15 @@
// You are welcome to contact the author at: // You are welcome to contact the author at:
// fernando_cacciola@hotmail.com // fernando_cacciola@hotmail.com
// //
#ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_04APR2007_HPP #ifndef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_25AGO2003_HPP
#define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_04APR2007_HPP #define BOOST_UTILITY_DETAIL_INPLACE_FACTORY_SUFFIX_25AGO2003_HPP
#undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT #undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT
#undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL #undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL
#undef BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_ARG
#undef BOOST_MAX_INPLACE_FACTORY_ARITY #undef BOOST_MAX_INPLACE_FACTORY_ARITY
#undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_04APR2007_HPP #undef BOOST_UTILITY_DETAIL_INPLACE_FACTORY_PREFIX_25AGO2003_HPP
#endif #endif

View File

@@ -21,69 +21,66 @@
template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
struct result_of<F(BOOST_RESULT_OF_ARGS)> struct result_of<F(BOOST_RESULT_OF_ARGS)>
: boost::detail::result_of_impl<F, F(BOOST_RESULT_OF_ARGS), (boost::detail::has_result_type<F>::value)> {}; : detail::result_of<F, F(BOOST_RESULT_OF_ARGS)> {};
#endif #endif
#undef BOOST_RESULT_OF_ARGS
#if BOOST_PP_ITERATION() >= 1
namespace detail { namespace detail {
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
struct result_of_impl<R (*)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false> struct result_of<R (*)(BOOST_RESULT_OF_ARGS), FArgs>
{ {
typedef R type; typedef R type;
}; };
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
struct result_of_impl<R (&)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false> struct result_of<R (&)(BOOST_RESULT_OF_ARGS), FArgs>
{ {
typedef R type; typedef R type;
}; };
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551)) #undef BOOST_RESULT_OF_ARGS
#if BOOST_PP_ITERATION() > 1 && !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551))
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
struct result_of_impl<R (T0::*) struct result_of<R (T0::*)
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)), (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)),
FArgs, false> FArgs>
{ {
typedef R type; typedef R type;
}; };
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
struct result_of_impl<R (T0::*) struct result_of<R (T0::*)
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T))
const, const,
FArgs, false> FArgs>
{ {
typedef R type; typedef R type;
}; };
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
struct result_of_impl<R (T0::*) struct result_of<R (T0::*)
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T))
volatile, volatile,
FArgs, false> FArgs>
{ {
typedef R type; typedef R type;
}; };
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION()) template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)> BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
struct result_of_impl<R (T0::*) struct result_of<R (T0::*)
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)) (BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T))
const volatile, const volatile,
FArgs, false> FArgs>
{ {
typedef R type; typedef R type;
}; };
#endif #endif
} }
#endif

View File

@@ -1,5 +1,4 @@
// Copyright (C) 2003, Fernando Luis Cacciola Carballal. // Copyright (C) 2003, Fernando Luis Cacciola Carballal.
// Copyright (C) 2007, Tobias Schwinger.
// //
// Use, modification, and distribution is subject to the Boost Software // Use, modification, and distribution is subject to the Boost Software
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
@@ -10,79 +9,50 @@
// You are welcome to contact the author at: // You are welcome to contact the author at:
// fernando_cacciola@hotmail.com // fernando_cacciola@hotmail.com
// //
#ifndef BOOST_UTILITY_INPLACE_FACTORY_04APR2007_HPP #ifndef BOOST_UTILITY_INPLACE_FACTORY_25AGO2003_HPP
#ifndef BOOST_PP_IS_ITERATING #define BOOST_UTILITY_INPLACE_FACTORY_25AGO2003_HPP
#include <boost/utility/detail/in_place_factory_prefix.hpp> #include <boost/utility/detail/in_place_factory_prefix.hpp>
#include <boost/type.hpp>
namespace boost { namespace boost {
class in_place_factory_base {} ; class in_place_factory_base {} ;
#define BOOST_PP_ITERATION_LIMITS (0, BOOST_MAX_INPLACE_FACTORY_ARITY) #define BOOST_DEFINE_INPLACE_FACTORY_CLASS(z,n,_) \
#define BOOST_PP_FILENAME_1 <boost/utility/in_place_factory.hpp> template< BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \
#include BOOST_PP_ITERATE() class BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) : public in_place_factory_base \
{ \
public: \
\
BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A,const& a) ) \
: \
BOOST_PP_ENUM( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT, _ ) \
{} \
\
template<class T> \
void apply ( void* address BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE(T) ) const \
{ \
new ( address ) T ( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), m_a ) ) ; \
} \
\
BOOST_PP_REPEAT( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL, _) \
} ; \
\
template< BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \
BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) < BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \
in_place ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A, const& a) ) \
{ \
return BOOST_PP_CAT(in_place_factory, BOOST_PP_INC(n) ) < BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \
( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), a ) ) ; \
} ; \
BOOST_PP_REPEAT( BOOST_MAX_INPLACE_FACTORY_ARITY, BOOST_DEFINE_INPLACE_FACTORY_CLASS, BOOST_PP_EMPTY() )
} // namespace boost } // namespace boost
#include <boost/utility/detail/in_place_factory_suffix.hpp> #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 #endif

View File

@@ -15,8 +15,6 @@
#include <boost/preprocessor.hpp> #include <boost/preprocessor.hpp>
#include <boost/detail/workaround.hpp> #include <boost/detail/workaround.hpp>
#include <boost/mpl/has_xxx.hpp> #include <boost/mpl/has_xxx.hpp>
#include <boost/mpl/if.hpp>
#include <boost/mpl/bool.hpp>
#ifndef BOOST_RESULT_OF_NUM_ARGS #ifndef BOOST_RESULT_OF_NUM_ARGS
# define BOOST_RESULT_OF_NUM_ARGS 10 # define BOOST_RESULT_OF_NUM_ARGS 10
@@ -31,58 +29,37 @@ namespace detail {
BOOST_MPL_HAS_XXX_TRAIT_DEF(result_type) BOOST_MPL_HAS_XXX_TRAIT_DEF(result_type)
template<typename F, typename FArgs, bool HasResultType> struct result_of_impl; template<typename F, typename FArgs, bool HasResultType> struct get_result_of;
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;
};
template<typename F, typename FArgs> template<typename F, typename FArgs>
struct result_of_impl<F, FArgs, true> struct get_result_of<F, FArgs, true>
{ {
typedef typename F::result_type type; typedef typename F::result_type type;
}; };
template<typename FArgs> template<typename F, typename FArgs>
struct is_function_with_no_args : mpl::false_ {}; struct get_result_of<F, FArgs, false>
{
typedef typename F::template result<FArgs>::type type;
};
template<typename F> template<typename F>
struct is_function_with_no_args<F(void)> : mpl::true_ {}; struct get_result_of<F, F(void), false>
{
typedef void type;
};
template<typename F, typename FArgs> template<typename F, typename FArgs>
struct result_of_nested_result : F::template result<FArgs> struct result_of : get_result_of<F, FArgs, (has_result_type<F>::value)> {};
{};
template<typename F, typename FArgs>
struct result_of_impl<F, FArgs, false>
: mpl::if_<is_function_with_no_args<FArgs>,
result_of_void_impl<F>,
result_of_nested_result<F, FArgs> >::type
{};
} // end namespace detail } // end namespace detail
#define BOOST_PP_ITERATION_PARAMS_1 (3,(0,BOOST_RESULT_OF_NUM_ARGS,<boost/utility/detail/result_of_iterate.hpp>)) #define BOOST_PP_ITERATION_PARAMS_1 (3,(0,BOOST_RESULT_OF_NUM_ARGS,<boost/utility/detail/result_of_iterate.hpp>))
#include BOOST_PP_ITERATE() #include BOOST_PP_ITERATE()
}
#else #else
# define BOOST_NO_RESULT_OF 1 # error Your compiler cannot support class template result_of
#endif #endif
}
#endif // BOOST_RESULT_OF_HPP #endif // BOOST_RESULT_OF_HPP

View File

@@ -1,5 +1,4 @@
// Copyright (C) 2003, Fernando Luis Cacciola Carballal. // Copyright (C) 2003, Fernando Luis Cacciola Carballal.
// Copyright (C) 2007, Tobias Schwinger.
// //
// Use, modification, and distribution is subject to the Boost Software // Use, modification, and distribution is subject to the Boost Software
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
@@ -10,8 +9,8 @@
// You are welcome to contact the author at: // You are welcome to contact the author at:
// fernando_cacciola@hotmail.com // fernando_cacciola@hotmail.com
// //
#ifndef BOOST_UTILITY_TYPED_INPLACE_FACTORY_04APR2007_HPP #ifndef BOOST_UTILITY_TYPED_INPLACE_FACTORY_25AGO2003_HPP
#ifndef BOOST_PP_IS_ITERATING #define BOOST_UTILITY_TYPED_INPLACE_FACTORY_25AGO2003_HPP
#include <boost/utility/detail/in_place_factory_prefix.hpp> #include <boost/utility/detail/in_place_factory_prefix.hpp>
@@ -19,59 +18,40 @@ namespace boost {
class typed_in_place_factory_base {} ; class typed_in_place_factory_base {} ;
#define BOOST_PP_ITERATION_LIMITS (0, BOOST_MAX_INPLACE_FACTORY_ARITY) #define BOOST_DEFINE_TYPED_INPLACE_FACTORY_CLASS(z,n,_) \
#define BOOST_PP_FILENAME_1 <boost/utility/typed_in_place_factory.hpp> template< class T, BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \
#include BOOST_PP_ITERATE() class BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) : public typed_in_place_factory_base \
{ \
public: \
\
typedef T value_type ; \
\
BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A,const& a) ) \
: \
BOOST_PP_ENUM( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_INIT, _ ) \
{} \
\
void apply ( void* address ) const \
{ \
new ( address ) T ( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), m_a ) ) ; \
} \
\
BOOST_PP_REPEAT( BOOST_PP_INC(n), BOOST_DEFINE_INPLACE_FACTORY_CLASS_MEMBER_DECL, _) \
} ; \
\
template< class T, BOOST_PP_ENUM_PARAMS(BOOST_PP_INC(n),class A) > \
BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) < T , BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \
in_place ( BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_INC(n),A, const& a) ) \
{ \
return BOOST_PP_CAT(typed_in_place_factory, BOOST_PP_INC(n) ) < T, BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), A ) > \
( BOOST_PP_ENUM_PARAMS( BOOST_PP_INC(n), a ) ) ; \
} ; \
BOOST_PP_REPEAT( BOOST_MAX_INPLACE_FACTORY_ARITY, BOOST_DEFINE_TYPED_INPLACE_FACTORY_CLASS, BOOST_PP_EMPTY() )
} // namespace boost } // namespace boost
#include <boost/utility/detail/in_place_factory_suffix.hpp> #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 #endif

View File

@@ -1,110 +1,16 @@
// (C) Copyright 2002-2007, Fernando Luis Cacciola Carballal. // (C) 2002, Fernando Luis Cacciola Carballal.
// //
// Distributed under the Boost Software License, Version 1.0. (See // Distributed under the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or copy at // accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt) // http://www.boost.org/LICENSE_1_0.txt)
// //
// 21 Ago 2002 (Created) Fernando Cacciola // 21 Ago 2002 (Created) Fernando Cacciola
// 07 Set 2007 (Worked around MSVC++ bug) Fernando Cacciola, Niels Dekker
// //
#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
#include <boost/detail/select_type.hpp> #include "boost/detail/select_type.hpp"
#include <boost/type_traits/cv_traits.hpp> #include "boost/type_traits/cv_traits.hpp"
#include <boost/detail/workaround.hpp>
#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1500) )
// Microsoft Visual C++ does not correctly support value initialization, as reported by
// Pavel Kuznetsov (MetaCommunications Engineering), 7/28/2005, Feedback ID 100744,
// Feedback Title: Value-initialization in new-expression
// https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=100744
// The report was closed at 11/14/2006, and its status was set to "Closed (Won't Fix)".
// Luckily, even in the presence of this compiler bug, boost::value_initialized will still
// do its job correctly, when using the following workaround:
#define BOOST_UTILITY_VALUE_INIT_WORKAROUND
#endif
#ifdef BOOST_UTILITY_VALUE_INIT_WORKAROUND
#include <boost/aligned_storage.hpp>
#include <boost/type_traits/alignment_of.hpp>
#include <cstring>
#include <new>
#ifdef BOOST_MSVC
#pragma warning(push)
#if _MSC_VER >= 1310
// When using MSVC 7.1 or higher, placement new, "new (&x) T()", may trigger warning C4345:
// "behavior change: an object of POD type constructed with an initializer of the form ()
// will be default-initialized". There is no need to worry about this, though.
#pragma warning(disable: 4345)
#endif
#endif
namespace boost {
namespace vinit_detail {
template<class T>
class const_T_base
{
protected :
const_T_base()
{
std::memset(&x, 0, sizeof(x));
new (&x) T();
}
~const_T_base()
{
void const * ptr = &x;
static_cast<T*>(ptr)->T::~T();
}
T & get() const
{
void const * ptr = &x;
return *static_cast<T*>(ptr);
}
private :
typename ::boost::aligned_storage<sizeof(T), ::boost::alignment_of<T>::value>::type x;
} ;
template<class T>
class non_const_T_base
{
protected :
non_const_T_base()
{
std::memset(&x, 0, sizeof(x));
new (&x) T();
}
~non_const_T_base()
{
void * ptr = &x;
static_cast<T*>(ptr)->T::~T();
}
T & get() const
{
void * ptr = &x;
return *static_cast<T*>(ptr);
}
private :
mutable typename ::boost::aligned_storage<sizeof(T), ::boost::alignment_of<T>::value>::type x;
} ;
#ifdef BOOST_MSVC
// Restores the state of warning C4345.
#pragma warning(pop)
#endif
#else
namespace boost { namespace boost {
@@ -116,34 +22,25 @@ class const_T_base
protected : protected :
const_T_base() : x() {} const_T_base() : x() {}
T & get() const { return x; }
private :
T x ; T x ;
} ; } ;
template<class T> template<class T>
class non_const_T_base struct non_const_T_base
{ {
protected : protected :
non_const_T_base() : x() {} non_const_T_base() : x() {}
T & get() const { return x; }
private :
mutable T x ; mutable T x ;
} ; } ;
#endif
template<class T> template<class T>
struct select_base struct select_base
{ {
typedef typedef typename
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) detail::if_true< ::boost::is_const<T>::value >
typename
#endif
::boost::detail::if_true< ::boost::is_const<T>::value >
::template then< const_T_base<T>, non_const_T_base<T> >::type type ; ::template then< const_T_base<T>, non_const_T_base<T> >::type type ;
} ; } ;
@@ -156,9 +53,9 @@ class value_initialized : private vinit_detail::select_base<T>::type
value_initialized() {} value_initialized() {}
operator T&() const { return this->get(); } operator T&() const { return this->x ; }
T& data() const { return this->get(); } T& data() const { return this->x ; }
} ; } ;

View File

@@ -19,7 +19,6 @@
<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="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="operators.htm">operators</a><br> <a href="operators.htm">operators</a><br>
@@ -28,13 +27,8 @@
<a href="value_init.htm">value_init</a></p> <a href="value_init.htm">value_init</a></p>
</blockquote> </blockquote>
<hr> <hr>
<p><EFBFBD> Copyright Beman Dawes, 2001</p>
<p>Distributed under the Boost Software License, Version 1.0. (See
accompanying file <a href="../../LICENSE_1_0.txt">
LICENSE_1_0.txt</a> or copy at
<a href="http://www.boost.org/LICENSE_1_0.txt">
www.boost.org/LICENSE_1_0.txt</a>)</p>
<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 -->01 September, 2003<!--webbot bot="Timestamp" endspan i-checksum="38582" --></p>
</body> <p>&nbsp;</p>
</body>
</html> </html>

View File

@@ -174,7 +174,7 @@ test_opr<T, R, P>::post_increment_test
oss << *i++ << ' '; oss << *i++ << ' ';
} }
BOOST_CHECK( oss.str() == "apple orange pear peach grape plum "); BOOST_TEST( oss.str() == "apple orange pear peach grape plum ");
} }
// Test post-decrement // Test post-decrement
@@ -193,7 +193,7 @@ test_opr<T, R, P>::post_decrement_test
oss << *i << ' '; oss << *i << ' ';
} }
BOOST_CHECK( oss.str() == "plum grape peach pear orange apple "); BOOST_TEST( oss.str() == "plum grape peach pear orange apple ");
} }
// Test indirect structure referral // Test indirect structure referral
@@ -211,7 +211,7 @@ test_opr<T, R, P>::indirect_referral_test
oss << i->size() << ' '; oss << i->size() << ' ';
} }
BOOST_CHECK( oss.str() == "5 6 4 5 5 4 "); BOOST_TEST( oss.str() == "5 6 4 5 5 4 ");
} }
// Test offset addition // Test offset addition
@@ -230,7 +230,7 @@ test_opr<T, R, P>::offset_addition_test
oss << *i << ' '; oss << *i << ' ';
} }
BOOST_CHECK( oss.str() == "apple pear grape "); BOOST_TEST( oss.str() == "apple pear grape ");
} }
// Test offset addition, in reverse order // Test offset addition, in reverse order
@@ -249,7 +249,7 @@ test_opr<T, R, P>::reverse_offset_addition_test
oss << *i << ' '; oss << *i << ' ';
} }
BOOST_CHECK( oss.str() == "apple pear grape "); BOOST_TEST( oss.str() == "apple pear grape ");
} }
// Test offset subtraction // Test offset subtraction
@@ -272,7 +272,7 @@ test_opr<T, R, P>::offset_subtraction_test
} }
} }
BOOST_CHECK( oss.str() == "grape pear apple "); BOOST_TEST( oss.str() == "grape pear apple ");
} }
// Test comparisons // Test comparisons
@@ -296,10 +296,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;
@@ -320,5 +320,5 @@ test_opr<T, R, P>::indexing_test
oss << fruit_begin[ k ] << ' '; oss << fruit_begin[ k ] << ' ';
} }
BOOST_CHECK( oss.str() == "apple orange pear peach grape plum "); BOOST_TEST( oss.str() == "apple orange pear peach grape plum ");
} }

View File

@@ -57,22 +57,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)); BOOST_STATIC_CONSTANT(Number, min = Number(Number(prev::min) << CHAR_BIT));
#endif
}; };
}; };
@@ -229,16 +221,10 @@ void test_aux(unsigned_tag, Number*)
(sizeof(Number) < sizeof(boost::intmax_t)) (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;
@@ -322,15 +308,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;

View File

@@ -269,17 +269,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( (x1 < y1) == (x2 < y2) ); BOOST_TEST( (x1 < y1) == (x2 < y2) );
BOOST_CHECK( (x1 <= y1) == (x2 <= y2) ); BOOST_TEST( (x1 <= y1) == (x2 <= y2) );
BOOST_CHECK( (x1 >= y1) == (x2 >= y2) ); BOOST_TEST( (x1 >= y1) == (x2 >= y2) );
BOOST_CHECK( (x1 > y1) == (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>
@@ -293,8 +293,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( (x1 == y1) == (x2 == y2) ); BOOST_TEST( (x1 == y1) == (x2 == y2) );
BOOST_CHECK( (x1 != y1) == (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>
@@ -308,7 +308,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>
@@ -322,7 +322,7 @@ namespace
template <class A, class B> template <class A, class B>
void test_value_equality(A a, B b) void test_value_equality(A a, B b)
{ {
BOOST_CHECK(a.value() == b); BOOST_TEST(a.value() == b);
} }
#define TEST_OP_R(op) test_value_equality(x1 op y1, x2 op y2) #define TEST_OP_R(op) test_value_equality(x1 op y1, x2 op y2)
@@ -448,16 +448,16 @@ namespace
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>
@@ -536,7 +536,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>;
@@ -561,7 +561,7 @@ 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 * [] )
@@ -606,22 +606,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( i2 == i ); BOOST_TEST( i2 == i );
BOOST_CHECK( i1 != i2 ); BOOST_TEST( i1 != i2 );
BOOST_CHECK( i1 < i2 ); BOOST_TEST( i1 < i2 );
BOOST_CHECK( i1 <= i2 ); BOOST_TEST( i1 <= i2 );
BOOST_CHECK( i <= i2 ); BOOST_TEST( i <= i2 );
BOOST_CHECK( i2 > i1 ); BOOST_TEST( i2 > i1 );
BOOST_CHECK( i2 >= i1 ); BOOST_TEST( i2 >= i1 );
BOOST_CHECK( 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) );
@@ -645,86 +645,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( j2 == j ); BOOST_TEST( j2 == j );
BOOST_CHECK( 2 == j ); BOOST_TEST( 2 == j );
BOOST_CHECK( j2 == 2 ); BOOST_TEST( j2 == 2 );
BOOST_CHECK( j == j2 ); BOOST_TEST( j == j2 );
BOOST_CHECK( j1 != j2 ); BOOST_TEST( j1 != j2 );
BOOST_CHECK( j1 != 2 ); BOOST_TEST( j1 != 2 );
BOOST_CHECK( 1 != j2 ); BOOST_TEST( 1 != j2 );
BOOST_CHECK( j1 < j2 ); BOOST_TEST( j1 < j2 );
BOOST_CHECK( 1 < j2 ); BOOST_TEST( 1 < j2 );
BOOST_CHECK( j1 < 2 ); BOOST_TEST( j1 < 2 );
BOOST_CHECK( j1 <= j2 ); BOOST_TEST( j1 <= j2 );
BOOST_CHECK( 1 <= j2 ); BOOST_TEST( 1 <= j2 );
BOOST_CHECK( j1 <= j ); BOOST_TEST( j1 <= j );
BOOST_CHECK( j <= j2 ); BOOST_TEST( j <= j2 );
BOOST_CHECK( 2 <= j2 ); BOOST_TEST( 2 <= j2 );
BOOST_CHECK( j <= 2 ); BOOST_TEST( j <= 2 );
BOOST_CHECK( j2 > j1 ); BOOST_TEST( j2 > j1 );
BOOST_CHECK( 2 > j1 ); BOOST_TEST( 2 > j1 );
BOOST_CHECK( j2 > 1 ); BOOST_TEST( j2 > 1 );
BOOST_CHECK( j2 >= j1 ); BOOST_TEST( j2 >= j1 );
BOOST_CHECK( 2 >= j1 ); BOOST_TEST( 2 >= j1 );
BOOST_CHECK( j2 >= 1 ); BOOST_TEST( j2 >= 1 );
BOOST_CHECK( j2 >= j ); BOOST_TEST( j2 >= j );
BOOST_CHECK( 2 >= j ); BOOST_TEST( 2 >= j );
BOOST_CHECK( j2 >= 2 ); BOOST_TEST( j2 >= 2 );
BOOST_CHECK( (j1 + 2) == 3 ); BOOST_TEST( (j1 + 2) == 3 );
BOOST_CHECK( (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( (j + 2) == 5 ); BOOST_TEST( (j + 2) == 5 );
BOOST_CHECK( (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( (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( (j * 2) == 8 ); BOOST_TEST( (j * 2) == 8 );
BOOST_CHECK( (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( (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( (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( (1 | j2 | j) == 7 ); BOOST_TEST( (1 | j2 | j) == 7 );
BOOST_CHECK( (j1 | 2 | j) == 7 ); BOOST_TEST( (j1 | 2 | j) == 7 );
BOOST_CHECK( (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( (7 & j2) == 2 ); BOOST_TEST( (7 & j2) == 2 );
BOOST_CHECK( (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( (3 ^ j1) == 2 ); BOOST_TEST( (3 ^ j1) == 2 );
BOOST_CHECK( (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( (j1 << 2) == 4 ); BOOST_TEST( (j1 << 2) == 4 );
BOOST_CHECK( (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( (j >> 2) == 1 ); BOOST_TEST( (j >> 2) == 1 );
BOOST_CHECK( (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";
@@ -733,22 +733,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( k2 == k ); BOOST_TEST( k2 == k );
BOOST_CHECK( k1 != k2 ); BOOST_TEST( k1 != k2 );
BOOST_CHECK( k1 < k2 ); BOOST_TEST( k1 < k2 );
BOOST_CHECK( k1 <= k2 ); BOOST_TEST( k1 <= k2 );
BOOST_CHECK( k <= k2 ); BOOST_TEST( k <= k2 );
BOOST_CHECK( k2 > k1 ); BOOST_TEST( k2 > k1 );
BOOST_CHECK( k2 >= k1 ); BOOST_TEST( k2 >= k1 );
BOOST_CHECK( k2 >= k ); BOOST_TEST( k2 >= k );
cout << "Performed tests on MyChar objects.\n"; cout << "Performed tests on MyChar objects.\n";
@@ -756,39 +756,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( l2 == l ); BOOST_TEST( l2 == l );
BOOST_CHECK( 2 == l ); BOOST_TEST( 2 == l );
BOOST_CHECK( l2 == 2 ); BOOST_TEST( l2 == 2 );
BOOST_CHECK( l == l2 ); BOOST_TEST( l == l2 );
BOOST_CHECK( l1 != l2 ); BOOST_TEST( l1 != l2 );
BOOST_CHECK( l1 != 2 ); BOOST_TEST( l1 != 2 );
BOOST_CHECK( 1 != l2 ); BOOST_TEST( 1 != l2 );
BOOST_CHECK( l1 < l2 ); BOOST_TEST( l1 < l2 );
BOOST_CHECK( 1 < l2 ); BOOST_TEST( 1 < l2 );
BOOST_CHECK( l1 < 2 ); BOOST_TEST( l1 < 2 );
BOOST_CHECK( l1 <= l2 ); BOOST_TEST( l1 <= l2 );
BOOST_CHECK( 1 <= l2 ); BOOST_TEST( 1 <= l2 );
BOOST_CHECK( l1 <= l ); BOOST_TEST( l1 <= l );
BOOST_CHECK( l <= l2 ); BOOST_TEST( l <= l2 );
BOOST_CHECK( 2 <= l2 ); BOOST_TEST( 2 <= l2 );
BOOST_CHECK( l <= 2 ); BOOST_TEST( l <= 2 );
BOOST_CHECK( l2 > l1 ); BOOST_TEST( l2 > l1 );
BOOST_CHECK( 2 > l1 ); BOOST_TEST( 2 > l1 );
BOOST_CHECK( l2 > 1 ); BOOST_TEST( l2 > 1 );
BOOST_CHECK( l2 >= l1 ); BOOST_TEST( l2 >= l1 );
BOOST_CHECK( 2 >= l1 ); BOOST_TEST( 2 >= l1 );
BOOST_CHECK( l2 >= 1 ); BOOST_TEST( l2 >= 1 );
BOOST_CHECK( l2 >= l ); BOOST_TEST( l2 >= l );
BOOST_CHECK( 2 >= l ); BOOST_TEST( 2 >= l );
BOOST_CHECK( l2 >= 2 ); BOOST_TEST( l2 >= 2 );
cout << "Performed tests on MyShort objects.\n"; cout << "Performed tests on MyShort objects.\n";
@@ -798,44 +798,44 @@ 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( di2 == di ); BOOST_TEST( di2 == di );
BOOST_CHECK( 2 == di ); BOOST_TEST( 2 == di );
BOOST_CHECK( di == 2 ); BOOST_TEST( di == 2 );
BOOST_CHECK( di1 < di2 ); BOOST_TEST( di1 < di2 );
BOOST_CHECK( 1 < di2 ); BOOST_TEST( 1 < di2 );
BOOST_CHECK( di1 <= di2 ); BOOST_TEST( di1 <= di2 );
BOOST_CHECK( 1 <= di2 ); BOOST_TEST( 1 <= di2 );
BOOST_CHECK( di2 > di1 ); BOOST_TEST( di2 > di1 );
BOOST_CHECK( di2 > 1 ); BOOST_TEST( di2 > 1 );
BOOST_CHECK( di2 >= di1 ); BOOST_TEST( di2 >= di1 );
BOOST_CHECK( di2 >= 1 ); BOOST_TEST( di2 >= 1 );
BOOST_CHECK( di1 / di2 == half ); BOOST_TEST( di1 / di2 == half );
BOOST_CHECK( di1 / 2 == half ); BOOST_TEST( di1 / 2 == half );
BOOST_CHECK( 1 / di2 == half ); BOOST_TEST( 1 / di2 == half );
PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=2) == half) ); PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=2) == half) );
PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=di2) == half) ); PRIVATE_EXPR_TEST( (tmp=di1), ((tmp/=di2) == half) );
BOOST_CHECK( di1 * di2 == di2 ); BOOST_TEST( di1 * di2 == di2 );
BOOST_CHECK( di1 * 2 == di2 ); BOOST_TEST( di1 * 2 == di2 );
BOOST_CHECK( 1 * di2 == di2 ); BOOST_TEST( 1 * di2 == di2 );
PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=2) == di2) ); PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=2) == di2) );
PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=di2) == di2) ); PRIVATE_EXPR_TEST( (tmp=di1), ((tmp*=di2) == di2) );
BOOST_CHECK( di2 - di1 == di1 ); BOOST_TEST( di2 - di1 == di1 );
BOOST_CHECK( di2 - 1 == di1 ); BOOST_TEST( di2 - 1 == di1 );
BOOST_CHECK( 2 - di1 == di1 ); BOOST_TEST( 2 - di1 == di1 );
PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=1) == di1) ); PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=1) == di1) );
PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=di1) == di1) ); PRIVATE_EXPR_TEST( (tmp=di2), ((tmp-=di1) == di1) );
BOOST_CHECK( di1 + di1 == di2 ); BOOST_TEST( di1 + di1 == di2 );
BOOST_CHECK( di1 + 1 == di2 ); BOOST_TEST( di1 + 1 == di2 );
BOOST_CHECK( 1 + di1 == di2 ); BOOST_TEST( 1 + di1 == di2 );
PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=1) == di2) ); PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=1) == di2) );
PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=di1) == di2) ); PRIVATE_EXPR_TEST( (tmp=di1), ((tmp+=di1) == di2) );
@@ -846,48 +846,48 @@ 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( li2 == li ); BOOST_TEST( li2 == li );
BOOST_CHECK( 2 == li ); BOOST_TEST( 2 == li );
BOOST_CHECK( li == 2 ); BOOST_TEST( li == 2 );
BOOST_CHECK( li1 < li2 ); BOOST_TEST( li1 < li2 );
BOOST_CHECK( 1 < li2 ); BOOST_TEST( 1 < li2 );
BOOST_CHECK( li1 <= li2 ); BOOST_TEST( li1 <= li2 );
BOOST_CHECK( 1 <= li2 ); BOOST_TEST( 1 <= li2 );
BOOST_CHECK( li2 > li1 ); BOOST_TEST( li2 > li1 );
BOOST_CHECK( li2 > 1 ); BOOST_TEST( li2 > 1 );
BOOST_CHECK( li2 >= li1 ); BOOST_TEST( li2 >= li1 );
BOOST_CHECK( li2 >= 1 ); BOOST_TEST( li2 >= 1 );
BOOST_CHECK( li1 % li2 == li1 ); BOOST_TEST( li1 % li2 == li1 );
BOOST_CHECK( li1 % 2 == li1 ); BOOST_TEST( li1 % 2 == li1 );
BOOST_CHECK( 1 % li2 == li1 ); BOOST_TEST( 1 % li2 == li1 );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=2) == li1) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=2) == li1) );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=li2) == li1) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2%=li2) == li1) );
BOOST_CHECK( li1 / li2 == 0 ); BOOST_TEST( li1 / li2 == 0 );
BOOST_CHECK( li1 / 2 == 0 ); BOOST_TEST( li1 / 2 == 0 );
BOOST_CHECK( 1 / li2 == 0 ); BOOST_TEST( 1 / li2 == 0 );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=2) == 0) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=2) == 0) );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=li2) == 0) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2/=li2) == 0) );
BOOST_CHECK( li1 * li2 == li2 ); BOOST_TEST( li1 * li2 == li2 );
BOOST_CHECK( li1 * 2 == li2 ); BOOST_TEST( li1 * 2 == li2 );
BOOST_CHECK( 1 * li2 == li2 ); BOOST_TEST( 1 * li2 == li2 );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=2) == li2) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=2) == li2) );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=li2) == li2) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2*=li2) == li2) );
BOOST_CHECK( li2 - li1 == li1 ); BOOST_TEST( li2 - li1 == li1 );
BOOST_CHECK( li2 - 1 == li1 ); BOOST_TEST( li2 - 1 == li1 );
BOOST_CHECK( 2 - li1 == li1 ); BOOST_TEST( 2 - li1 == li1 );
PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=1) == li1) ); PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=1) == li1) );
PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=li1) == li1) ); PRIVATE_EXPR_TEST( (tmp2=li2), ((tmp2-=li1) == li1) );
BOOST_CHECK( li1 + li1 == li2 ); BOOST_TEST( li1 + li1 == li2 );
BOOST_CHECK( li1 + 1 == li2 ); BOOST_TEST( li1 + 1 == li2 );
BOOST_CHECK( 1 + li1 == li2 ); BOOST_TEST( 1 + li1 == li2 );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=1) == li2) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=1) == li2) );
PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=li1) == li2) ); PRIVATE_EXPR_TEST( (tmp2=li1), ((tmp2+=li1) == li2) );

View File

@@ -60,11 +60,11 @@ 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);
} }
}; };

View File

@@ -1 +0,0 @@
The existance of this file tells the regression reporting programs that the directory contains sub-directories which are libraries.

43
test/Jamfile Executable file
View File

@@ -0,0 +1,43 @@
# Copyright David Abrahams 2003. Permission to copy, use,
# modify, sell and distribute this software is granted provided this
# copyright notice appears in all copies. This software is provided
# "as is" without express or implied warranty, and with no claim as
# to its suitability for any purpose.
# For more information, see http://www.boost.org/
subproject libs/utility/test ;
# bring in rules for testing
import testing ;
# Make tests run by default.
DEPENDS all : test ;
local test_monitor = <lib>@boost/libs/test/build/boost_test_exec_monitor ;
# Please keep the tests ordered by filename
test-suite utility
:
[ run ../addressof_test.cpp $(test_monitor) ]
[ run ../assert_test.cpp ]
[ run ../base_from_member_test.cpp ]
[ run ../binary_search_test.cpp ]
[ run ../call_traits_test.cpp : -u ]
[ compile-fail ../checked_delete_test.cpp ]
[ run ../compressed_pair_test.cpp $(test_monitor) : -u ]
[ run ../current_function_test.cpp : : : <test-info>always_show_run_output ]
[ run ../iterators_test.cpp $(test_monitor) ]
[ run next_prior_test.cpp $(test_monitor) ]
[ compile-fail ../noncopyable_test.cpp ]
[ run ../numeric_traits_test.cpp ]
[ run ../operators_test.cpp $(test_monitor) ]
[ compile ../ref_ct_test.cpp ]
[ run ../ref_test.cpp $(test_monitor) ]
[ compile result_of_test.cpp ]
[ run ../shared_iterator_test.cpp ]
[ run ../value_init_test.cpp ]
[ compile-fail ../value_init_test_fail1.cpp ]
[ compile-fail ../value_init_test_fail2.cpp ]
[ compile-fail ../value_init_test_fail3.cpp ]
;

View File

@@ -1,7 +1,8 @@
# Copyright David Abrahams 2003. # Copyright David Abrahams 2003. Permission to copy, use,
# modify, sell and distribute this software is granted provided this
# Distributed under the Boost Software License, Version 1.0. # copyright notice appears in all copies. This software is provided
# See 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.
# For more information, see http://www.boost.org/ # For more information, see http://www.boost.org/
@@ -11,27 +12,25 @@ import testing ;
# Please keep the tests ordered by filename # Please keep the tests ordered by filename
test-suite utility test-suite utility
: :
[ run ../addressof_test.cpp ] [ run ../addressof_test.cpp ../../test/build//boost_test_exec_monitor ]
[ run ../assert_test.cpp ] [ run ../assert_test.cpp ]
[ run ../base_from_member_test.cpp ] [ run ../base_from_member_test.cpp ]
[ run ../binary_search_test.cpp ] [ run ../binary_search_test.cpp ]
[ run ../call_traits_test.cpp : -u ] [ run ../call_traits_test.cpp : -u ]
[ compile-fail ../checked_delete_test.cpp ] [ compile-fail ../checked_delete_test.cpp ]
[ run ../compressed_pair_test.cpp ../../test/build//boost_test_exec_monitor/<link>static : -u ] [ run ../compressed_pair_test.cpp ../../test/build//boost_test_exec_monitor : -u ]
[ run ../current_function_test.cpp : : : <test-info>always_show_run_output ] [ run ../current_function_test.cpp : : : <test-info>always_show_run_output ]
[ run ../iterators_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] [ run ../iterators_test.cpp ../../test/build//boost_test_exec_monitor ]
[ run next_prior_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] [ run next_prior_test.cpp ../../test/build//boost_test_exec_monitor ]
[ compile-fail ../noncopyable_test.cpp ] [ compile-fail ../noncopyable_test.cpp ]
[ run ../numeric_traits_test.cpp ] [ run ../numeric_traits_test.cpp ]
[ run ../operators_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] [ run ../operators_test.cpp ../../test/build//boost_test_exec_monitor ]
[ compile ../ref_ct_test.cpp ] [ compile ../ref_ct_test.cpp ]
[ run ../ref_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] [ run ../ref_test.cpp ../../test/build//boost_test_exec_monitor ]
[ compile result_of_test.cpp ] [ compile result_of_test.cpp ]
[ run ../shared_iterator_test.cpp ] [ run ../shared_iterator_test.cpp ]
[ run ../value_init_test.cpp ] [ run ../value_init_test.cpp ]
[ compile-fail ../value_init_test_fail1.cpp ] [ compile-fail ../value_init_test_fail1.cpp ]
[ compile-fail ../value_init_test_fail2.cpp ] [ compile-fail ../value_init_test_fail2.cpp ]
[ compile-fail ../value_init_test_fail3.cpp ] [ compile-fail ../value_init_test_fail3.cpp ]
[ run ../verify_test.cpp ]
; ;

View File

@@ -24,24 +24,6 @@ struct int_result_type_and_float_result_of
template<typename F> struct result { typedef float type; }; template<typename F> struct result { typedef float type; };
}; };
template<typename T>
struct int_result_type_template { typedef int result_type; };
template<typename T>
struct int_result_of_template
{
template<typename F> struct result;
template<typename This, typename That> struct result<This(That)> { typedef int type; };
};
template<typename T>
struct int_result_type_and_float_result_of_template
{
typedef int result_type;
template<typename F> struct result;
template<typename This, typename That> struct result<This(That)> { typedef float type; };
};
struct X {}; struct X {};
int main() int main()
@@ -50,13 +32,10 @@ int main()
typedef int (*func_ptr)(float, double); typedef int (*func_ptr)(float, double);
typedef int (&func_ref)(float, double); typedef int (&func_ref)(float, double);
typedef int (*func_ptr_0)();
typedef int (&func_ref_0)();
typedef int (X::*mem_func_ptr)(float); typedef int (X::*mem_func_ptr)(float);
typedef int (X::*mem_func_ptr_c)(float) const; typedef int (X::*mem_func_ptr_c)(float) const;
typedef int (X::*mem_func_ptr_v)(float) volatile; typedef int (X::*mem_func_ptr_v)(float) volatile;
typedef int (X::*mem_func_ptr_cv)(float) const volatile; typedef int (X::*mem_func_ptr_cv)(float) const volatile;
typedef int (X::*mem_func_ptr_0)();
BOOST_STATIC_ASSERT((is_same<result_of<int_result_type(float)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<int_result_type(float)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<int_result_of(double)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<int_result_of(double)>::type, int>::value));
@@ -64,22 +43,11 @@ int main()
BOOST_STATIC_ASSERT((is_same<result_of<const int_result_of(double)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<const int_result_of(double)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<volatile int_result_of(void)>::type, void>::value)); BOOST_STATIC_ASSERT((is_same<result_of<volatile int_result_of(void)>::type, void>::value));
BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of(char)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of(char)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_template<void>(float)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<int_result_of_template<void>(double)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<int_result_of_template<void>(void)>::type, void>::value));
BOOST_STATIC_ASSERT((is_same<result_of<const int_result_of_template<void>(double)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<volatile int_result_of_template<void>(void)>::type, void>::value));
BOOST_STATIC_ASSERT((is_same<result_of<int_result_type_and_float_result_of_template<void>(char)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<func_ptr(char, float)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<func_ptr(char, float)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<func_ref(char, float)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<func_ref(char, float)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<func_ptr_0()>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<func_ref_0()>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr(X,char)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr(X,char)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_c(X,char)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_c(X,char)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_v(X,char)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_v(X,char)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_cv(X,char)>::type, int>::value)); BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_cv(X,char)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<mem_func_ptr_0(X)>::type, int>::value));
BOOST_STATIC_ASSERT((is_same<result_of<func_ptr(void)>::type, int>::value));
return 0; return 0;
} }

View File

@@ -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="../../boost.png" alt="boost.png (6897 bytes)" width="277" height="86">
</td> </td>
<td align="center"> <td align="middle">
<h1>throw_exception.hpp</h1> <h1>throw_exception.hpp</h1>
</td> </td>
</tr> </tr>
@@ -51,8 +52,9 @@ template&lt;class E&gt; void throw_exception(E const &amp; e)
} }
</pre> </pre>
<p><br> <p><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>

View File

@@ -23,7 +23,6 @@
<li> <li>
Function template <a href="#addressof">addressof()</a></li> Function template <a href="#addressof">addressof()</a></li>
<li>Class template <a href="#result_of">result_of</a></li> <li>Class template <a href="#result_of">result_of</a></li>
<li><a href="index.html">Other utilities not part of <code>utility.hpp</code></a></li>
</ul> </ul>
<h2> <h2>
Function templates <a name="checked_delete">checked_delete</a>() and Function templates <a name="checked_delete">checked_delete</a>() and
@@ -163,9 +162,9 @@ void f() {
<code><em>N</em> &gt; 0</code> or <code>void</code> <code><em>N</em> &gt; 0</code> or <code>void</code>
when <code><em>N</em> = 0</code>. For additional when <code><em>N</em> = 0</code>. For additional
information about <code>result_of</code>, see the information about <code>result_of</code>, see the
C++ Library Technical Report, <a current draft of the C++ Library TR, <a
href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2005/n1836.pdf">N1836</a>, href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2004/n1647.pdf">N1647</a>,
or, for motivation and design rationale, the <code>result_of</code> <a or the <code>result_of</code> <a
href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1454.html">proposal</a>.</p> href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1454.html">proposal</a>.</p>
<p>Class template <code>result_of</code> resides in <p>Class template <code>result_of</code> resides in
@@ -176,19 +175,18 @@ void f() {
<code>BOOST_RESULT_OF_NUM_ARGS</code> to the maximum <code>BOOST_RESULT_OF_NUM_ARGS</code> to the maximum
value for <em>N</em>.</p> value for <em>N</em>.</p>
<a name="BOOST_NO_RESULT_OF"></a> <p>This implementation of <code>result_of</code> requires class template partial specialization, the ability to parse function types properly, and support for SFINAE. Contributed by Doug Gregor.</p>
<p>This implementation of <code>result_of</code> requires class template partial specialization, the ability to parse function types properly, and support for SFINAE. If <code>result_of</code> is not supported by your compiler, including the header <code>boost/utility/result_of.hpp</code> will define the macro <code>BOOST_NO_RESULT_OF</code>. Contributed by Doug Gregor.</p>
<h2>Class templates for the Base-from-Member Idiom</h2> <h2>Class templates for the Base-from-Member Idiom</h2>
<p>See <a href="base_from_member.html">separate documentation</a>.</p> <p>See <a href="base_from_member.html">separate documentation</a>.</p>
<hr> <hr>
<p>Revised&nbsp; <!--webbot bot="Timestamp" S-Type="EDITED" S-Format="%d %B, %Y" startspan <p>Revised&nbsp; <!--webbot bot="Timestamp" S-Type="EDITED" S-Format="%d %B, %Y" startspan
-->07 November, 2007<!--webbot bot="Timestamp" endspan i-checksum="39369" -->02 May, 2004<!--webbot bot="Timestamp" endspan i-checksum="38582"
--> -->
</p> </p>
<p>&copy; Copyright Beman Dawes 1999-2003.</p> <p>&copy; Copyright boost.org 1999-2003. Permission to copy, use, modify, sell and distribute
<p>Distributed under the Boost Software License, Version 1.0. See this document is granted provided this copyright notice appears in all copies.
<a href="http://www.boost.org/LICENSE_1_0.txt">www.boost.org/LICENSE_1_0.txt</a></p> This document is provided &quot;as is&quot; without express or implied
warranty, and with no claim as to its suitability for any purpose.</p>
</body> </body>
</html> </html>

View File

@@ -15,8 +15,8 @@
<h2>Contents</h2> <h2>Contents</h2>
<dl> <dl>
<dt><a href="#rationale">Rationale</a></dt> <dt><a href="#intro">Rationale</a></dt>
<dt><a href="#intro">Introduction</a></dt> <dt><a href="#rationale">Introduction</a></dt>
</dl> </dl>
<ul> <ul>
@@ -49,7 +49,7 @@ a solution with consistent syntax for value initialization of scalar,
union and class types. <br> union and class types. <br>
</p> </p>
<h2><a name="intro"></a>Introduction</h2> <h2><a name="into"></a>Introduction</h2>
<p>The C++ standard [<a href="#references">1</a>] contains the definitions <p>The C++ standard [<a href="#references">1</a>] contains the definitions
of <code>zero-initialization</code> and <code>default-initialization</code>. of <code>zero-initialization</code> and <code>default-initialization</code>.
@@ -131,7 +131,7 @@ data member:</p>
<h2><a name="val_init"><code>template class value_initialized&lt;T&gt;</code></a></h2> <h2><a name="val_init"><code>template class value_initialized&lt;T&gt;</code></a></h2>
<pre>namespace boost {<br><br>template&lt;class T&gt;<br>class value_initialized<br>{<br> public :<br> value_initialized() : x() {}<br> operator T&amp;() const { return x ; }<br> T&amp; data() const { return x ; }<br><br> private :<br> <i>unspecified</i> x ;<br>} ;<br><br>template&lt;class T&gt;<br>T const&amp; get ( value_initialized&lt;T&gt; const&amp; x )<br>{<br> return x.data() ;<br>}<br><br>template&lt;class T&gt;<br>T&amp; get ( value_initialized&lt;T&gt;&amp; x )<br>{<br> return x.data() ;<br>}<br><br>} // namespace boost<br></pre> <pre>namespace boost {<br><br>template&lt;class T&gt;<br>class value_initialized<br>{<br> public :<br> value_initialized() : x() {}<br> operator T&amp;() const { return x ; }<br> T&amp; data() const { return x ; }<br><br> private :<br> <i>impll-defined</i> x ;<br>} ;<br><br>template&lt;class T&gt;<br>T const&amp; get ( value_initialized&lt;T&gt; const&amp; x )<br>{<br> return x.data() ;<br>}<br><br>template&lt;class T&gt;<br>T&amp; get ( value_initialized&lt;T&gt;&amp; x )<br>{<br> return x.data() ;<br>}<br><br>} // namespace boost<br></pre>
<p>An object of this template class is a <code>T</code>-wrapper convertible <p>An object of this template class is a <code>T</code>-wrapper convertible
to <code>'T&amp;'</code> whose wrapped object (data member of type <code>T</code>) to <code>'T&amp;'</code> whose wrapped object (data member of type <code>T</code>)
@@ -197,23 +197,23 @@ the wrapped object is always performed with the <code>get()</code> idiom:</p>
value_initialized was developed by Fernando Cacciola, with help and value_initialized was developed by Fernando Cacciola, with help and
suggestions from David Abrahams and Darin Adler.<br> suggestions from David Abrahams and Darin Adler.<br>
Special thanks to Bj<42>rn Karlsson who carefully edited and completed this documentation. Special thanks to Bj<42>rn Karlsson who carefully edited and completed this documentation.
<pre>&nbsp;</pre>
<hr>
<p>Revised 19 September 2002</p>
<p>&copy; Copyright boost.org 2002. Permission to copy, use, modify, sell
and distribute this document is granted provided this copyright notice appears
in all copies. This document is provided "as is" without express or implied
warranty, and with no claim as to its suitability for any purpose.</p>
<p>Developed by <a href="mailto:fernando_cacciola@hotmail.com">Fernando Cacciola</a>, <p>Developed by <a href="mailto:fernando_cacciola@hotmail.com">Fernando Cacciola</a>,
the latest version of this file can be found at <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 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>. at <a href="http://www.yahoogroups.com/list/boost">www.yahoogroups.com/list/boost</a>.
</p> </p>
<hr>
<p>Revised 19 September 2002</p>
<p>&copy; Copyright Fernando Cacciola, 2002.</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>
<br> <br>
<br> <br>
</body> </body>
</html> </html>

View File

@@ -1,4 +1,4 @@
// Copyright 2002, Fernando Luis Cacciola Carballal. // (C) 2002, Fernando Luis Cacciola Carballal.
// //
// Distributed under the Boost Software License, Version 1.0. (See // Distributed under the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or copy at // accompanying file LICENSE_1_0.txt or copy at
@@ -60,45 +60,31 @@ struct NonPOD : NonPODBase
std::string id ; std::string id ;
} ; } ;
//
// Sample aggregate POD struct type
//
struct AggregatePODStruct
{
float f;
char c;
int i;
};
bool operator == ( AggregatePODStruct const& lhs, AggregatePODStruct const& rhs )
{ return lhs.f == rhs.f && lhs.c == rhs.c && lhs.i == rhs.i ; }
template<class T> template<class T>
void test ( T const& y, T const& z ) void test ( T const& y, T const& z )
{ {
boost::value_initialized<T> x ; boost::value_initialized<T> x ;
BOOST_CHECK ( y == x ) ; BOOST_TEST ( y == x ) ;
BOOST_CHECK ( y == boost::get(x) ) ; BOOST_TEST ( y == boost::get(x) ) ;
static_cast<T&>(x) = z ; static_cast<T&>(x) = z ;
boost::get(x) = z ; boost::get(x) = z ;
BOOST_CHECK ( x == z ) ; BOOST_TEST ( x == z ) ;
boost::value_initialized<T> const x_c ; boost::value_initialized<T> const x_c ;
BOOST_CHECK ( y == x_c ) ; BOOST_TEST ( y == x_c ) ;
BOOST_CHECK ( y == boost::get(x_c) ) ; BOOST_TEST ( y == boost::get(x_c) ) ;
T& x_c_ref = x_c ; T& x_c_ref = x_c ;
x_c_ref = z ; x_c_ref = z ;
BOOST_CHECK ( x_c == z ) ; BOOST_TEST ( x_c == z ) ;
#if !BOOST_WORKAROUND(BOOST_MSVC, < 1300) #if !BOOST_WORKAROUND(BOOST_MSVC, < 1300)
boost::value_initialized<T const> cx ; boost::value_initialized<T const> cx ;
BOOST_CHECK ( y == cx ) ; BOOST_TEST ( y == cx ) ;
BOOST_CHECK ( y == boost::get(cx) ) ; BOOST_TEST ( y == boost::get(cx) ) ;
boost::value_initialized<T const> const cx_c ; boost::value_initialized<T const> const cx_c ;
BOOST_CHECK ( y == cx_c ) ; BOOST_TEST ( y == cx_c ) ;
BOOST_CHECK ( y == boost::get(cx_c) ) ; BOOST_TEST ( y == boost::get(cx_c) ) ;
#endif #endif
} }
@@ -109,13 +95,6 @@ int test_main(int, char **)
test( POD(0,0,0.0), POD('a',1234,56.78) ) ; test( POD(0,0,0.0), POD('a',1234,56.78) ) ;
test( NonPOD( std::string() ), NonPOD( std::string("something") ) ) ; test( NonPOD( std::string() ), NonPOD( std::string("something") ) ) ;
NonPOD NonPOD_object( std::string("NonPOD_object") );
test<NonPOD *>( 0, &NonPOD_object ) ;
AggregatePODStruct zeroInitializedAggregatePODStruct = { 0.0f, '\0', 0 };
AggregatePODStruct nonZeroInitializedAggregatePODStruct = { 1.25f, 'a', -1 };
test(zeroInitializedAggregatePODStruct, nonZeroInitializedAggregatePODStruct);
return 0; return 0;
} }

View File

@@ -1,4 +1,4 @@
// Copyright 2002, Fernando Luis Cacciola Carballal. // (C) 2002, Fernando Luis Cacciola Carballal.
// //
// Distributed under the Boost Software License, Version 1.0. (See // Distributed under the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or copy at // accompanying file LICENSE_1_0.txt or copy at

View File

@@ -1,4 +1,4 @@
// Copyright 2002, Fernando Luis Cacciola Carballal. // (C) 2002, Fernando Luis Cacciola Carballal.
// //
// Distributed under the Boost Software License, Version 1.0. (See // Distributed under the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or copy at // accompanying file LICENSE_1_0.txt or copy at

View File

@@ -1,4 +1,4 @@
// Copyright 2002, Fernando Luis Cacciola Carballal. // (C) 2002, Fernando Luis Cacciola Carballal.
// //
// Distributed under the Boost Software License, Version 1.0. (See // Distributed under the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or copy at // accompanying file LICENSE_1_0.txt or copy at

View File

@@ -1,126 +0,0 @@
//
// verify_test.cpp - a test for BOOST_VERIFY
//
// Copyright (c) 2002 Peter Dimov and Multi Media Ltd.
// Copyright (c) 2007 Peter Dimov
//
// Distributed under the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt)
//
#include <boost/detail/lightweight_test.hpp>
#include <boost/assert.hpp>
int f( int & x )
{
return ++x;
}
void test_default()
{
int x = 1;
BOOST_VERIFY( 1 );
BOOST_VERIFY( x == 1 );
BOOST_VERIFY( ++x );
BOOST_VERIFY( f(x) );
BOOST_VERIFY( &x );
BOOST_TEST( x == 3 );
}
#define BOOST_DISABLE_ASSERTS
#include <boost/assert.hpp>
void test_disabled()
{
int x = 1;
BOOST_VERIFY( 1 );
BOOST_VERIFY( x == 1 );
BOOST_VERIFY( ++x );
BOOST_VERIFY( f(x) );
BOOST_VERIFY( &x );
BOOST_TEST( x == 3 );
BOOST_VERIFY( 0 );
BOOST_VERIFY( !x );
BOOST_VERIFY( x == 0 );
BOOST_VERIFY( !++x );
BOOST_VERIFY( !f(x) );
BOOST_TEST( x == 5 );
void * p = 0;
BOOST_VERIFY( p );
}
#undef BOOST_DISABLE_ASSERTS
#define BOOST_ENABLE_ASSERT_HANDLER
#include <boost/assert.hpp>
#include <boost/config.hpp>
#include <cstdio>
int handler_invoked = 0;
void boost::assertion_failed(char const * expr, char const * function, char const * file, long line)
{
#if !defined(BOOST_NO_STDC_NAMESPACE)
using std::printf;
#endif
printf("Expression: %s\nFunction: %s\nFile: %s\nLine: %ld\n\n", expr, function, file, line);
++handler_invoked;
}
struct X
{
static bool f()
{
BOOST_VERIFY( 0 );
return false;
}
};
void test_handler()
{
int x = 1;
BOOST_VERIFY( 1 );
BOOST_VERIFY( x == 1 );
BOOST_VERIFY( ++x );
BOOST_VERIFY( f(x) );
BOOST_VERIFY( &x );
BOOST_TEST( x == 3 );
BOOST_VERIFY( 0 );
BOOST_VERIFY( !x );
BOOST_VERIFY( x == 0 );
BOOST_VERIFY( !++x );
BOOST_VERIFY( !f(x) );
BOOST_TEST( x == 5 );
void * p = 0;
BOOST_VERIFY( p );
BOOST_VERIFY( X::f() );
BOOST_TEST( handler_invoked == 8 );
}
#undef BOOST_ENABLE_ASSERT_HANDLER
int main()
{
test_default();
test_disabled();
test_handler();
return boost::report_errors();
}