Update ICU C++ API symbols
authorJohn Naylor <[email protected]>
Thu, 7 Aug 2025 10:14:39 +0000 (17:14 +0700)
committerJohn Naylor <[email protected]>
Thu, 7 Aug 2025 10:14:39 +0000 (17:14 +0700)
Recent ICU versions have added U_SHOW_CPLUSPLUS_HEADER_API, and we need
to set this to zero as well to hide the ICU C++ APIs from pg_locale.h

Per discussion, we want cpluspluscheck to work cleanly in backbranches,
so backpatch both this and its predecessor commit ed26c4e25a4 to all
supported versions.

Reported-by: Tom Lane <[email protected]>
Discussion: https://postgr.es/m/1115793.1754414782%40sss.pgh.pa.us
Backpatch-through: 13

.cirrus.tasks.yml
src/include/utils/pg_locale.h

index d12360aa35680284cd0d3501845c669ec2efa58b..aa01f57202c2515d948ea4ef6f4b343aea61d561 100644 (file)
@@ -773,14 +773,11 @@ task:
   # - Don't use ccache, the files are uncacheable, polluting ccache's
   #   cache
   # - Use -fmax-errors, as particularly cpluspluscheck can be very verbose
-  # - XXX have to disable ICU to avoid errors:
-  #   https://postgr.es/m/20220323002024.f2g6tivduzrktgfa%40alap3.anarazel.de
   ###
   always:
     headers_headerscheck_script: |
       time ./configure \
         ${LINUX_CONFIGURE_FEATURES} \
-        --without-icu \
         --quiet \
         CC="gcc" CXX"=g++" CLANG="clang"
       make -s -j${BUILD_JOBS} clean
index e2a72435427cf14dc7bb75fac1b654d14a67d4b3..73d3e6e9310a03b4ff3701a784cb49eb3396166a 100644 (file)
 #include <xlocale.h>
 #endif
 #ifdef USE_ICU
+/* only include the C APIs, to avoid errors in cpluspluscheck */
+#undef U_SHOW_CPLUSPLUS_API
+#define U_SHOW_CPLUSPLUS_API 0
+#undef U_SHOW_CPLUSPLUS_HEADER_API
+#define U_SHOW_CPLUSPLUS_HEADER_API 0
 #include <unicode/ucol.h>
 #endif