I did: > 2024-10-29 Bruno Haible <br...@clisp.org> > > assert-h, stdbool: Allow mixed use of gcc/g++ and clang/clang++ again. > * m4/assert_h.m4 (gl_ASSERT_H): Improve indentation. With GCC and clang, > don't use the value of HAVE_C_STATIC_ASSERT. > * m4/c-bool.m4 (gl_C_BOOL): With GCC and clang, don't use the value of > HAVE_C_BOOL.
It turns out that MSVC 14 cannot parse these preprocessor expressions with nested conditional expressions: ..\config.h(1454): fatal error C1012: unmatched parenthesis: missing ')' These guys are not capable of writing a right-recursive expression parser... This patch fixes it. 2024-10-30 Bruno Haible <br...@clisp.org> assert-h, stdbool: Fix compilation error with MSVC 14 (regr. yesterday). * m4/assert_h.m4 (gl_ASSERT_H): Add parentheses to the preprocessor expression. * m4/c-bool.m4 (gl_C_BOOL): Likewise. diff --git a/m4/assert_h.m4 b/m4/assert_h.m4 index 9bdb3c4f03..8f772f0a63 100644 --- a/m4/assert_h.m4 +++ b/m4/assert_h.m4 @@ -1,5 +1,5 @@ # assert_h.m4 -# serial 2 +# serial 3 dnl Copyright (C) 2011-2024 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, @@ -50,6 +50,10 @@ AC_DEFUN([gl_ASSERT_H] dnl The "zz" puts this toward config.h's end, to avoid potential dnl collisions with other definitions. + dnl Hardcode the known configuration results for GCC and clang, so that + dnl a configuration made with the C compiler works also with the C++ compiler + dnl and vice versa. + dnl The seemingly redundant parentheses are necessary for MSVC 14. dnl #undef assert so that programs are not tempted to use it without dnl specifically including assert.h. dnl #undef __ASSERT_H__ so that on IRIX, when programs later include @@ -60,12 +64,12 @@ AC_DEFUN([gl_ASSERT_H] [#if (!(defined __clang__ \ ? (defined __cplusplus \ ? __cplusplus >= 201703L \ - : __STDC_VERSION__ >= 202000L && __clang_major__ >= 16) : \ - defined __GNUC__ \ - ? (defined __cplusplus \ - ? __cplusplus >= 201103L && __GNUG__ >= 6 \ - : __STDC_VERSION__ >= 202000L && __GNUC__ >= 13) : \ - defined HAVE_C_STATIC_ASSERT) \ + : __STDC_VERSION__ >= 202000L && __clang_major__ >= 16) \ + : (defined __GNUC__ \ + ? (defined __cplusplus \ + ? __cplusplus >= 201103L && __GNUG__ >= 6 \ + : __STDC_VERSION__ >= 202000L && __GNUC__ >= 13) \ + : defined HAVE_C_STATIC_ASSERT)) \ && !defined assert \ && (!defined __cplusplus \ || (__cpp_static_assert < 201411 \ diff --git a/m4/c-bool.m4 b/m4/c-bool.m4 index 8ea186d1cf..fa792b12a1 100644 --- a/m4/c-bool.m4 +++ b/m4/c-bool.m4 @@ -1,5 +1,5 @@ # c-bool.m4 -# serial 2 +# serial 3 dnl Copyright 2022-2024 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, @@ -30,15 +30,23 @@ AC_DEFUN([gl_C_BOOL] dnl The "zz" puts this toward config.h's end, to avoid potential dnl collisions with other definitions. dnl If 'bool', 'true' and 'false' do not work, arrange for them to work. - dnl In C, this means including <stdbool.h> if it is not already included. + dnl Hardcode the known configuration results for GCC and clang, so that + dnl a configuration made with the C compiler works also with the C++ compiler + dnl and vice versa. + dnl The seemingly redundant parentheses are necessary for MSVC 14. + dnl "Arrange for them to work", in C, means including <stdbool.h> if it is + dnl not already included. dnl However, if the preprocessor mistakenly treats 'true' as 0, dnl define it to a bool expression equal to 1; this is needed in dnl Sun C++ 5.11 (Oracle Solaris Studio 12.2, 2010) and older. AH_VERBATIM([zzbool], -[#if !(defined __cplusplus ? 1 : \ - defined __clang__ ? __STDC_VERSION__ >= 202000L && __clang_major__ >= 15 : \ - defined __GNUC__ ? __STDC_VERSION__ >= 202000L && __GNUC__ >= 13 : \ - defined HAVE_C_BOOL) +[#if !(defined __cplusplus \ + ? 1 \ + : (defined __clang__ \ + ? __STDC_VERSION__ >= 202000L && __clang_major__ >= 15 \ + : (defined __GNUC__ \ + ? __STDC_VERSION__ >= 202000L && __GNUC__ >= 13 \ + : defined HAVE_C_BOOL))) # if !defined __cplusplus && !defined __bool_true_false_are_defined # if HAVE_STDBOOL_H # include <stdbool.h>