提交 bd4ac584 编写于 作者: J jsalling

Inline the isneg/ispos macros, remove promotion warnings on constants

Originated from commit c6dc96f3 but are rarely used and not in math.h
Removes float to double promotion warning and simplifies the code
'gcc -std=gnu99 -Wdouble-promotion' spits out these warnings
上级 0603c1cf
...@@ -688,11 +688,11 @@ void UnityAssertEqualIntArray(UNITY_INTERNAL_PTR expected, ...@@ -688,11 +688,11 @@ void UnityAssertEqualIntArray(UNITY_INTERNAL_PTR expected,
/*-----------------------------------------------*/ /*-----------------------------------------------*/
/* Wrap this define in a function with variable types as float or double */ /* Wrap this define in a function with variable types as float or double */
#define UNITY_FLOAT_OR_DOUBLE_WITHIN(delta, expected, actual, diff) \ #define UNITY_FLOAT_OR_DOUBLE_WITHIN(delta, expected, actual, diff) \
if (isinf(expected) && isinf(actual) && (isneg(expected) == isneg(actual))) return 1; \ if (isinf(expected) && isinf(actual) && ((expected < 0) == (actual < 0))) return 1; \
if (UNITY_NAN_CHECK) return 1; \ if (UNITY_NAN_CHECK) return 1; \
diff = actual - expected; \ diff = actual - expected; \
if (diff < 0.0f) diff = 0.0f - diff; \ if (diff < 0) diff = -diff; \
if (delta < 0.0f) delta = 0.0f - delta; \ if (delta < 0) delta = -delta; \
return !(isnan(diff) || isinf(diff) || (diff > delta)) return !(isnan(diff) || isinf(diff) || (diff > delta))
/* This first part of this condition will catch any NaN or Infinite values */ /* This first part of this condition will catch any NaN or Infinite values */
#ifndef UNITY_NAN_NOT_EQUAL_NAN #ifndef UNITY_NAN_NOT_EQUAL_NAN
...@@ -793,11 +793,11 @@ void UnityAssertFloatSpecial(const UNITY_FLOAT actual, ...@@ -793,11 +793,11 @@ void UnityAssertFloatSpecial(const UNITY_FLOAT actual,
{ {
case UNITY_FLOAT_IS_INF: case UNITY_FLOAT_IS_INF:
case UNITY_FLOAT_IS_NOT_INF: case UNITY_FLOAT_IS_NOT_INF:
is_trait = isinf(actual) & ispos(actual); is_trait = isinf(actual) && (actual > 0);
break; break;
case UNITY_FLOAT_IS_NEG_INF: case UNITY_FLOAT_IS_NEG_INF:
case UNITY_FLOAT_IS_NOT_NEG_INF: case UNITY_FLOAT_IS_NOT_NEG_INF:
is_trait = isinf(actual) & isneg(actual); is_trait = isinf(actual) && (actual < 0);
break; break;
case UNITY_FLOAT_IS_NAN: case UNITY_FLOAT_IS_NAN:
...@@ -805,13 +805,9 @@ void UnityAssertFloatSpecial(const UNITY_FLOAT actual, ...@@ -805,13 +805,9 @@ void UnityAssertFloatSpecial(const UNITY_FLOAT actual,
is_trait = isnan(actual) ? 1 : 0; is_trait = isnan(actual) ? 1 : 0;
break; break;
/* A determinate number is non infinite and not NaN. (therefore the opposite of the two above) */ case UNITY_FLOAT_IS_DET: /* A determinate number is non infinite and not NaN. */
case UNITY_FLOAT_IS_DET:
case UNITY_FLOAT_IS_NOT_DET: case UNITY_FLOAT_IS_NOT_DET:
if (isinf(actual) || isnan(actual)) is_trait = !isinf(actual) && !isnan(actual);
is_trait = 0;
else
is_trait = 1;
break; break;
default: default:
...@@ -922,11 +918,11 @@ void UnityAssertDoubleSpecial(const UNITY_DOUBLE actual, ...@@ -922,11 +918,11 @@ void UnityAssertDoubleSpecial(const UNITY_DOUBLE actual,
{ {
case UNITY_FLOAT_IS_INF: case UNITY_FLOAT_IS_INF:
case UNITY_FLOAT_IS_NOT_INF: case UNITY_FLOAT_IS_NOT_INF:
is_trait = isinf(actual) & ispos(actual); is_trait = isinf(actual) && (actual > 0);
break; break;
case UNITY_FLOAT_IS_NEG_INF: case UNITY_FLOAT_IS_NEG_INF:
case UNITY_FLOAT_IS_NOT_NEG_INF: case UNITY_FLOAT_IS_NOT_NEG_INF:
is_trait = isinf(actual) & isneg(actual); is_trait = isinf(actual) && (actual < 0);
break; break;
case UNITY_FLOAT_IS_NAN: case UNITY_FLOAT_IS_NAN:
...@@ -934,13 +930,9 @@ void UnityAssertDoubleSpecial(const UNITY_DOUBLE actual, ...@@ -934,13 +930,9 @@ void UnityAssertDoubleSpecial(const UNITY_DOUBLE actual,
is_trait = isnan(actual) ? 1 : 0; is_trait = isnan(actual) ? 1 : 0;
break; break;
/* A determinate number is non infinite and not NaN. (therefore the opposite of the two above) */ case UNITY_FLOAT_IS_DET: /* A determinate number is non infinite and not NaN. */
case UNITY_FLOAT_IS_DET:
case UNITY_FLOAT_IS_NOT_DET: case UNITY_FLOAT_IS_NOT_DET:
if (isinf(actual) || isnan(actual)) is_trait = !isinf(actual) && !isnan(actual);
is_trait = 0;
else
is_trait = 1;
break; break;
default: default:
......
...@@ -187,6 +187,7 @@ ...@@ -187,6 +187,7 @@
#endif #endif
typedef UNITY_FLOAT_TYPE UNITY_FLOAT; typedef UNITY_FLOAT_TYPE UNITY_FLOAT;
/* isinf & isnan macros should be provided by math.h */
#ifndef isinf #ifndef isinf
/* The value of Inf - Inf is NaN */ /* The value of Inf - Inf is NaN */
#define isinf(n) (isnan((n) - (n)) && !isnan(n)) #define isinf(n) (isnan((n) - (n)) && !isnan(n))
...@@ -198,14 +199,6 @@ typedef UNITY_FLOAT_TYPE UNITY_FLOAT; ...@@ -198,14 +199,6 @@ typedef UNITY_FLOAT_TYPE UNITY_FLOAT;
#define isnan(n) ((n != n) ? 1 : 0) #define isnan(n) ((n != n) ? 1 : 0)
#endif #endif
#ifndef isneg
#define isneg(n) ((n < 0.0f) ? 1 : 0)
#endif
#ifndef ispos
#define ispos(n) ((n > 0.0f) ? 1 : 0)
#endif
#endif #endif
/*------------------------------------------------------- /*-------------------------------------------------------
...@@ -243,7 +236,7 @@ typedef UNITY_FLOAT_TYPE UNITY_FLOAT; ...@@ -243,7 +236,7 @@ typedef UNITY_FLOAT_TYPE UNITY_FLOAT;
/* Double Floating Point Support */ /* Double Floating Point Support */
#ifndef UNITY_DOUBLE_PRECISION #ifndef UNITY_DOUBLE_PRECISION
#define UNITY_DOUBLE_PRECISION (1e-12f) #define UNITY_DOUBLE_PRECISION (1e-12)
#endif #endif
#ifndef UNITY_DOUBLE_TYPE #ifndef UNITY_DOUBLE_TYPE
......
...@@ -3274,8 +3274,9 @@ void testFloatPrinting(void) ...@@ -3274,8 +3274,9 @@ void testFloatPrinting(void)
TEST_ASSERT_EQUAL_PRINT_FLOATING("8.3099991e+09", 8309999104.0f); TEST_ASSERT_EQUAL_PRINT_FLOATING("8.3099991e+09", 8309999104.0f);
TEST_ASSERT_EQUAL_PRINT_FLOATING("1.0e+10", 1.0e+10f); TEST_ASSERT_EQUAL_PRINT_FLOATING("1.0e+10", 1.0e+10f);
TEST_ASSERT_EQUAL_PRINT_FLOATING("1.0e+10", 10000000000.0f); TEST_ASSERT_EQUAL_PRINT_FLOATING("1.0e+10", 10000000000.0f);
TEST_ASSERT_EQUAL_PRINT_FLOATING("1.00005499e+10", 1.000055e+10f); /* Some compilers have trouble with inexact float constants, a float cast works generally */
TEST_ASSERT_EQUAL_PRINT_FLOATING("1.10000006e+38", 1.10000005e+38f); TEST_ASSERT_EQUAL_PRINT_FLOATING("1.00005499e+10", (float)1.000055e+10f);
TEST_ASSERT_EQUAL_PRINT_FLOATING("1.10000006e+38", (float)1.10000005e+38f);
TEST_ASSERT_EQUAL_PRINT_FLOATING("1.63529943e+10", 1.63529943e+10f); TEST_ASSERT_EQUAL_PRINT_FLOATING("1.63529943e+10", 1.63529943e+10f);
TEST_ASSERT_EQUAL_PRINT_FLOATING("3.40282347e+38", 3.40282346638e38f); TEST_ASSERT_EQUAL_PRINT_FLOATING("3.40282347e+38", 3.40282346638e38f);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册