forked from boostorg/system
Use unsafe_get instead of *get_if
This commit is contained in:
@@ -176,11 +176,11 @@ public:
|
|||||||
{
|
{
|
||||||
if( has_value() )
|
if( has_value() )
|
||||||
{
|
{
|
||||||
return *variant2::get_if<0>( &v_ );
|
return variant2::unsafe_get<0>( v_ );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw_exception_from_error_code( *variant2::get_if<1>( &v_ ) );
|
throw_exception_from_error_code( variant2::unsafe_get<1>( v_ ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -190,11 +190,11 @@ public:
|
|||||||
{
|
{
|
||||||
if( has_value() )
|
if( has_value() )
|
||||||
{
|
{
|
||||||
return *variant2::get_if<0>( &v_ );
|
return variant2::unsafe_get<0>( v_ );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw_exception_from_error_code( *variant2::get_if<1>( &v_ ) );
|
throw_exception_from_error_code( variant2::unsafe_get<1>( v_ ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -202,11 +202,11 @@ public:
|
|||||||
{
|
{
|
||||||
if( has_value() )
|
if( has_value() )
|
||||||
{
|
{
|
||||||
return *variant2::get_if<0>( &v_ );
|
return variant2::unsafe_get<0>( v_ );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw_exception_from_error_code( *variant2::get_if<1>( &v_ ) );
|
throw_exception_from_error_code( variant2::unsafe_get<1>( v_ ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -288,11 +288,10 @@ public:
|
|||||||
|
|
||||||
// error access
|
// error access
|
||||||
|
|
||||||
BOOST_CXX14_CONSTEXPR E error() const
|
constexpr E error() const
|
||||||
noexcept( std::is_nothrow_default_constructible<E>::value && std::is_nothrow_copy_constructible<E>::value )
|
noexcept( std::is_nothrow_default_constructible<E>::value && std::is_nothrow_copy_constructible<E>::value )
|
||||||
{
|
{
|
||||||
E const * p = variant2::get_if<1>( &v_ );
|
return has_error()? variant2::unsafe_get<1>( v_ ): E();
|
||||||
return p? *p: E();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// swap
|
// swap
|
||||||
|
Reference in New Issue
Block a user