mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-08 12:26:10 +00:00

test/std/containers/Emplaceable.h test/std/containers/NotConstructible.h test/support/counting_predicates.hpp Replace unary_function/binary_function inheritance with typedefs. test/std/depr/depr.function.objects/depr.base/binary_function.pass.cpp test/std/depr/depr.function.objects/depr.base/unary_function.pass.cpp test/std/utilities/function.objects/func.require/binary_function.pass.cpp test/std/utilities/function.objects/func.require/unary_function.pass.cpp Mark these tests as requiring 98/03/11/14 because 17 removed unary_function/binary_function. test/std/thread/futures/futures.task/futures.task.members/ctor_func_alloc.pass.cpp test/std/thread/futures/futures.task/futures.task.nonmembers/uses_allocator.pass.cpp Mark these tests as requiring 11/14 because 17 removed packaged_task allocator support. test/std/utilities/function.objects/func.wrap/func.wrap.func/derive_from.pass.cpp This test doesn't need to be skipped in C++17 mode. Only the construction of std::function from an allocator needs to be skipped in C++17 mode. test/std/utilities/function.objects/refwrap/refwrap.access/conversion.pass.cpp test/std/utilities/function.objects/refwrap/refwrap.assign/copy_assign.pass.cpp test/std/utilities/function.objects/refwrap/refwrap.const/copy_ctor.pass.cpp test/std/utilities/function.objects/refwrap/refwrap.const/type_ctor.pass.cpp When testing these reference_wrapper features, unary_function inheritance is totally irrelevant. test/std/utilities/function.objects/refwrap/weak_result.pass.cpp Define and use my_unary_function/my_binary_function to test the weak result type machinery (which is still present in C++17, although deprecated). test/support/msvc_stdlib_force_include.hpp Now we can test C++17 strictly, without enabling removed features. Fixes D36503. llvm-svn: 311705
98 lines
3.1 KiB
C++
98 lines
3.1 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// <functional>
|
|
|
|
// reference_wrapper
|
|
|
|
// has weak result type
|
|
|
|
#include <functional>
|
|
#include <type_traits>
|
|
|
|
template <class Arg, class Result>
|
|
struct my_unary_function
|
|
{ // std::unary_function was removed in C++17
|
|
typedef Arg argument_type;
|
|
typedef Result result_type;
|
|
};
|
|
|
|
template <class Arg1, class Arg2, class Result>
|
|
struct my_binary_function
|
|
{ // std::binary_function was removed in C++17
|
|
typedef Arg1 first_argument_type;
|
|
typedef Arg2 second_argument_type;
|
|
typedef Result result_type;
|
|
};
|
|
|
|
class functor1
|
|
: public my_unary_function<int, char>
|
|
{
|
|
};
|
|
|
|
class functor2
|
|
: public my_binary_function<char, int, double>
|
|
{
|
|
};
|
|
|
|
class functor3
|
|
: public my_unary_function<char, int>,
|
|
public my_binary_function<char, int, double>
|
|
{
|
|
public:
|
|
typedef float result_type;
|
|
};
|
|
|
|
class functor4
|
|
: public my_unary_function<char, int>,
|
|
public my_binary_function<char, int, double>
|
|
{
|
|
public:
|
|
};
|
|
|
|
class C {};
|
|
|
|
template <class T>
|
|
struct has_result_type
|
|
{
|
|
private:
|
|
struct two {char _; char __;};
|
|
template <class U> static two test(...);
|
|
template <class U> static char test(typename U::result_type* = 0);
|
|
public:
|
|
static const bool value = sizeof(test<T>(0)) == 1;
|
|
};
|
|
|
|
int main()
|
|
{
|
|
static_assert((std::is_same<std::reference_wrapper<functor1>::result_type,
|
|
char>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<functor2>::result_type,
|
|
double>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<functor3>::result_type,
|
|
float>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<void()>::result_type,
|
|
void>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<int*(double*)>::result_type,
|
|
int*>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<void(*)()>::result_type,
|
|
void>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<int*(*)(double*)>::result_type,
|
|
int*>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<int*(C::*)(double*)>::result_type,
|
|
int*>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<int (C::*)(double*) const volatile>::result_type,
|
|
int>::value), "");
|
|
static_assert((std::is_same<std::reference_wrapper<C()>::result_type,
|
|
C>::value), "");
|
|
static_assert(has_result_type<std::reference_wrapper<functor3> >::value, "");
|
|
static_assert(!has_result_type<std::reference_wrapper<functor4> >::value, "");
|
|
static_assert(!has_result_type<std::reference_wrapper<C> >::value, "");
|
|
}
|