mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 03:32:35 +08:00

Quite a few libcxx tests seem to follow the format: #if _LIBCPP_STD_VER > X // Do test. #else // Empty test. #endif We should instead use the UNSUPPORTED lit directive to exclude the test on earlier C++ standards. This gives us a more accurate number of test passes for those standards and avoids unnecessary conflicts with other lit directives on the same tests. Reviewers: bcraig, ericwf, mclow.lists Differential revision: http://reviews.llvm.org/D20730 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@271108 91177308-0d34-0410-b5e6-96231b3b80d8
45 lines
1.6 KiB
C++
45 lines
1.6 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.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++98, c++03, c++11
|
|
#include <functional>
|
|
#include <string>
|
|
|
|
template <class _Tp>
|
|
struct is_transparent
|
|
{
|
|
private:
|
|
struct __two {char __lx; char __lxx;};
|
|
template <class _Up> static __two __test(...);
|
|
template <class _Up> static char __test(typename _Up::is_transparent* = 0);
|
|
public:
|
|
static const bool value = sizeof(__test<_Tp>(0)) == 1;
|
|
};
|
|
|
|
|
|
int main ()
|
|
{
|
|
static_assert ( !is_transparent<std::logical_and<int>>::value, "" );
|
|
static_assert ( !is_transparent<std::logical_and<std::string>>::value, "" );
|
|
static_assert ( is_transparent<std::logical_and<void>>::value, "" );
|
|
static_assert ( is_transparent<std::logical_and<>>::value, "" );
|
|
|
|
static_assert ( !is_transparent<std::logical_or<int>>::value, "" );
|
|
static_assert ( !is_transparent<std::logical_or<std::string>>::value, "" );
|
|
static_assert ( is_transparent<std::logical_or<void>>::value, "" );
|
|
static_assert ( is_transparent<std::logical_or<>>::value, "" );
|
|
|
|
static_assert ( !is_transparent<std::logical_not<int>>::value, "" );
|
|
static_assert ( !is_transparent<std::logical_not<std::string>>::value, "" );
|
|
static_assert ( is_transparent<std::logical_not<void>>::value, "" );
|
|
static_assert ( is_transparent<std::logical_not<>>::value, "" );
|
|
|
|
return 0;
|
|
}
|