Merge branch 'develop' of https://github.com/RobertLeahy/optional-2 into RobertLeahy-develop

This commit is contained in:
Andrzej Krzemienski
2020-04-06 00:33:11 +02:00
6 changed files with 37 additions and 18 deletions

View File

@ -151,6 +151,7 @@ matrix:
- llvm-toolchain-precise-3.9 - llvm-toolchain-precise-3.9
- os: linux - os: linux
dist: trusty
compiler: clang++-4.0 compiler: clang++-4.0
env: TOOLSET=clang COMPILER=clang++-4.0 CXXSTD=03,11,14,1z env: TOOLSET=clang COMPILER=clang++-4.0 CXXSTD=03,11,14,1z
addons: addons:
@ -162,6 +163,7 @@ matrix:
- llvm-toolchain-trusty-4.0 - llvm-toolchain-trusty-4.0
- os: linux - os: linux
dist: trusty
compiler: clang++-5.0 compiler: clang++-5.0
env: TOOLSET=clang COMPILER=clang++-5.0 CXXSTD=03,11,14,1z env: TOOLSET=clang COMPILER=clang++-5.0 CXXSTD=03,11,14,1z
addons: addons:

View File

@ -359,7 +359,7 @@ class tc_optional_base : public optional_tag
template<class Expr> template<class Expr>
void construct ( Expr const& factory, in_place_factory_base const* ) void construct ( Expr const& factory, in_place_factory_base const* )
{ {
boost_optional_detail::construct<value_type>(factory, m_storage.address()); boost_optional_detail::construct<value_type>(factory, boost::addressof(m_storage));
m_initialized = true ; m_initialized = true ;
} }

View File

@ -26,12 +26,14 @@ struct size_tag {};
template< typename T, typename U > template< typename T, typename U >
struct is_constructible struct is_constructible
{ {
template< typename T1, typename U1 > static U& get();
static yes_type check_helper(size_tag< sizeof(static_cast< T1 >(U1())) >*);
template< typename T1, typename U1 > template< typename T1 >
static yes_type check_helper(size_tag< sizeof(static_cast< T1 >(get())) >*);
template< typename T1 >
static no_type check_helper(...); static no_type check_helper(...);
static const bool value = sizeof(check_helper< T, U >(0)) == sizeof(yes_type); static const bool value = sizeof(check_helper< T >(0)) == sizeof(yes_type);
}; };
template< typename T > template< typename T >

View File

@ -31,10 +31,10 @@ struct Guard
std::string str; std::string str;
Guard() : num() {} Guard() : num() {}
Guard(double num_, std::string str_) : num(num_), str(str_) {} Guard(double num_, std::string str_) : num(num_), str(str_) {}
friend bool operator==(const Guard& lhs, const Guard& rhs) { return lhs.num == rhs.num && lhs.str == rhs.str; } friend bool operator==(const Guard& lhs, const Guard& rhs) { return lhs.num == rhs.num && lhs.str == rhs.str; }
friend bool operator!=(const Guard& lhs, const Guard& rhs) { return !(lhs == rhs); } friend bool operator!=(const Guard& lhs, const Guard& rhs) { return !(lhs == rhs); }
private: private:
Guard(const Guard&); Guard(const Guard&);
Guard& operator=(const Guard&); Guard& operator=(const Guard&);
@ -44,26 +44,30 @@ void test_ctor()
{ {
#ifndef BOOST_OPTIONAL_NO_INPLACE_FACTORY_SUPPORT #ifndef BOOST_OPTIONAL_NO_INPLACE_FACTORY_SUPPORT
Guard g0, g1(1.0, "one"), g2(2.0, "two"); Guard g0, g1(1.0, "one"), g2(2.0, "two");
boost::optional<Guard> og0 ( boost::in_place() ); boost::optional<Guard> og0 ( boost::in_place() );
boost::optional<Guard> og1 ( boost::in_place(1.0, "one") ); boost::optional<Guard> og1 ( boost::in_place(1.0, "one") );
boost::optional<Guard> og1_( boost::in_place(1.0, "one") ); boost::optional<Guard> og1_( boost::in_place(1.0, "one") );
boost::optional<Guard> og2 ( boost::in_place<Guard>(2.0, "two") ); boost::optional<Guard> og2 ( boost::in_place<Guard>(2.0, "two") );
BOOST_TEST(og0); BOOST_TEST(og0);
BOOST_TEST(og1); BOOST_TEST(og1);
BOOST_TEST(og1_); BOOST_TEST(og1_);
BOOST_TEST(og2); BOOST_TEST(og2);
BOOST_TEST(*og0 == g0); BOOST_TEST(*og0 == g0);
BOOST_TEST(*og1 == g1); BOOST_TEST(*og1 == g1);
BOOST_TEST(*og1_ == g1); BOOST_TEST(*og1_ == g1);
BOOST_TEST(*og2 == g2); BOOST_TEST(*og2 == g2);
BOOST_TEST(og1_ == og1); BOOST_TEST(og1_ == og1);
BOOST_TEST(og1_ != og2); BOOST_TEST(og1_ != og2);
BOOST_TEST(og1_ != og0); BOOST_TEST(og1_ != og0);
#endif
boost::optional<unsigned int> o( boost::in_place(5) );
BOOST_TEST(o);
BOOST_TEST(*o == 5);
#endif
} }
void test_assign() void test_assign()
@ -71,27 +75,32 @@ void test_assign()
#ifndef BOOST_OPTIONAL_NO_INPLACE_FACTORY_SUPPORT #ifndef BOOST_OPTIONAL_NO_INPLACE_FACTORY_SUPPORT
#ifndef BOOST_OPTIONAL_WEAK_OVERLOAD_RESOLUTION #ifndef BOOST_OPTIONAL_WEAK_OVERLOAD_RESOLUTION
Guard g0, g1(1.0, "one"), g2(2.0, "two"); Guard g0, g1(1.0, "one"), g2(2.0, "two");
boost::optional<Guard> og0, og1, og1_, og2; boost::optional<Guard> og0, og1, og1_, og2;
og0 = boost::in_place(); og0 = boost::in_place();
og1 = boost::in_place(1.0, "one"); og1 = boost::in_place(1.0, "one");
og1_ = boost::in_place(1.0, "one"); og1_ = boost::in_place(1.0, "one");
og2 = boost::in_place<Guard>(2.0, "two"); og2 = boost::in_place<Guard>(2.0, "two");
BOOST_TEST(og0); BOOST_TEST(og0);
BOOST_TEST(og1); BOOST_TEST(og1);
BOOST_TEST(og1_); BOOST_TEST(og1_);
BOOST_TEST(og2); BOOST_TEST(og2);
BOOST_TEST(*og0 == g0); BOOST_TEST(*og0 == g0);
BOOST_TEST(*og1 == g1); BOOST_TEST(*og1 == g1);
BOOST_TEST(*og1_ == g1); BOOST_TEST(*og1_ == g1);
BOOST_TEST(*og2 == g2); BOOST_TEST(*og2 == g2);
BOOST_TEST(og1_ == og1); BOOST_TEST(og1_ == og1);
BOOST_TEST(og1_ != og2); BOOST_TEST(og1_ != og2);
BOOST_TEST(og1_ != og0); BOOST_TEST(og1_ != og0);
boost::optional<unsigned int> o;
o = boost::in_place(5);
BOOST_TEST(o);
BOOST_TEST(*o == 5);
#endif #endif
#endif #endif
} }
@ -101,4 +110,4 @@ int main()
test_ctor(); test_ctor();
test_assign(); test_assign();
return boost::report_errors(); return boost::report_errors();
} }

View File

@ -15,6 +15,8 @@
#pragma hdrstop #pragma hdrstop
#endif #endif
#ifndef BOOST_OPTIONAL_DETAIL_NO_IS_CONSTRUCTIBLE_TRAIT
#ifndef BOOST_OPTIONAL_DETAIL_NO_SFINAE_FRIENDLY_CONSTRUCTORS
template <typename, typename> template <typename, typename>
struct void_t struct void_t
{ {
@ -49,6 +51,8 @@ struct Path
#endif #endif
}; };
#endif
#endif
int main() int main()

View File

@ -93,7 +93,9 @@ template <typename T>
void test_all_const_cases() void test_all_const_cases()
{ {
test_converting_ctor<T>(); test_converting_ctor<T>();
#ifndef BOOST_OPTIONAL_CONFIG_NO_PROPER_CONVERT_FROM_CONST_INT
test_converting_ctor<const T>(); test_converting_ctor<const T>();
#endif
test_converting_ctor_for_noconst_const<T>(); test_converting_ctor_for_noconst_const<T>();
} }