I've seen this question enough times to know that it should be fixed: http://stackoverflow.com/questions/6193734/implicit-conversions-with-stdfunction
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@132363 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f0562af9dd
commit
083ba5f5ca
@ -1101,6 +1101,21 @@ class _LIBCPP_VISIBLE function<_R(_ArgTypes...)>
|
|||||||
template <class _R2, class ..._A>
|
template <class _R2, class ..._A>
|
||||||
_LIBCPP_INLINE_VISIBILITY
|
_LIBCPP_INLINE_VISIBILITY
|
||||||
static bool __not_null(const function<_R(_A...)>& __p) {return __p;}
|
static bool __not_null(const function<_R(_A...)>& __p) {return __p;}
|
||||||
|
|
||||||
|
template <class _F, bool = __invokable<_F&, _ArgTypes...>::value>
|
||||||
|
struct __callable;
|
||||||
|
template <class _F>
|
||||||
|
struct __callable<_F, true>
|
||||||
|
{
|
||||||
|
static const bool value =
|
||||||
|
is_convertible<typename __invoke_of<_F&, _ArgTypes...>::type,
|
||||||
|
_R>::value;
|
||||||
|
};
|
||||||
|
template <class _F>
|
||||||
|
struct __callable<_F, false>
|
||||||
|
{
|
||||||
|
static const bool value = false;
|
||||||
|
};
|
||||||
public:
|
public:
|
||||||
typedef _R result_type;
|
typedef _R result_type;
|
||||||
|
|
||||||
@ -1113,7 +1128,7 @@ public:
|
|||||||
function(function&&) _NOEXCEPT;
|
function(function&&) _NOEXCEPT;
|
||||||
template<class _F>
|
template<class _F>
|
||||||
function(_F,
|
function(_F,
|
||||||
typename enable_if<!is_integral<_F>::value>::type* = 0);
|
typename enable_if<__callable<_F>::value>::type* = 0);
|
||||||
|
|
||||||
template<class _Alloc>
|
template<class _Alloc>
|
||||||
_LIBCPP_INLINE_VISIBILITY
|
_LIBCPP_INLINE_VISIBILITY
|
||||||
@ -1127,7 +1142,7 @@ public:
|
|||||||
function(allocator_arg_t, const _Alloc&, function&&);
|
function(allocator_arg_t, const _Alloc&, function&&);
|
||||||
template<class _F, class _Alloc>
|
template<class _F, class _Alloc>
|
||||||
function(allocator_arg_t, const _Alloc& __a, _F __f,
|
function(allocator_arg_t, const _Alloc& __a, _F __f,
|
||||||
typename enable_if<!is_integral<_F>::value>::type* = 0);
|
typename enable_if<__callable<_F>::value>::type* = 0);
|
||||||
|
|
||||||
function& operator=(const function&);
|
function& operator=(const function&);
|
||||||
function& operator=(function&&) _NOEXCEPT;
|
function& operator=(function&&) _NOEXCEPT;
|
||||||
@ -1135,7 +1150,7 @@ public:
|
|||||||
template<class _F>
|
template<class _F>
|
||||||
typename enable_if
|
typename enable_if
|
||||||
<
|
<
|
||||||
!is_integral<typename decay<_F>::type>::value,
|
__callable<typename decay<_F>::type>::value,
|
||||||
function&
|
function&
|
||||||
>::type
|
>::type
|
||||||
operator=(_F&&);
|
operator=(_F&&);
|
||||||
@ -1239,7 +1254,7 @@ function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc&,
|
|||||||
template<class _R, class ..._ArgTypes>
|
template<class _R, class ..._ArgTypes>
|
||||||
template <class _F>
|
template <class _F>
|
||||||
function<_R(_ArgTypes...)>::function(_F __f,
|
function<_R(_ArgTypes...)>::function(_F __f,
|
||||||
typename enable_if<!is_integral<_F>::value>::type*)
|
typename enable_if<__callable<_F>::value>::type*)
|
||||||
: __f_(0)
|
: __f_(0)
|
||||||
{
|
{
|
||||||
if (__not_null(__f))
|
if (__not_null(__f))
|
||||||
@ -1265,7 +1280,7 @@ function<_R(_ArgTypes...)>::function(_F __f,
|
|||||||
template<class _R, class ..._ArgTypes>
|
template<class _R, class ..._ArgTypes>
|
||||||
template <class _F, class _Alloc>
|
template <class _F, class _Alloc>
|
||||||
function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc& __a0, _F __f,
|
function<_R(_ArgTypes...)>::function(allocator_arg_t, const _Alloc& __a0, _F __f,
|
||||||
typename enable_if<!is_integral<_F>::value>::type*)
|
typename enable_if<__callable<_F>::value>::type*)
|
||||||
: __f_(0)
|
: __f_(0)
|
||||||
{
|
{
|
||||||
typedef allocator_traits<_Alloc> __alloc_traits;
|
typedef allocator_traits<_Alloc> __alloc_traits;
|
||||||
@ -1341,7 +1356,7 @@ template<class _R, class ..._ArgTypes>
|
|||||||
template <class _F>
|
template <class _F>
|
||||||
typename enable_if
|
typename enable_if
|
||||||
<
|
<
|
||||||
!is_integral<typename decay<_F>::type>::value,
|
function<_R(_ArgTypes...)>::template __callable<typename decay<_F>::type>::value,
|
||||||
function<_R(_ArgTypes...)>&
|
function<_R(_ArgTypes...)>&
|
||||||
>::type
|
>::type
|
||||||
function<_R(_ArgTypes...)>::operator=(_F&& __f)
|
function<_R(_ArgTypes...)>::operator=(_F&& __f)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user