Add all the relational operators to std::experimental::optional. Also update bad_optional_access to match the Library Fundamentals draft standard. This is not all of the upcoming changes to optional, though.
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@223775 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -16,131 +16,147 @@
|
|||||||
|
|
||||||
// C++1y
|
// C++1y
|
||||||
|
|
||||||
#include <initializer_list>
|
namespace std { namespace experimental { inline namespace fundamentals_v1 {
|
||||||
|
|
||||||
namespace std { namespace experimental {
|
// 5.3, optional for object types
|
||||||
|
template <class T> class optional;
|
||||||
|
|
||||||
// optional for object types
|
// 5.4, In-place construction
|
||||||
template <class T>
|
struct in_place_t{};
|
||||||
class optional
|
constexpr in_place_t in_place{};
|
||||||
{
|
|
||||||
public:
|
|
||||||
typedef T value_type;
|
|
||||||
|
|
||||||
// constructors
|
// 5.5, No-value state indicator
|
||||||
constexpr optional() noexcept;
|
struct nullopt_t{see below};
|
||||||
constexpr optional(nullopt_t) noexcept;
|
constexpr nullopt_t nullopt(unspecified);
|
||||||
optional(const optional&);
|
|
||||||
optional(optional&&) noexcept(is_nothrow_move_constructible<T>::value);
|
|
||||||
constexpr optional(const T&);
|
|
||||||
constexpr optional(T&&);
|
|
||||||
template <class... Args> constexpr explicit optional(in_place_t, Args&&...);
|
|
||||||
template <class U, class... Args>
|
|
||||||
constexpr explicit optional(in_place_t, initializer_list<U>, Args&&...);
|
|
||||||
|
|
||||||
// destructor
|
// 5.6, Class bad_optional_access
|
||||||
~optional();
|
class bad_optional_access;
|
||||||
|
|
||||||
// assignment
|
// 5.7, Relational operators
|
||||||
optional& operator=(nullopt_t) noexcept;
|
template <class T>
|
||||||
optional& operator=(const optional&);
|
constexpr bool operator==(const optional<T>&, const optional<T>&);
|
||||||
optional& operator=(optional&&)
|
template <class T>
|
||||||
noexcept(is_nothrow_move_assignable<T>::value &&
|
constexpr bool operator!=(const optional<T>&, const optional<T>&);
|
||||||
is_nothrow_move_constructible<T>::value);
|
template <class T>
|
||||||
template <class U> optional& operator=(U&&);
|
constexpr bool operator<(const optional<T>&, const optional<T>&);
|
||||||
template <class... Args> void emplace(Args&&...);
|
template <class T>
|
||||||
template <class U, class... Args> void emplace(initializer_list<U>, Args&&...);
|
constexpr bool operator>(const optional<T>&, const optional<T>&);
|
||||||
|
template <class T>
|
||||||
|
constexpr bool operator<=(const optional<T>&, const optional<T>&);
|
||||||
|
template <class T>
|
||||||
|
constexpr bool operator>=(const optional<T>&, const optional<T>&);
|
||||||
|
|
||||||
// swap
|
// 5.8, Comparison with nullopt
|
||||||
void swap(optional&)
|
template <class T> constexpr bool operator==(const optional<T>&, nullopt_t) noexcept;
|
||||||
noexcept(is_nothrow_move_constructible<T>::value &&
|
template <class T> constexpr bool operator==(nullopt_t, const optional<T>&) noexcept;
|
||||||
noexcept(swap(declval<T&>(), declval<T&>())));
|
template <class T> constexpr bool operator!=(const optional<T>&, nullopt_t) noexcept;
|
||||||
|
template <class T> constexpr bool operator!=(nullopt_t, const optional<T>&) noexcept;
|
||||||
|
template <class T> constexpr bool operator<(const optional<T>&, nullopt_t) noexcept;
|
||||||
|
template <class T> constexpr bool operator<(nullopt_t, const optional<T>&) noexcept;
|
||||||
|
template <class T> constexpr bool operator<=(const optional<T>&, nullopt_t) noexcept;
|
||||||
|
template <class T> constexpr bool operator<=(nullopt_t, const optional<T>&) noexcept;
|
||||||
|
template <class T> constexpr bool operator>(const optional<T>&, nullopt_t) noexcept;
|
||||||
|
template <class T> constexpr bool operator>(nullopt_t, const optional<T>&) noexcept;
|
||||||
|
template <class T> constexpr bool operator>=(const optional<T>&, nullopt_t) noexcept;
|
||||||
|
template <class T> constexpr bool operator>=(nullopt_t, const optional<T>&) noexcept;
|
||||||
|
|
||||||
// observers
|
// 5.9, Comparison with T
|
||||||
constexpr T const* operator->() const;
|
template <class T> constexpr bool operator==(const optional<T>&, const T&);
|
||||||
T* operator->();
|
template <class T> constexpr bool operator==(const T&, const optional<T>&);
|
||||||
constexpr T const& operator*() const;
|
template <class T> constexpr bool operator!=(const optional<T>&, const T&);
|
||||||
T& operator*();
|
template <class T> constexpr bool operator!=(const T&, const optional<T>&);
|
||||||
constexpr explicit operator bool() const noexcept;
|
template <class T> constexpr bool operator<(const optional<T>&, const T&);
|
||||||
constexpr T const& value() const;
|
template <class T> constexpr bool operator<(const T&, const optional<T>&);
|
||||||
T& value();
|
template <class T> constexpr bool operator<=(const optional<T>&, const T&);
|
||||||
template <class U> constexpr T value_or(U&&) const&;
|
template <class T> constexpr bool operator<=(const T&, const optional<T>&);
|
||||||
template <class U> T value_or(U&&) &&;
|
template <class T> constexpr bool operator>(const optional<T>&, const T&);
|
||||||
};
|
template <class T> constexpr bool operator>(const T&, const optional<T>&);
|
||||||
|
template <class T> constexpr bool operator>=(const optional<T>&, const T&);
|
||||||
|
template <class T> constexpr bool operator>=(const T&, const optional<T>&);
|
||||||
|
|
||||||
// In-place construction
|
// 5.10, Specialized algorithms
|
||||||
struct in_place_t{};
|
template <class T> void swap(optional<T>&, optional<T>&) noexcept(see below);
|
||||||
constexpr in_place_t in_place{};
|
template <class T> constexpr optional<see below> make_optional(T&&);
|
||||||
|
|
||||||
// Disengaged state indicator
|
template <class T>
|
||||||
struct nullopt_t{see below};
|
class optional
|
||||||
constexpr nullopt_t nullopt(unspecified);
|
{
|
||||||
|
public:
|
||||||
|
typedef T value_type;
|
||||||
|
|
||||||
// class bad_optional_access
|
// 5.3.1, Constructors
|
||||||
class bad_optional_access
|
constexpr optional() noexcept;
|
||||||
: public logic_error
|
constexpr optional(nullopt_t) noexcept;
|
||||||
{
|
optional(const optional&);
|
||||||
public:
|
optional(optional&&) noexcept(see below);
|
||||||
explicit bad_optional_access(const string& what_arg);
|
constexpr optional(const T&);
|
||||||
explicit bad_optional_access(const char* what_arg);
|
constexpr optional(T&&);
|
||||||
};
|
template <class... Args> constexpr explicit optional(in_place_t, Args&&...);
|
||||||
|
template <class U, class... Args>
|
||||||
|
constexpr explicit optional(in_place_t, initializer_list<U>, Args&&...);
|
||||||
|
|
||||||
// Relational operators
|
// 5.3.2, Destructor
|
||||||
template <class T> constexpr bool operator==(const optional<T>&, const optional<T>&);
|
~optional();
|
||||||
template <class T> constexpr bool operator< (const optional<T>&, const optional<T>&);
|
|
||||||
|
|
||||||
// Comparison with nullopt
|
// 5.3.3, Assignment
|
||||||
template <class T> constexpr bool operator==(const optional<T>&, nullopt_t) noexcept;
|
optional& operator=(nullopt_t) noexcept;
|
||||||
template <class T> constexpr bool operator==(nullopt_t, const optional<T>&) noexcept;
|
optional& operator=(const optional&);
|
||||||
template <class T> constexpr bool operator<(const optional<T>&, nullopt_t) noexcept;
|
optional& operator=(optional&&) noexcept(see below);
|
||||||
template <class T> constexpr bool operator<(nullopt_t, const optional<T>&) noexcept;
|
template <class U> optional& operator=(U&&);
|
||||||
|
template <class... Args> void emplace(Args&&...);
|
||||||
|
template <class U, class... Args>
|
||||||
|
void emplace(initializer_list<U>, Args&&...);
|
||||||
|
|
||||||
// Comparison with T
|
// 5.3.4, Swap
|
||||||
template <class T> constexpr bool operator==(const optional<T>&, const T&);
|
void swap(optional&) noexcept(see below);
|
||||||
template <class T> constexpr bool operator==(const T&, const optional<T>&);
|
|
||||||
template <class T> constexpr bool operator<(const optional<T>&, const T&);
|
|
||||||
template <class T> constexpr bool operator<(const T&, const optional<T>&);
|
|
||||||
|
|
||||||
// Specialized algorithms
|
// 5.3.5, Observers
|
||||||
template <class T> void swap(optional<T>&, optional<T>&) noexcept(see below);
|
constexpr T const* operator ->() const;
|
||||||
template <class T> constexpr optional<typename decay<T>::type> make_optional(T&&);
|
constexpr T* operator ->();
|
||||||
|
constexpr T const& operator *() const &;
|
||||||
|
constexpr T& operator *() &;
|
||||||
|
constexpr T&& operator *() &&;
|
||||||
|
constexpr const T&& operator *() const &&;
|
||||||
|
constexpr explicit operator bool() const noexcept;
|
||||||
|
constexpr T const& value() const &;
|
||||||
|
constexpr T& value() &;
|
||||||
|
constexpr T&& value() &&;
|
||||||
|
constexpr const T&& value() const &&;
|
||||||
|
template <class U> constexpr T value_or(U&&) const &;
|
||||||
|
template <class U> constexpr T value_or(U&&) &&;
|
||||||
|
|
||||||
// hash support
|
private:
|
||||||
template <class T> struct hash;
|
T* val; // exposition only
|
||||||
template <class T> struct hash<optional<T>>;
|
};
|
||||||
|
|
||||||
}} // std::experimental
|
} // namespace fundamentals_v1
|
||||||
|
} // namespace experimental
|
||||||
|
|
||||||
|
// 5.11, Hash support
|
||||||
|
template <class T> struct hash;
|
||||||
|
template <class T> struct hash<experimental::optional<T>>;
|
||||||
|
|
||||||
|
} // namespace std
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <__config>
|
#include <experimental/__config>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
namespace std { namespace experimental {
|
_LIBCPP_BEGIN_NAMESPACE_EXPERIMENTAL
|
||||||
|
|
||||||
class _LIBCPP_EXCEPTION_ABI bad_optional_access
|
class _LIBCPP_EXCEPTION_ABI bad_optional_access
|
||||||
: public logic_error
|
: public std::logic_error
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
#if _LIBCPP_STD_VER > 11
|
bad_optional_access() : std::logic_error("Bad optional Access") {}
|
||||||
_LIBCPP_INLINE_VISIBILITY explicit bad_optional_access(const string& __arg)
|
|
||||||
: logic_error(__arg) {}
|
// Get the key function ~bad_optional_access() into the dylib
|
||||||
_LIBCPP_INLINE_VISIBILITY explicit bad_optional_access(const char* __arg)
|
|
||||||
: logic_error(__arg) {}
|
|
||||||
_LIBCPP_INLINE_VISIBILITY bad_optional_access(const bad_optional_access&) noexcept = default;
|
|
||||||
_LIBCPP_INLINE_VISIBILITY bad_optional_access& operator=(const bad_optional_access&) noexcept = default;
|
|
||||||
#else
|
|
||||||
private:
|
|
||||||
bad_optional_access(const bad_optional_access&);
|
|
||||||
bad_optional_access& operator=(const bad_optional_access&);
|
|
||||||
public:
|
|
||||||
#endif // _LIBCPP_STD_VER > 11
|
|
||||||
// Get the key function ~bad_optional_access() into the dylib even if not compiling for C++1y
|
|
||||||
virtual ~bad_optional_access() _NOEXCEPT;
|
virtual ~bad_optional_access() _NOEXCEPT;
|
||||||
};
|
};
|
||||||
|
|
||||||
}} // std::experimental
|
_LIBCPP_END_NAMESPACE_EXPERIMENTAL
|
||||||
|
|
||||||
|
|
||||||
#if _LIBCPP_STD_VER > 11
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
@@ -148,16 +164,14 @@ public:
|
|||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <new>
|
#include <new>
|
||||||
#include <__functional_base>
|
#include <__functional_base>
|
||||||
|
|
||||||
#include <__undef_min_max>
|
#include <__undef_min_max>
|
||||||
|
|
||||||
#include <__debug>
|
#include <__debug>
|
||||||
|
|
||||||
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
||||||
#pragma GCC system_header
|
#pragma GCC system_header
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace std { namespace experimental { inline namespace __library_fundamentals_v1 {
|
_LIBCPP_BEGIN_NAMESPACE_LFTS
|
||||||
|
|
||||||
struct in_place_t {};
|
struct in_place_t {};
|
||||||
constexpr in_place_t in_place{};
|
constexpr in_place_t in_place{};
|
||||||
@@ -503,7 +517,7 @@ public:
|
|||||||
constexpr value_type const& value() const
|
constexpr value_type const& value() const
|
||||||
{
|
{
|
||||||
if (!this->__engaged_)
|
if (!this->__engaged_)
|
||||||
throw bad_optional_access("optional<T>::value: not engaged");
|
throw bad_optional_access();
|
||||||
return this->__val_;
|
return this->__val_;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -511,7 +525,7 @@ public:
|
|||||||
value_type& value()
|
value_type& value()
|
||||||
{
|
{
|
||||||
if (!this->__engaged_)
|
if (!this->__engaged_)
|
||||||
throw bad_optional_access("optional<T>::value: not engaged");
|
throw bad_optional_access();
|
||||||
return this->__val_;
|
return this->__val_;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -556,6 +570,7 @@ private:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Comparisons between optionals
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
inline _LIBCPP_INLINE_VISIBILITY
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
constexpr
|
constexpr
|
||||||
@@ -569,6 +584,15 @@ operator==(const optional<_Tp>& __x, const optional<_Tp>& __y)
|
|||||||
return *__x == *__y;
|
return *__x == *__y;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator!=(const optional<_Tp>& __x, const optional<_Tp>& __y)
|
||||||
|
{
|
||||||
|
return !(__x == __y);
|
||||||
|
}
|
||||||
|
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
inline _LIBCPP_INLINE_VISIBILITY
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
constexpr
|
constexpr
|
||||||
@@ -579,9 +603,38 @@ operator<(const optional<_Tp>& __x, const optional<_Tp>& __y)
|
|||||||
return false;
|
return false;
|
||||||
if (!static_cast<bool>(__x))
|
if (!static_cast<bool>(__x))
|
||||||
return true;
|
return true;
|
||||||
return less<_Tp>{}(*__x, *__y);
|
return *__x < *__y;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>(const optional<_Tp>& __x, const optional<_Tp>& __y)
|
||||||
|
{
|
||||||
|
return __y < __x;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator<=(const optional<_Tp>& __x, const optional<_Tp>& __y)
|
||||||
|
{
|
||||||
|
return !(__y < __x);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>=(const optional<_Tp>& __x, const optional<_Tp>& __y)
|
||||||
|
{
|
||||||
|
return !(__x < __y);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Comparisons with nullopt
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
inline _LIBCPP_INLINE_VISIBILITY
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
constexpr
|
constexpr
|
||||||
@@ -600,6 +653,24 @@ operator==(nullopt_t, const optional<_Tp>& __x) noexcept
|
|||||||
return !static_cast<bool>(__x);
|
return !static_cast<bool>(__x);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator!=(const optional<_Tp>& __x, nullopt_t) noexcept
|
||||||
|
{
|
||||||
|
return static_cast<bool>(__x);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator!=(nullopt_t, const optional<_Tp>& __x) noexcept
|
||||||
|
{
|
||||||
|
return static_cast<bool>(__x);
|
||||||
|
}
|
||||||
|
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
inline _LIBCPP_INLINE_VISIBILITY
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
constexpr
|
constexpr
|
||||||
@@ -618,6 +689,61 @@ operator<(nullopt_t, const optional<_Tp>& __x) noexcept
|
|||||||
return static_cast<bool>(__x);
|
return static_cast<bool>(__x);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator<=(const optional<_Tp>& __x, nullopt_t) noexcept
|
||||||
|
{
|
||||||
|
return !static_cast<bool>(__x);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator<=(nullopt_t, const optional<_Tp>& __x) noexcept
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>(const optional<_Tp>& __x, nullopt_t) noexcept
|
||||||
|
{
|
||||||
|
return static_cast<bool>(__x);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>(nullopt_t, const optional<_Tp>& __x) noexcept
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>=(const optional<_Tp>&, nullopt_t) noexcept
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>=(nullopt_t, const optional<_Tp>& __x) noexcept
|
||||||
|
{
|
||||||
|
return !static_cast<bool>(__x);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Comparisons with T
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
inline _LIBCPP_INLINE_VISIBILITY
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
constexpr
|
constexpr
|
||||||
@@ -636,6 +762,24 @@ operator==(const _Tp& __v, const optional<_Tp>& __x)
|
|||||||
return static_cast<bool>(__x) ? *__x == __v : false;
|
return static_cast<bool>(__x) ? *__x == __v : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator!=(const optional<_Tp>& __x, const _Tp& __v)
|
||||||
|
{
|
||||||
|
return static_cast<bool>(__x) ? !(*__x == __v) : true;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator!=(const _Tp& __v, const optional<_Tp>& __x)
|
||||||
|
{
|
||||||
|
return static_cast<bool>(__x) ? !(*__x == __v) : true;
|
||||||
|
}
|
||||||
|
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
inline _LIBCPP_INLINE_VISIBILITY
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
constexpr
|
constexpr
|
||||||
@@ -654,6 +798,61 @@ operator<(const _Tp& __v, const optional<_Tp>& __x)
|
|||||||
return static_cast<bool>(__x) ? less<_Tp>{}(__v, *__x) : false;
|
return static_cast<bool>(__x) ? less<_Tp>{}(__v, *__x) : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator<=(const optional<_Tp>& __x, const _Tp& __v)
|
||||||
|
{
|
||||||
|
return !(__x > __v);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator<=(const _Tp& __v, const optional<_Tp>& __x)
|
||||||
|
{
|
||||||
|
return !(__v > __x);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>(const optional<_Tp>& __x, const _Tp& __v)
|
||||||
|
{
|
||||||
|
return static_cast<bool>(__x) ? __v < __x : false;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>(const _Tp& __v, const optional<_Tp>& __x)
|
||||||
|
{
|
||||||
|
return static_cast<bool>(__x) ? __x < __v : true;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>=(const optional<_Tp>& __x, const _Tp& __v)
|
||||||
|
{
|
||||||
|
return !(__x < __v);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class _Tp>
|
||||||
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
|
constexpr
|
||||||
|
bool
|
||||||
|
operator>=(const _Tp& __v, const optional<_Tp>& __x)
|
||||||
|
{
|
||||||
|
return !(__v < __x);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
template <class _Tp>
|
template <class _Tp>
|
||||||
inline _LIBCPP_INLINE_VISIBILITY
|
inline _LIBCPP_INLINE_VISIBILITY
|
||||||
void
|
void
|
||||||
@@ -671,7 +870,7 @@ make_optional(_Tp&& __v)
|
|||||||
return optional<typename decay<_Tp>::type>(_VSTD::forward<_Tp>(__v));
|
return optional<typename decay<_Tp>::type>(_VSTD::forward<_Tp>(__v));
|
||||||
}
|
}
|
||||||
|
|
||||||
}}} // namespace std::experimental::__library_fundamentals_v1
|
_LIBCPP_END_NAMESPACE_LFTS
|
||||||
|
|
||||||
_LIBCPP_BEGIN_NAMESPACE_STD
|
_LIBCPP_BEGIN_NAMESPACE_STD
|
||||||
|
|
||||||
|
@@ -9,8 +9,7 @@
|
|||||||
|
|
||||||
#include "experimental/optional"
|
#include "experimental/optional"
|
||||||
|
|
||||||
namespace std // purposefully not using versioning namespace
|
_LIBCPP_BEGIN_NAMESPACE_EXPERIMENTAL
|
||||||
{ namespace experimental {
|
|
||||||
|
|
||||||
#ifdef _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS
|
#ifdef _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS
|
||||||
|
|
||||||
@@ -22,4 +21,4 @@ bad_optional_access::~bad_optional_access() _NOEXCEPT = default;
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}} // std::experimental
|
_LIBCPP_END_NAMESPACE_EXPERIMENTAL
|
||||||
|
@@ -1,29 +0,0 @@
|
|||||||
//===----------------------------------------------------------------------===//
|
|
||||||
//
|
|
||||||
// The LLVM Compiler Infrastructure
|
|
||||||
//
|
|
||||||
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
||||||
// Source Licenses. See LICENSE.TXT for details.
|
|
||||||
//
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
|
|
||||||
// <optional>
|
|
||||||
|
|
||||||
// class bad_optional_access;
|
|
||||||
// explicit bad_optional_access(const char* what_arg);
|
|
||||||
|
|
||||||
#include <experimental/optional>
|
|
||||||
#include <string>
|
|
||||||
#include <cstring>
|
|
||||||
#include <cassert>
|
|
||||||
|
|
||||||
int main()
|
|
||||||
{
|
|
||||||
#if _LIBCPP_STD_VER > 11
|
|
||||||
using std::experimental::bad_optional_access;
|
|
||||||
|
|
||||||
const char* s = "message";
|
|
||||||
bad_optional_access e(s);
|
|
||||||
assert(std::strcmp(e.what(), s) == 0);
|
|
||||||
#endif // _LIBCPP_STD_VER > 11
|
|
||||||
}
|
|
@@ -1,35 +0,0 @@
|
|||||||
//===----------------------------------------------------------------------===//
|
|
||||||
//
|
|
||||||
// The LLVM Compiler Infrastructure
|
|
||||||
//
|
|
||||||
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
||||||
// Source Licenses. See LICENSE.TXT for details.
|
|
||||||
//
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
|
|
||||||
// <optional>
|
|
||||||
|
|
||||||
// class bad_optional_access;
|
|
||||||
// bad_optional_access& operator=(const bad_optional_access&);
|
|
||||||
|
|
||||||
#include <experimental/optional>
|
|
||||||
#include <string>
|
|
||||||
#include <cstring>
|
|
||||||
#include <type_traits>
|
|
||||||
#include <cassert>
|
|
||||||
|
|
||||||
int main()
|
|
||||||
{
|
|
||||||
#if _LIBCPP_STD_VER > 11
|
|
||||||
using std::experimental::bad_optional_access;
|
|
||||||
|
|
||||||
static_assert(std::is_nothrow_copy_assignable<bad_optional_access>::value, "");
|
|
||||||
const std::string s1("one message");
|
|
||||||
const std::string s2("another message");
|
|
||||||
bad_optional_access e1(s1);
|
|
||||||
bad_optional_access e2(s2);
|
|
||||||
assert(std::strcmp(e1.what(), e2.what()) != 0);
|
|
||||||
e1 = e2;
|
|
||||||
assert(std::strcmp(e1.what(), e2.what()) == 0);
|
|
||||||
#endif // _LIBCPP_STD_VER > 11
|
|
||||||
}
|
|
@@ -1,32 +0,0 @@
|
|||||||
//===----------------------------------------------------------------------===//
|
|
||||||
//
|
|
||||||
// The LLVM Compiler Infrastructure
|
|
||||||
//
|
|
||||||
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
||||||
// Source Licenses. See LICENSE.TXT for details.
|
|
||||||
//
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
|
|
||||||
// <optional>
|
|
||||||
|
|
||||||
// class bad_optional_access;
|
|
||||||
// bad_optional_access(const bad_optional_access&);
|
|
||||||
|
|
||||||
#include <experimental/optional>
|
|
||||||
#include <string>
|
|
||||||
#include <cstring>
|
|
||||||
#include <type_traits>
|
|
||||||
#include <cassert>
|
|
||||||
|
|
||||||
int main()
|
|
||||||
{
|
|
||||||
#if _LIBCPP_STD_VER > 11
|
|
||||||
using std::experimental::bad_optional_access;
|
|
||||||
|
|
||||||
static_assert(std::is_nothrow_copy_constructible<bad_optional_access>::value, "");
|
|
||||||
const std::string s("another message");
|
|
||||||
bad_optional_access e1(s);
|
|
||||||
bad_optional_access e2 = e1;
|
|
||||||
assert(std::strcmp(e1.what(), e2.what()) == 0);
|
|
||||||
#endif // _LIBCPP_STD_VER > 11
|
|
||||||
}
|
|
@@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
// <optional>
|
// <optional>
|
||||||
|
|
||||||
// class bad_optional_access is not default constructible
|
// class bad_optional_access is default constructible
|
||||||
|
|
||||||
#include <experimental/optional>
|
#include <experimental/optional>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
@@ -18,7 +18,6 @@ int main()
|
|||||||
{
|
{
|
||||||
#if _LIBCPP_STD_VER > 11
|
#if _LIBCPP_STD_VER > 11
|
||||||
using std::experimental::bad_optional_access;
|
using std::experimental::bad_optional_access;
|
||||||
|
bad_optional_access ex;
|
||||||
static_assert(!std::is_default_constructible<bad_optional_access>::value, "");
|
|
||||||
#endif // _LIBCPP_STD_VER > 11
|
#endif // _LIBCPP_STD_VER > 11
|
||||||
}
|
}
|
||||||
|
@@ -1,29 +0,0 @@
|
|||||||
//===----------------------------------------------------------------------===//
|
|
||||||
//
|
|
||||||
// The LLVM Compiler Infrastructure
|
|
||||||
//
|
|
||||||
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
||||||
// Source Licenses. See LICENSE.TXT for details.
|
|
||||||
//
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
|
|
||||||
// <optional>
|
|
||||||
|
|
||||||
// class bad_optional_access;
|
|
||||||
// explicit bad_optional_access(const string& what_arg);
|
|
||||||
|
|
||||||
#include <experimental/optional>
|
|
||||||
#include <string>
|
|
||||||
#include <cstring>
|
|
||||||
#include <cassert>
|
|
||||||
|
|
||||||
int main()
|
|
||||||
{
|
|
||||||
#if _LIBCPP_STD_VER > 11
|
|
||||||
using std::experimental::bad_optional_access;
|
|
||||||
|
|
||||||
const std::string s("message");
|
|
||||||
bad_optional_access e(s);
|
|
||||||
assert(std::strcmp(e.what(), s.c_str()) == 0);
|
|
||||||
#endif // _LIBCPP_STD_VER > 11
|
|
||||||
}
|
|
@@ -38,21 +38,21 @@ int main()
|
|||||||
typedef optional<T> O;
|
typedef optional<T> O;
|
||||||
|
|
||||||
constexpr T val(2);
|
constexpr T val(2);
|
||||||
constexpr O o1; // disengaged
|
constexpr O o1; // disengaged
|
||||||
constexpr O o2{1}; // engaged
|
constexpr O o2{1}; // engaged
|
||||||
constexpr O o3{val}; // engaged
|
constexpr O o3{val}; // engaged
|
||||||
|
|
||||||
static_assert ( !(o1 == T(1)), "" );
|
static_assert ( !(o1 == T(1)), "" );
|
||||||
static_assert ( o2 == T(1), "" );
|
static_assert ( (o2 == T(1)), "" );
|
||||||
static_assert ( !(o3 == T(1)), "" );
|
static_assert ( !(o3 == T(1)), "" );
|
||||||
static_assert ( o3 == T(2) , "" );
|
static_assert ( (o3 == T(2)), "" );
|
||||||
static_assert ( o3 == val, "" );
|
static_assert ( (o3 == val), "" );
|
||||||
|
|
||||||
static_assert ( !(T(1) == o1), "" );
|
static_assert ( !(T(1) == o1), "" );
|
||||||
static_assert ( T(1) == o2, "" );
|
static_assert ( (T(1) == o2), "" );
|
||||||
static_assert ( !(T(1) == o3), "" );
|
static_assert ( !(T(1) == o3), "" );
|
||||||
static_assert ( T(2) == o3 , "" );
|
static_assert ( (T(2) == o3), "" );
|
||||||
static_assert ( val == o3 , "" );
|
static_assert ( (val == o3), "" );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,61 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator>(const optional<T>& x, const T& v);
|
||||||
|
// template <class T> constexpr bool operator>(const T& v, const optional<T>& x);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator < ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ < rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
{
|
||||||
|
typedef X T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr T val(2);
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
constexpr O o3{val}; // engaged
|
||||||
|
|
||||||
|
static_assert ( !(o1 > T(1)), "" );
|
||||||
|
static_assert ( !(o2 > T(1)), "" ); // equal
|
||||||
|
static_assert ( (o3 > T(1)), "" );
|
||||||
|
static_assert ( !(o2 > val), "" );
|
||||||
|
static_assert ( !(o3 > val), "" ); // equal
|
||||||
|
static_assert ( !(o3 > T(3)), "" );
|
||||||
|
|
||||||
|
static_assert ( (T(1) > o1), "" );
|
||||||
|
static_assert ( !(T(1) > o2), "" ); // equal
|
||||||
|
static_assert ( !(T(1) > o3), "" );
|
||||||
|
static_assert ( (val > o2), "" );
|
||||||
|
static_assert ( !(val > o3), "" ); // equal
|
||||||
|
static_assert ( (T(3) > o3), "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -0,0 +1,61 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator>=(const optional<T>& x, const T& v);
|
||||||
|
// template <class T> constexpr bool operator>=(const T& v, const optional<T>& x);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator < ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ < rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
{
|
||||||
|
typedef X T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr T val(2);
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
constexpr O o3{val}; // engaged
|
||||||
|
|
||||||
|
static_assert ( !(o1 >= T(1)), "" );
|
||||||
|
static_assert ( (o2 >= T(1)), "" ); // equal
|
||||||
|
static_assert ( (o3 >= T(1)), "" );
|
||||||
|
static_assert ( !(o2 >= val), "" );
|
||||||
|
static_assert ( (o3 >= val), "" ); // equal
|
||||||
|
static_assert ( !(o3 >= T(3)), "" );
|
||||||
|
|
||||||
|
static_assert ( (T(1) >= o1), "" );
|
||||||
|
static_assert ( (T(1) >= o2), "" ); // equal
|
||||||
|
static_assert ( !(T(1) >= o3), "" );
|
||||||
|
static_assert ( (val >= o2), "" );
|
||||||
|
static_assert ( (val >= o3), "" ); // equal
|
||||||
|
static_assert ( (T(3) >= o3), "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -0,0 +1,61 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator<=(const optional<T>& x, const T& v);
|
||||||
|
// template <class T> constexpr bool operator<=(const T& v, const optional<T>& x);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator < ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ < rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
{
|
||||||
|
typedef X T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr T val(2);
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
constexpr O o3{val}; // engaged
|
||||||
|
|
||||||
|
static_assert ( (o1 <= T(1)), "" );
|
||||||
|
static_assert ( (o2 <= T(1)), "" ); // equal
|
||||||
|
static_assert ( !(o3 <= T(1)), "" );
|
||||||
|
static_assert ( (o2 <= val), "" );
|
||||||
|
static_assert ( (o3 <= val), "" ); // equal
|
||||||
|
static_assert ( (o3 <= T(3)), "" );
|
||||||
|
|
||||||
|
static_assert ( !(T(1) <= o1), "" );
|
||||||
|
static_assert ( (T(1) <= o2), "" ); // equal
|
||||||
|
static_assert ( (T(1) <= o3), "" );
|
||||||
|
static_assert ( !(val <= o2), "" );
|
||||||
|
static_assert ( (val <= o3), "" ); // equal
|
||||||
|
static_assert ( !(T(3) <= o3), "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -39,22 +39,22 @@ int main()
|
|||||||
typedef optional<T> O;
|
typedef optional<T> O;
|
||||||
|
|
||||||
constexpr T val(2);
|
constexpr T val(2);
|
||||||
constexpr O o1; // disengaged
|
constexpr O o1; // disengaged
|
||||||
constexpr O o2{1}; // engaged
|
constexpr O o2{1}; // engaged
|
||||||
constexpr O o3{val}; // engaged
|
constexpr O o3{val}; // engaged
|
||||||
|
|
||||||
static_assert ( o1 < T(1) , "" );
|
static_assert ( (o1 < T(1)), "" );
|
||||||
static_assert ( !(o2 < T(1)), "" );
|
static_assert ( !(o2 < T(1)), "" ); // equal
|
||||||
static_assert ( !(o3 < T(1)), "" );
|
static_assert ( !(o3 < T(1)), "" );
|
||||||
static_assert ( o2 < T(2) , "" );
|
static_assert ( (o2 < val), "" );
|
||||||
static_assert ( o2 < T(val), "" );
|
static_assert ( !(o3 < val), "" ); // equal
|
||||||
static_assert ( o3 < T(3) , "" );
|
static_assert ( (o3 < T(3)), "" );
|
||||||
|
|
||||||
static_assert ( !(T(1) < o1), "" );
|
static_assert ( !(T(1) < o1), "" );
|
||||||
static_assert ( !(T(1) < o2), "" );
|
static_assert ( !(T(1) < o2), "" ); // equal
|
||||||
static_assert ( T(1) < o3 , "" );
|
static_assert ( (T(1) < o3), "" );
|
||||||
static_assert ( !(T(2) < o2), "" );
|
static_assert ( !(val < o2), "" );
|
||||||
static_assert (!(T(val) < o2), "" );
|
static_assert ( !(val < o3), "" ); // equal
|
||||||
static_assert ( !(T(3) < o3), "" );
|
static_assert ( !(T(3) < o3), "" );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@@ -0,0 +1,58 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator!=(const optional<T>& x, const T& v);
|
||||||
|
// template <class T> constexpr bool operator!=(const T& v, const optional<T>& x);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator == ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ == rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
{
|
||||||
|
typedef X T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr T val(2);
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
constexpr O o3{val}; // engaged
|
||||||
|
|
||||||
|
static_assert ( (o1 != T(1)), "" );
|
||||||
|
static_assert ( !(o2 != T(1)), "" );
|
||||||
|
static_assert ( (o3 != T(1)), "" );
|
||||||
|
static_assert ( !(o3 != T(2)), "" );
|
||||||
|
static_assert ( !(o3 != val), "" );
|
||||||
|
|
||||||
|
static_assert ( (T(1) != o1), "" );
|
||||||
|
static_assert ( !(T(1) != o2), "" );
|
||||||
|
static_assert ( (T(1) != o3), "" );
|
||||||
|
static_assert ( !(T(2) != o3), "" );
|
||||||
|
static_assert ( !(val != o3), "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -29,9 +29,9 @@ int main()
|
|||||||
constexpr O o1; // disengaged
|
constexpr O o1; // disengaged
|
||||||
constexpr O o2{1}; // engaged
|
constexpr O o2{1}; // engaged
|
||||||
|
|
||||||
static_assert ( nullopt == o1 , "" );
|
static_assert ( (nullopt == o1), "" );
|
||||||
static_assert ( !(nullopt == o2), "" );
|
static_assert ( !(nullopt == o2), "" );
|
||||||
static_assert ( o1 == nullopt , "" );
|
static_assert ( (o1 == nullopt), "" );
|
||||||
static_assert ( !(o2 == nullopt), "" );
|
static_assert ( !(o2 == nullopt), "" );
|
||||||
|
|
||||||
static_assert (noexcept(nullopt == o1), "");
|
static_assert (noexcept(nullopt == o1), "");
|
41
test/utilities/optional/optional.nullops/greater.pass.cpp
Normal file
41
test/utilities/optional/optional.nullops/greater.pass.cpp
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator>(const optional<T>& x, nullopt_t) noexcept;
|
||||||
|
// template <class T> constexpr bool operator>(nullopt_t, const optional<T>& x) noexcept;
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
using std::experimental::optional;
|
||||||
|
using std::experimental::nullopt_t;
|
||||||
|
using std::experimental::nullopt;
|
||||||
|
|
||||||
|
{
|
||||||
|
typedef int T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( !(nullopt > o1), "" );
|
||||||
|
static_assert ( !(nullopt > o2), "" );
|
||||||
|
static_assert ( !(o1 > nullopt), "" );
|
||||||
|
static_assert ( (o2 > nullopt), "" );
|
||||||
|
|
||||||
|
static_assert (noexcept(nullopt > o1), "");
|
||||||
|
static_assert (noexcept(o1 > nullopt), "");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -0,0 +1,41 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator>=(const optional<T>& x, nullopt_t) noexcept;
|
||||||
|
// template <class T> constexpr bool operator>=(nullopt_t, const optional<T>& x) noexcept;
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
using std::experimental::optional;
|
||||||
|
using std::experimental::nullopt_t;
|
||||||
|
using std::experimental::nullopt;
|
||||||
|
|
||||||
|
{
|
||||||
|
typedef int T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( (nullopt >= o1), "" );
|
||||||
|
static_assert ( !(nullopt >= o2), "" );
|
||||||
|
static_assert ( (o1 >= nullopt), "" );
|
||||||
|
static_assert ( (o2 >= nullopt), "" );
|
||||||
|
|
||||||
|
static_assert (noexcept(nullopt >= o1), "");
|
||||||
|
static_assert (noexcept(o1 >= nullopt), "");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
41
test/utilities/optional/optional.nullops/less_equal.pass.cpp
Normal file
41
test/utilities/optional/optional.nullops/less_equal.pass.cpp
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator<=(const optional<T>& x, nullopt_t) noexcept;
|
||||||
|
// template <class T> constexpr bool operator<=(nullopt_t, const optional<T>& x) noexcept;
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
using std::experimental::optional;
|
||||||
|
using std::experimental::nullopt_t;
|
||||||
|
using std::experimental::nullopt;
|
||||||
|
|
||||||
|
{
|
||||||
|
typedef int T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( (nullopt <= o1), "" );
|
||||||
|
static_assert ( (nullopt <= o2), "" );
|
||||||
|
static_assert ( (o1 <= nullopt), "" );
|
||||||
|
static_assert ( !(o2 <= nullopt), "" );
|
||||||
|
|
||||||
|
static_assert (noexcept(nullopt <= o1), "");
|
||||||
|
static_assert (noexcept(o1 <= nullopt), "");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -30,7 +30,7 @@ int main()
|
|||||||
constexpr O o2{1}; // engaged
|
constexpr O o2{1}; // engaged
|
||||||
|
|
||||||
static_assert ( !(nullopt < o1), "" );
|
static_assert ( !(nullopt < o1), "" );
|
||||||
static_assert ( nullopt < o2 , "" );
|
static_assert ( (nullopt < o2), "" );
|
||||||
static_assert ( !(o1 < nullopt), "" );
|
static_assert ( !(o1 < nullopt), "" );
|
||||||
static_assert ( !(o2 < nullopt), "" );
|
static_assert ( !(o2 < nullopt), "" );
|
||||||
|
|
||||||
|
41
test/utilities/optional/optional.nullops/not_equal.pass.cpp
Normal file
41
test/utilities/optional/optional.nullops/not_equal.pass.cpp
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator!=(const optional<T>& x, nullopt_t) noexcept;
|
||||||
|
// template <class T> constexpr bool operator!=(nullopt_t, const optional<T>& x) noexcept;
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
using std::experimental::optional;
|
||||||
|
using std::experimental::nullopt_t;
|
||||||
|
using std::experimental::nullopt;
|
||||||
|
|
||||||
|
{
|
||||||
|
typedef int T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( !(nullopt != o1), "" );
|
||||||
|
static_assert ( (nullopt != o2), "" );
|
||||||
|
static_assert ( !(o1 != nullopt), "" );
|
||||||
|
static_assert ( (o2 != nullopt), "" );
|
||||||
|
|
||||||
|
static_assert (noexcept(nullopt != o1), "");
|
||||||
|
static_assert (noexcept(o1 != nullopt), "");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -0,0 +1,75 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator>= (const optional<T>& x, const optional<T>& y);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator < ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ < rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
{
|
||||||
|
typedef optional<X> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2; // disengaged
|
||||||
|
constexpr O o3{1}; // engaged
|
||||||
|
constexpr O o4{2}; // engaged
|
||||||
|
constexpr O o5{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( (o1 >= o1), "" );
|
||||||
|
static_assert ( (o1 >= o2), "" );
|
||||||
|
static_assert ( !(o1 >= o3), "" );
|
||||||
|
static_assert ( !(o1 >= o4), "" );
|
||||||
|
static_assert ( !(o1 >= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o2 >= o1), "" );
|
||||||
|
static_assert ( (o2 >= o2), "" );
|
||||||
|
static_assert ( !(o2 >= o3), "" );
|
||||||
|
static_assert ( !(o2 >= o4), "" );
|
||||||
|
static_assert ( !(o2 >= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o3 >= o1), "" );
|
||||||
|
static_assert ( (o3 >= o2), "" );
|
||||||
|
static_assert ( (o3 >= o3), "" );
|
||||||
|
static_assert ( !(o3 >= o4), "" );
|
||||||
|
static_assert ( (o3 >= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o4 >= o1), "" );
|
||||||
|
static_assert ( (o4 >= o2), "" );
|
||||||
|
static_assert ( (o4 >= o3), "" );
|
||||||
|
static_assert ( (o4 >= o4), "" );
|
||||||
|
static_assert ( (o4 >= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o5 >= o1), "" );
|
||||||
|
static_assert ( (o5 >= o2), "" );
|
||||||
|
static_assert ( (o5 >= o3), "" );
|
||||||
|
static_assert ( !(o5 >= o4), "" );
|
||||||
|
static_assert ( (o5 >= o5), "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -0,0 +1,75 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator> (const optional<T>& x, const optional<T>& y);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator < ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ < rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
{
|
||||||
|
typedef optional<X> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2; // disengaged
|
||||||
|
constexpr O o3{1}; // engaged
|
||||||
|
constexpr O o4{2}; // engaged
|
||||||
|
constexpr O o5{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( !(o1 > o1), "" );
|
||||||
|
static_assert ( !(o1 > o2), "" );
|
||||||
|
static_assert ( !(o1 > o3), "" );
|
||||||
|
static_assert ( !(o1 > o4), "" );
|
||||||
|
static_assert ( !(o1 > o5), "" );
|
||||||
|
|
||||||
|
static_assert ( !(o2 > o1), "" );
|
||||||
|
static_assert ( !(o2 > o2), "" );
|
||||||
|
static_assert ( !(o2 > o3), "" );
|
||||||
|
static_assert ( !(o2 > o4), "" );
|
||||||
|
static_assert ( !(o2 > o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o3 > o1), "" );
|
||||||
|
static_assert ( (o3 > o2), "" );
|
||||||
|
static_assert ( !(o3 > o3), "" );
|
||||||
|
static_assert ( !(o3 > o4), "" );
|
||||||
|
static_assert ( !(o3 > o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o4 > o1), "" );
|
||||||
|
static_assert ( (o4 > o2), "" );
|
||||||
|
static_assert ( (o4 > o3), "" );
|
||||||
|
static_assert ( !(o4 > o4), "" );
|
||||||
|
static_assert ( (o4 > o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o5 > o1), "" );
|
||||||
|
static_assert ( (o5 > o2), "" );
|
||||||
|
static_assert ( !(o5 > o3), "" );
|
||||||
|
static_assert ( !(o5 > o4), "" );
|
||||||
|
static_assert ( !(o5 > o5), "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
75
test/utilities/optional/optional.relops/less_equal.pass.cpp
Normal file
75
test/utilities/optional/optional.relops/less_equal.pass.cpp
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator<= (const optional<T>& x, const optional<T>& y);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator < ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ < rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
{
|
||||||
|
typedef optional<X> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2; // disengaged
|
||||||
|
constexpr O o3{1}; // engaged
|
||||||
|
constexpr O o4{2}; // engaged
|
||||||
|
constexpr O o5{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( (o1 <= o1), "" );
|
||||||
|
static_assert ( (o1 <= o2), "" );
|
||||||
|
static_assert ( (o1 <= o3), "" );
|
||||||
|
static_assert ( (o1 <= o4), "" );
|
||||||
|
static_assert ( (o1 <= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o2 <= o1), "" );
|
||||||
|
static_assert ( (o2 <= o2), "" );
|
||||||
|
static_assert ( (o2 <= o3), "" );
|
||||||
|
static_assert ( (o2 <= o4), "" );
|
||||||
|
static_assert ( (o2 <= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( !(o3 <= o1), "" );
|
||||||
|
static_assert ( !(o3 <= o2), "" );
|
||||||
|
static_assert ( (o3 <= o3), "" );
|
||||||
|
static_assert ( (o3 <= o4), "" );
|
||||||
|
static_assert ( (o3 <= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( !(o4 <= o1), "" );
|
||||||
|
static_assert ( !(o4 <= o2), "" );
|
||||||
|
static_assert ( !(o4 <= o3), "" );
|
||||||
|
static_assert ( (o4 <= o4), "" );
|
||||||
|
static_assert ( !(o4 <= o5), "" );
|
||||||
|
|
||||||
|
static_assert ( !(o5 <= o1), "" );
|
||||||
|
static_assert ( !(o5 <= o2), "" );
|
||||||
|
static_assert ( (o5 <= o3), "" );
|
||||||
|
static_assert ( (o5 <= o4), "" );
|
||||||
|
static_assert ( (o5 <= o5), "" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
@@ -43,20 +43,20 @@ int main()
|
|||||||
|
|
||||||
static_assert ( !(o1 < o1), "" );
|
static_assert ( !(o1 < o1), "" );
|
||||||
static_assert ( !(o1 < o2), "" );
|
static_assert ( !(o1 < o2), "" );
|
||||||
static_assert ( o1 < o3 , "" );
|
static_assert ( (o1 < o3), "" );
|
||||||
static_assert ( o1 < o4 , "" );
|
static_assert ( (o1 < o4), "" );
|
||||||
static_assert ( o1 < o5 , "" );
|
static_assert ( (o1 < o5), "" );
|
||||||
|
|
||||||
static_assert ( !(o2 < o1), "" );
|
static_assert ( !(o2 < o1), "" );
|
||||||
static_assert ( !(o2 < o2), "" );
|
static_assert ( !(o2 < o2), "" );
|
||||||
static_assert ( o2 < o3 , "" );
|
static_assert ( (o2 < o3), "" );
|
||||||
static_assert ( o2 < o4 , "" );
|
static_assert ( (o2 < o4), "" );
|
||||||
static_assert ( o2 < o5 , "" );
|
static_assert ( (o2 < o5), "" );
|
||||||
|
|
||||||
static_assert ( !(o3 < o1), "" );
|
static_assert ( !(o3 < o1), "" );
|
||||||
static_assert ( !(o3 < o2), "" );
|
static_assert ( !(o3 < o2), "" );
|
||||||
static_assert ( !(o3 < o3), "" );
|
static_assert ( !(o3 < o3), "" );
|
||||||
static_assert ( o3 < o4 , "" );
|
static_assert ( (o3 < o4), "" );
|
||||||
static_assert ( !(o3 < o5), "" );
|
static_assert ( !(o3 < o5), "" );
|
||||||
|
|
||||||
static_assert ( !(o4 < o1), "" );
|
static_assert ( !(o4 < o1), "" );
|
||||||
@@ -68,7 +68,7 @@ int main()
|
|||||||
static_assert ( !(o5 < o1), "" );
|
static_assert ( !(o5 < o1), "" );
|
||||||
static_assert ( !(o5 < o2), "" );
|
static_assert ( !(o5 < o2), "" );
|
||||||
static_assert ( !(o5 < o3), "" );
|
static_assert ( !(o5 < o3), "" );
|
||||||
static_assert ( o5 < o4 , "" );
|
static_assert ( (o5 < o4), "" );
|
||||||
static_assert ( !(o5 < o5), "" );
|
static_assert ( !(o5 < o5), "" );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
79
test/utilities/optional/optional.relops/not_equal.pass.cpp
Normal file
79
test/utilities/optional/optional.relops/not_equal.pass.cpp
Normal file
@@ -0,0 +1,79 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <optional>
|
||||||
|
|
||||||
|
// template <class T> constexpr bool operator!=(const optional<T>& x, const optional<T>& y);
|
||||||
|
|
||||||
|
#include <experimental/optional>
|
||||||
|
#include <type_traits>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
|
||||||
|
using std::experimental::optional;
|
||||||
|
|
||||||
|
struct X
|
||||||
|
{
|
||||||
|
int i_;
|
||||||
|
|
||||||
|
constexpr X(int i) : i_(i) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
constexpr bool operator == ( const X &lhs, const X &rhs )
|
||||||
|
{ return lhs.i_ == rhs.i_ ; }
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
#if _LIBCPP_STD_VER > 11
|
||||||
|
{
|
||||||
|
typedef X T;
|
||||||
|
typedef optional<T> O;
|
||||||
|
|
||||||
|
constexpr O o1; // disengaged
|
||||||
|
constexpr O o2; // disengaged
|
||||||
|
constexpr O o3{1}; // engaged
|
||||||
|
constexpr O o4{2}; // engaged
|
||||||
|
constexpr O o5{1}; // engaged
|
||||||
|
|
||||||
|
static_assert ( !(o1 != o1), "" );
|
||||||
|
static_assert ( !(o1 != o2), "" );
|
||||||
|
static_assert ( (o1 != o3), "" );
|
||||||
|
static_assert ( (o1 != o4), "" );
|
||||||
|
static_assert ( (o1 != o5), "" );
|
||||||
|
|
||||||
|
static_assert ( !(o2 != o1), "" );
|
||||||
|
static_assert ( !(o2 != o2), "" );
|
||||||
|
static_assert ( (o2 != o3), "" );
|
||||||
|
static_assert ( (o2 != o4), "" );
|
||||||
|
static_assert ( (o2 != o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o3 != o1), "" );
|
||||||
|
static_assert ( (o3 != o2), "" );
|
||||||
|
static_assert ( !(o3 != o3), "" );
|
||||||
|
static_assert ( (o3 != o4), "" );
|
||||||
|
static_assert ( !(o3 != o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o4 != o1), "" );
|
||||||
|
static_assert ( (o4 != o2), "" );
|
||||||
|
static_assert ( (o4 != o3), "" );
|
||||||
|
static_assert ( !(o4 != o4), "" );
|
||||||
|
static_assert ( (o4 != o5), "" );
|
||||||
|
|
||||||
|
static_assert ( (o5 != o1), "" );
|
||||||
|
static_assert ( (o5 != o2), "" );
|
||||||
|
static_assert ( !(o5 != o3), "" );
|
||||||
|
static_assert ( (o5 != o4), "" );
|
||||||
|
static_assert ( !(o5 != o5), "" );
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
Reference in New Issue
Block a user