diff options
author | Eric Fiselier <eric@efcs.ca> | 2016-04-29 01:52:57 +0000 |
---|---|---|
committer | Eric Fiselier <eric@efcs.ca> | 2016-04-29 01:52:57 +0000 |
commit | bc32b5cf8f4c9f8243fe7b914500bee3bb6473c0 (patch) | |
tree | cc493034da7df997456de8aae718100e9f2dd052 | |
parent | 6eee9061ac1ce26c7a882faf6bb69c73ad332fa0 (diff) | |
download | bcm5719-llvm-bc32b5cf8f4c9f8243fe7b914500bee3bb6473c0.tar.gz bcm5719-llvm-bc32b5cf8f4c9f8243fe7b914500bee3bb6473c0.zip |
Move INVOKE tests into test/libcxx sub-tree.
Testing the concrete implementation of INVOKE means calling the implementation
specific names `__invoke` and `__invoke_constexpr`. For this reason the test
are non-standard. For this reason it's best if the tests live outside of the
`test/std` directory.
llvm-svn: 267973
-rw-r--r-- | libcxx/test/libcxx/utilities/function.objects/func.require/bullet_1_2_3.pass.cpp (renamed from libcxx/test/std/utilities/function.objects/func.require/bullet_1_2_3.pass.cpp) | 0 | ||||
-rw-r--r-- | libcxx/test/libcxx/utilities/function.objects/func.require/bullet_4_5_6.pass.cpp (renamed from libcxx/test/std/utilities/function.objects/func.require/bullet_4_5_6.pass.cpp) | 0 | ||||
-rw-r--r-- | libcxx/test/libcxx/utilities/function.objects/func.require/bullet_7.pass.cpp (renamed from libcxx/test/std/utilities/function.objects/func.require/bullet_7.pass.cpp) | 0 | ||||
-rw-r--r-- | libcxx/test/libcxx/utilities/function.objects/func.require/invoke.pass.cpp (renamed from libcxx/test/std/utilities/function.objects/func.require/invoke.pass.cpp) | 15 | ||||
-rw-r--r-- | libcxx/test/libcxx/utilities/function.objects/func.require/invoke_helpers.h (renamed from libcxx/test/std/utilities/function.objects/func.require/invoke_helpers.h) | 0 | ||||
-rw-r--r-- | libcxx/test/std/utilities/function.objects/func.require/INVOKE_tested_elsewhere.pass.cpp | 16 |
6 files changed, 21 insertions, 10 deletions
diff --git a/libcxx/test/std/utilities/function.objects/func.require/bullet_1_2_3.pass.cpp b/libcxx/test/libcxx/utilities/function.objects/func.require/bullet_1_2_3.pass.cpp index 509c751b455..509c751b455 100644 --- a/libcxx/test/std/utilities/function.objects/func.require/bullet_1_2_3.pass.cpp +++ b/libcxx/test/libcxx/utilities/function.objects/func.require/bullet_1_2_3.pass.cpp diff --git a/libcxx/test/std/utilities/function.objects/func.require/bullet_4_5_6.pass.cpp b/libcxx/test/libcxx/utilities/function.objects/func.require/bullet_4_5_6.pass.cpp index 803c501f8c9..803c501f8c9 100644 --- a/libcxx/test/std/utilities/function.objects/func.require/bullet_4_5_6.pass.cpp +++ b/libcxx/test/libcxx/utilities/function.objects/func.require/bullet_4_5_6.pass.cpp diff --git a/libcxx/test/std/utilities/function.objects/func.require/bullet_7.pass.cpp b/libcxx/test/libcxx/utilities/function.objects/func.require/bullet_7.pass.cpp index 0d14a350c89..0d14a350c89 100644 --- a/libcxx/test/std/utilities/function.objects/func.require/bullet_7.pass.cpp +++ b/libcxx/test/libcxx/utilities/function.objects/func.require/bullet_7.pass.cpp diff --git a/libcxx/test/std/utilities/function.objects/func.require/invoke.pass.cpp b/libcxx/test/libcxx/utilities/function.objects/func.require/invoke.pass.cpp index 25681630a80..1d4251354dc 100644 --- a/libcxx/test/std/utilities/function.objects/func.require/invoke.pass.cpp +++ b/libcxx/test/libcxx/utilities/function.objects/func.require/invoke.pass.cpp @@ -9,12 +9,10 @@ // [func.require] -// INVOKE -#if __cplusplus < 201103L -int main () {} // no __invoke in C++03 -#else - #include <type_traits> +#include <functional> + +#include "test_macros.h" template <typename T, int N> struct Array @@ -26,10 +24,9 @@ struct Type { Array<char, 1>::type& f1(); Array<char, 2>::type& f2() const; - +#if TEST_STD_VER >= 11 Array<char, 1>::type& g1() &; Array<char, 2>::type& g2() const &; -#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES Array<char, 3>::type& g3() &&; Array<char, 4>::type& g4() const &&; #endif @@ -39,12 +36,10 @@ int main() { static_assert(sizeof(std::__invoke(&Type::f1, std::declval<Type >())) == 1, ""); static_assert(sizeof(std::__invoke(&Type::f2, std::declval<Type const >())) == 2, ""); - +#if TEST_STD_VER >= 11 static_assert(sizeof(std::__invoke(&Type::g1, std::declval<Type &>())) == 1, ""); static_assert(sizeof(std::__invoke(&Type::g2, std::declval<Type const &>())) == 2, ""); -#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES static_assert(sizeof(std::__invoke(&Type::g3, std::declval<Type &&>())) == 3, ""); static_assert(sizeof(std::__invoke(&Type::g4, std::declval<Type const&&>())) == 4, ""); #endif } -#endif diff --git a/libcxx/test/std/utilities/function.objects/func.require/invoke_helpers.h b/libcxx/test/libcxx/utilities/function.objects/func.require/invoke_helpers.h index 7e7a5fd24a6..7e7a5fd24a6 100644 --- a/libcxx/test/std/utilities/function.objects/func.require/invoke_helpers.h +++ b/libcxx/test/libcxx/utilities/function.objects/func.require/invoke_helpers.h diff --git a/libcxx/test/std/utilities/function.objects/func.require/INVOKE_tested_elsewhere.pass.cpp b/libcxx/test/std/utilities/function.objects/func.require/INVOKE_tested_elsewhere.pass.cpp new file mode 100644 index 00000000000..d61c3773e53 --- /dev/null +++ b/libcxx/test/std/utilities/function.objects/func.require/INVOKE_tested_elsewhere.pass.cpp @@ -0,0 +1,16 @@ +//===----------------------------------------------------------------------===// +// +// 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. +// +//===----------------------------------------------------------------------===// + +// INVOKE (f, t1, t2, ..., tN) + +// The tests for INVOKE (f, t1, t2, ..., tN) live in the "test/libcxx" tree +// since they require calling the implementation specific "__invoke" and +// "__invoke_constexpr" functions. + +int main() {} |