> > + * lib/intprops.h (INT_PROMOTE): New macro. > > + * tests/test-intprops.c: Test it.
Additionally, there is a compilation error here: $ export CC="clang -std=gnu2x -Wincompatible-function-pointer-types" $ ./gnulib-tool --test --single-configure stdckdint-h ... In file included from ../../gltests/test-stdckdint-h.c:30: ../../gltests/test-intprops.c:70:35: error: use of undeclared identifier 'INT_PROMOTE' 70 | int check_INT_PROMOTE = _Generic (INT_PROMOTE ((short int) 0), int: 0); | ^ This patch fixes it. 2025-02-09 Bruno Haible <br...@clisp.org> stdckdint-h tests: Fix compilation error (regression 2025-02-07). * tests/test-intprops.c: Exclude INT_PROMOTE checks if TEST_STDCKDINT is defined. diff --git a/tests/test-intprops.c b/tests/test-intprops.c index 6c06e47ab3..d16b67b5ce 100644 --- a/tests/test-intprops.c +++ b/tests/test-intprops.c @@ -62,18 +62,20 @@ #define DONTCARE __LINE__ +#ifndef TEST_STDCKDINT /* Check that INT_PROMOTE promotes to int. GCC < 4.9 lacks _Generic even though it may claim C11 conformance. */ -#if (201112 <= __STDC_VERSION__ \ - && (!defined __GNUC__ || 4 < __GNUC__ + (9 <= __GNUC_MINOR__) \ - || defined __clang__)) +# if (201112 <= __STDC_VERSION__ \ + && (!defined __GNUC__ || 4 < __GNUC__ + (9 <= __GNUC_MINOR__) \ + || defined __clang__)) int check_INT_PROMOTE = _Generic (INT_PROMOTE ((short int) 0), int: 0); -#endif +# endif /* For other compilers, check the size and sign of INT_PROMOTE (x). */ int check_INT_PROMOTE_size [2 * (sizeof (INT_PROMOTE ((short int) 0)) == sizeof (int)) - 1]; int check_INT_PROMOTE_sign [2 * (INT_PROMOTE ((short int) -1) < 0) - 1]; +#endif int int_minus_2 = -2; int int_1 = 1; @@ -84,9 +86,6 @@ main (void) /* Use VERIFY for tests that must be integer constant expressions, ASSERT otherwise. */ - /* Check that INT_PROMOTE is a no-op on floats. */ - ASSERT (INT_PROMOTE (2.71828) > 2); - #ifndef TEST_STDCKDINT /* TYPE_IS_INTEGER. */ ASSERT (TYPE_IS_INTEGER (bool)); @@ -121,6 +120,9 @@ main (void) ASSERT (TYPE_SIGNED (double)); ASSERT (TYPE_SIGNED (long double)); + /* Check that INT_PROMOTE is a no-op on floats. */ + ASSERT (INT_PROMOTE (2.71828) > 2); + /* Integer representation. Check that it is two's complement. */ VERIFY (INT_MIN + INT_MAX < 0);