more unit test for opt ref swap and abstract types

This commit is contained in:
Andrzej Krzemienski
2016-02-16 23:49:15 +01:00
parent 143bda7c9f
commit b0602a1161
9 changed files with 66 additions and 124 deletions

View File

@ -13,7 +13,12 @@
[heading Boost Release X.XX] [heading Boost Release X.XX]
* Now `boost::optional` is specialized for reference parameters. This way the `sizeof` of optional reference is that of a pointer, and a number of bugs is avoided. * Now `boost::optional` is specialized for reference parameters. This addresses a couple of issues:
* the `sizeof` of optional reference is that of a pointer,
* some bugs connected to copying optional references are gone,
* you can swap optional references: it is like swapping pointers: shalow, underlying objects are not affected,
* optional references to abstract types work.
* Documented nested typedefs ([@https://svn.boost.org/trac/boost/ticket/5193 Trac #5193]).
[heading Boost Release 1.60] [heading Boost Release 1.60]

View File

@ -31,11 +31,32 @@
<span class="phrase"><a name="boost_optional.relnotes.boost_release_x_xx"></a></span><a class="link" href="relnotes.html#boost_optional.relnotes.boost_release_x_xx">Boost <span class="phrase"><a name="boost_optional.relnotes.boost_release_x_xx"></a></span><a class="link" href="relnotes.html#boost_optional.relnotes.boost_release_x_xx">Boost
Release X.XX</a> Release X.XX</a>
</h4> </h4>
<div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"> <div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; ">
<li class="listitem">
Now <code class="computeroutput"><span class="identifier">boost</span><span class="special">::</span><span class="identifier">optional</span></code> is specialized for reference Now <code class="computeroutput"><span class="identifier">boost</span><span class="special">::</span><span class="identifier">optional</span></code> is specialized for reference
parameters. This way the <code class="computeroutput"><span class="keyword">sizeof</span></code> parameters. This addresses a couple of issues:
of optional reference is that of a pointer, and a number of bugs is avoided. <div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; ">
</li></ul></div> <li class="listitem">
the <code class="computeroutput"><span class="keyword">sizeof</span></code> of optional
reference is that of a pointer,
</li>
<li class="listitem">
some bugs connected to copying optional references are gone,
</li>
<li class="listitem">
you can swap optional references: it is like swapping pointers: shalow,
underlying objects are not affected,
</li>
<li class="listitem">
optional references to abstract types work.
</li>
</ul></div>
</li>
<li class="listitem">
Documented nested typedefs (<a href="https://svn.boost.org/trac/boost/ticket/5193" target="_top">Trac
#5193</a>).
</li>
</ul></div>
<h4> <h4>
<a name="boost_optional.relnotes.h1"></a> <a name="boost_optional.relnotes.h1"></a>
<span class="phrase"><a name="boost_optional.relnotes.boost_release_1_60"></a></span><a class="link" href="relnotes.html#boost_optional.relnotes.boost_release_1_60">Boost <span class="phrase"><a name="boost_optional.relnotes.boost_release_1_60"></a></span><a class="link" href="relnotes.html#boost_optional.relnotes.boost_release_1_60">Boost

View File

@ -146,7 +146,7 @@
</div> </div>
</div> </div>
<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr> <table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
<td align="left"><p><small>Last revised: February 16, 2016 at 20:02:53 GMT</small></p></td> <td align="left"><p><small>Last revised: February 16, 2016 at 22:59:47 GMT</small></p></td>
<td align="right"><div class="copyright-footer"></div></td> <td align="right"><div class="copyright-footer"></div></td>
</tr></table> </tr></table>
<hr> <hr>

View File

@ -30,7 +30,6 @@ import testing ;
[ run optional_test_ref_convert_assign_const_int.cpp ] [ run optional_test_ref_convert_assign_const_int.cpp ]
[ run optional_test_ref_portable_minimum.cpp ] [ run optional_test_ref_portable_minimum.cpp ]
[ run optional_test_ref_move.cpp ] [ run optional_test_ref_move.cpp ]
[ run optional_test_ref_swap.cpp ]
[ run optional_test_inplace_factory.cpp ] [ run optional_test_inplace_factory.cpp ]
[ run optional_test_io.cpp ] [ run optional_test_io.cpp ]
[ run optional_test_move.cpp ] [ run optional_test_move.cpp ]

View File

@ -38,7 +38,7 @@ void test_optional_ref_assignment()
int main() int main()
{ {
test_optional_ref_assignment<ScopeGuard>(); test_optional_ref_assignment<ScopeGuard>();
//test_optional_ref_assignment<Abstract>(); test_optional_ref_assignment<Abstract>();
return boost::report_errors(); return boost::report_errors();
} }

View File

@ -33,7 +33,7 @@ void test_all_const_cases()
int main() int main()
{ {
test_all_const_cases<ScopeGuard>(); test_all_const_cases<ScopeGuard>();
//test_all_const_cases<Abstract>(); test_all_const_cases<Abstract>();
return boost::report_errors(); return boost::report_errors();
} }

View File

@ -101,7 +101,7 @@ int main()
{ {
test_all_const_cases<int>(); test_all_const_cases<int>();
test_all_const_cases<ScopeGuard>(); test_all_const_cases<ScopeGuard>();
//test_all_const_cases<Abstract>(); test_all_const_cases<Abstract>();
return boost::report_errors(); return boost::report_errors();
} }

View File

@ -256,11 +256,11 @@ void test_equality()
BOOST_TEST( (o2 != oN)); BOOST_TEST( (o2 != oN));
} }
template <typename T> template <typename T, typename U = T>
void test_order() void test_order()
{ {
typename concrete_type_of<T>::type v1(1), v2(2), v2_(2), v3(3); typename concrete_type_of<T>::type v1(1), v2(2), v2_(2), v3(3);
optional<T&> o1(v1), o2(v2), o2_(v2_), o3(v3), o3_(v3), oN, oN_; optional<U&> o1(v1), o2(v2), o2_(v2_), o3(v3), o3_(v3), oN, oN_;
// o2 and o2_ point to different objects; o3 and o3_ point to the same object // o2 and o2_ point to different objects; o3 and o3_ point to the same object
BOOST_TEST(!(oN < oN)); BOOST_TEST(!(oN < oN));
@ -399,13 +399,35 @@ void test_order()
BOOST_TEST(!(o3_ < oN_)); BOOST_TEST(!(o3_ < oN_));
} }
template <typename T> template <typename T, typename U = T>
void test_swap() void test_swap()
{ {
typename concrete_type_of<T>::type v1(1), v2(2); typename concrete_type_of<T>::type v1(1), v2(2);
optional<T&> o1(v1), o1_(v1), o2(v2), o2_(v2), oN, oN_; optional<U&> o1(v1), o1_(v1), o2(v2), o2_(v2), oN, oN_;
// swap(o1, o1); DOESN'T WORK swap(o1, o1);
BOOST_TEST(o1);
BOOST_TEST(boost::addressof(*o1) == boost::addressof(v1));
swap(oN, oN_);
BOOST_TEST(!oN);
BOOST_TEST(!oN_);
swap(o1, oN);
BOOST_TEST(!o1);
BOOST_TEST(oN);
BOOST_TEST(boost::addressof(*oN) == boost::addressof(v1));
swap(oN, o1);
BOOST_TEST(!oN);
BOOST_TEST(o1);
BOOST_TEST(boost::addressof(*o1) == boost::addressof(v1));
swap(o1_, o2_);
BOOST_TEST(o1_);
BOOST_TEST(o2_);
BOOST_TEST(boost::addressof(*o1_) == boost::addressof(v2));
BOOST_TEST(boost::addressof(*o2_) == boost::addressof(v1));
} }
template <typename T> template <typename T>
@ -431,18 +453,19 @@ void test_optional_const_ref()
test_arrow_noconst_const<T>(); test_arrow_noconst_const<T>();
test_equality<const T>(); test_equality<const T>();
test_order<const T>(); test_order<const T>();
//test_swap<T>(); test_swap<const T>();
test_swap<T, const T>();
} }
int main() int main()
{ {
test_optional_ref<int>(); test_optional_ref<int>();
test_optional_ref<ScopeGuard>(); test_optional_ref<ScopeGuard>();
//test_optional_ref<Abstract>(); test_optional_ref<Abstract>();
test_optional_const_ref<int>(); test_optional_const_ref<int>();
test_optional_const_ref<ScopeGuard>(); test_optional_const_ref<ScopeGuard>();
//test_optional_const_ref<Abstract>(); test_optional_const_ref<Abstract>();
return boost::report_errors(); return boost::report_errors();
} }

View File

@ -1,106 +0,0 @@
// Copyright (C) 2016 Andrzej Krzemienski.
//
// Use, modification, and distribution is subject to the Boost Software
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt)
//
// See http://www.boost.org/lib/optional for documentation.
//
// You are welcome to contact the maintainer at: akrzemi1@gmail.com
#include "boost/optional/optional.hpp"
#ifdef __BORLANDC__
#pragma hdrstop
#endif
#include <string>
#include "boost/core/addressof.hpp"
#include "boost/core/lightweight_test.hpp"
using boost::optional;
struct Iface
{
virtual void fun() = 0;
protected: ~Iface() {}
};
struct Impl : Iface
{
void fun() {}
};
template <typename T>
void test_swap_empty_with_empty()
{
boost::optional<T&> o1, o2;
swap(o1, o2);
BOOST_TEST(!o1);
BOOST_TEST(!o2);
}
template <typename T, typename U>
void test_swap_value_with_empty(U v1)
{
boost::optional<T&> o1 (v1), o2;
swap(o1, o2);
BOOST_TEST(!o1);
BOOST_TEST(o2);
BOOST_TEST(boost::addressof(*o2) == boost::addressof(v1));
}
template <typename T, typename U>
void test_swap_empty_with_value(U v2)
{
boost::optional<T&> o1, o2(v2);
swap(o1, o2);
BOOST_TEST(o1);
BOOST_TEST(boost::addressof(*o1) == boost::addressof(v2));
BOOST_TEST(!o2);
}
template <typename T, typename U>
void test_swap_value_with_value(U v1, U v2)
{
boost::optional<T&> o1(v1), o2(v2);
swap(o1, o2);
BOOST_TEST(o1);
BOOST_TEST(o2);
BOOST_TEST(boost::addressof(*o1) == boost::addressof(v2));
BOOST_TEST(boost::addressof(*o2) == boost::addressof(v1));
}
int main()
{
std::string s1 ("AAA"), s2 ("BB");
int i1 = 1, i2 = 2;
Impl p1, p2;
test_swap_empty_with_empty<std::string>( );
test_swap_value_with_empty<std::string>(s1 );
test_swap_empty_with_value<std::string>( s2);
test_swap_value_with_value<std::string>(s1, s2);
test_swap_empty_with_empty<int>( );
test_swap_value_with_empty<int>(i1 );
test_swap_empty_with_value<int>( i2);
test_swap_value_with_value<int>(i1, i2);
test_swap_empty_with_empty<Iface>( );
test_swap_value_with_empty<Iface>(p1 );
test_swap_empty_with_value<Iface>( p2);
test_swap_value_with_value<Iface>(p1, p2);
test_swap_empty_with_empty<const Iface>( );
test_swap_value_with_empty<const Iface>(p1 );
test_swap_empty_with_value<const Iface>( p2);
test_swap_value_with_value<const Iface>(p1, p2);
return boost::report_errors();
}