Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why is boost::optional<T> not convertable to bool for the purposes of std::is_convertible

I have

auto result = std::is_convertible
    < boost::optional<int>
    , bool
    >::value;

static_assert( result , "task should return bool" );

and it fails to compile. The definition of std::is_convertible is

template< class From, class To > struct is_convertible;

and optional is clearly convertible to boolean because we always use it like

void(boost::optional<int> const & value){
    if(value){
        std::cerr << *value << endl; 
    }
}

what am I missing here?

like image 881
bradgonesurfing Avatar asked Dec 24 '22 03:12

bradgonesurfing


1 Answers

boost::optional's operator bool is explicit. It works inside an if's condition, because it is a contextual conversion.

You need std::is_constructible, which tries to perform an explicit conversion.

The following compiles

static_assert
    ( std::is_constructible<bool, boost::optional<int>>::value
    , "msg" );

and the following fails to compile because optional is not convertible to int

static_assert
    ( std::is_constructible<int, boost::optional<int>>::value
    , "msg" );
like image 113
Quentin Avatar answered May 15 '23 05:05

Quentin