diff options
| author | Zoe Carver <z.zoelec2@gmail.com> | 2019-08-20 20:44:59 +0000 |
|---|---|---|
| committer | Zoe Carver <z.zoelec2@gmail.com> | 2019-08-20 20:44:59 +0000 |
| commit | 80ddfcb5b813a61bc75b8a8db0144416d7a47226 (patch) | |
| tree | 524a6873f3c4372ad3b0e8a0579bb5f261c8b6aa | |
| parent | cb40f89c6e2263a22acd62dbd55152e8e114ba60 (diff) | |
| download | bcm5719-llvm-80ddfcb5b813a61bc75b8a8db0144416d7a47226.tar.gz bcm5719-llvm-80ddfcb5b813a61bc75b8a8db0144416d7a47226.zip | |
[libc++] Fix std::abs tests
On systems where sizeof(long) == sizeof(int)
the current tests failed. This commit updates
those tests to work on all systems.
std::abs has specific long specializations
which can be used instead.
llvm-svn: 369437
| -rw-r--r-- | libcxx/test/std/numerics/c.math/abs.pass.cpp | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/libcxx/test/std/numerics/c.math/abs.pass.cpp b/libcxx/test/std/numerics/c.math/abs.pass.cpp index 33e0c7d64c4..bdca9a616ec 100644 --- a/libcxx/test/std/numerics/c.math/abs.pass.cpp +++ b/libcxx/test/std/numerics/c.math/abs.pass.cpp @@ -16,7 +16,7 @@ template<class T> struct correct_size_int { - typedef typename std::conditional<sizeof(T) <= sizeof(int), int, T>::type type; + typedef typename std::conditional<sizeof(T) < sizeof(int), int, T>::type type; }; template <class Source, class Result> @@ -39,6 +39,9 @@ void test_big() assert(std::abs(negative_big_value) == big_value); // make sure it doesnt get casted to a smaller type } +// The following is helpful to keep in mind: +// 1byte == char <= short <= int <= long <= long long + int main(int, char**) { // On some systems char is unsigned. @@ -47,14 +50,18 @@ int main(int, char**) std::is_signed<char>::value, char, signed char >::type SignedChar; - test_abs<short int, typename correct_size_int<short int>::type>(); - test_abs<SignedChar, typename correct_size_int<SignedChar>::type>(); - test_abs<signed char, typename correct_size_int<signed char>::type>(); + // All types less than or equal to and not greater than int are promoted to int. + test_abs<short int, int>(); + test_abs<SignedChar, int>(); + test_abs<signed char, int>(); - test_abs<int, typename correct_size_int<int>::type>(); - test_abs<long int, typename correct_size_int<long int>::type>(); - test_abs<long long int, typename correct_size_int<long long int>::type>(); + // These three calls have specific overloads: + test_abs<int, int>(); + test_abs<long int, long int>(); + test_abs<long long int, long long int>(); + // Here there is no guarantee that int is larger than int8_t so we + // use a helper type trait to conditional test against int. test_abs<std::int8_t, typename correct_size_int<std::int8_t>::type>(); test_abs<std::int16_t, typename correct_size_int<std::int16_t>::type>(); test_abs<std::int32_t, typename correct_size_int<std::int32_t>::type>(); |

