Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / libcxx / test / std / numerics / c.math / isnormal.pass.cpp
blobc3b8f31359f9880fcbdf99f7116f58b23e17d215
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 // bool isfinite(floating-point-type x); // constexpr since C++23
11 // We don't control the implementation on windows
12 // UNSUPPORTED: windows
14 #include <cassert>
15 #include <cmath>
16 #include <limits>
18 #include "test_macros.h"
19 #include "type_algorithms.h"
21 struct TestFloat {
22 template <class T>
23 static TEST_CONSTEXPR_CXX23 bool test() {
24 assert(std::isnormal(std::numeric_limits<T>::max()));
25 assert(!std::isnormal(std::numeric_limits<T>::infinity()));
26 assert(std::isnormal(std::numeric_limits<T>::min()));
27 assert(!std::isnormal(std::numeric_limits<T>::denorm_min()));
28 assert(std::isnormal(std::numeric_limits<T>::lowest()));
29 assert(!std::isnormal(-std::numeric_limits<T>::infinity()));
30 assert(!std::isnormal(T(0)));
31 assert(!std::isnormal(std::numeric_limits<T>::quiet_NaN()));
32 assert(!std::isnormal(std::numeric_limits<T>::signaling_NaN()));
34 return true;
37 template <class T>
38 TEST_CONSTEXPR_CXX23 void operator()() {
39 test<T>();
40 #if TEST_STD_VER >= 23
41 static_assert(test<T>());
42 #endif
46 struct TestInt {
47 template <class T>
48 static TEST_CONSTEXPR_CXX23 bool test() {
49 assert(std::isnormal(std::numeric_limits<T>::max()));
50 assert(std::isnormal(std::numeric_limits<T>::lowest()) == std::is_signed<T>::value);
51 assert(!std::isnormal(T(0)));
53 return true;
56 template <class T>
57 TEST_CONSTEXPR_CXX23 void operator()() {
58 test<T>();
59 #if TEST_STD_VER >= 23
60 static_assert(test<T>());
61 #endif
65 int main(int, char**) {
66 types::for_each(types::floating_point_types(), TestFloat());
67 types::for_each(types::integral_types(), TestInt());
69 return 0;