cxx/test/utilities/meta/meta.unary/meta.unary.comp/floating_point.pass.cpp

1 line
1.1 KiB
C++
Raw Normal View History

//===----------------------------------------------------------------------===// // // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // type_traits // floating_point #include <type_traits> template <class T> void test_floating_point_imp() { static_assert(!std::is_reference<T>::value, ""); static_assert( std::is_arithmetic<T>::value, ""); static_assert( std::is_fundamental<T>::value, ""); static_assert( std::is_object<T>::value, ""); static_assert( std::is_scalar<T>::value, ""); static_assert(!std::is_compound<T>::value, ""); static_assert(!std::is_member_pointer<T>::value, ""); } template <class T> void test_floating_point() { test_floating_point_imp<T>(); test_floating_point_imp<const T>(); test_floating_point_imp<volatile T>(); test_floating_point_imp<const volatile T>(); } int main() { test_floating_point<float>(); test_floating_point<double>(); test_floating_point<long double>(); }