aboutsummaryrefslogtreecommitdiff
path: root/src/common/jsonapi.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2025-05-18 12:45:55 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2025-05-18 12:45:55 -0400
commit12eee85e511ff8854ac61e8caad8cec218b20513 (patch)
treea899e7760e0e8a73aeb33f484a7a84dc2f2cb3ec /src/common/jsonapi.c
parent0d4dad200d78da6c1c2c705315a04c2080cdd975 (diff)
downloadpostgresql-12eee85e511ff8854ac61e8caad8cec218b20513.tar.gz
postgresql-12eee85e511ff8854ac61e8caad8cec218b20513.zip
Make our usage of memset_s() conform strictly to the C11 standard.
Per the letter of the C11 standard, one must #define __STDC_WANT_LIB_EXT1__ as 1 before including <string.h> in order to have access to memset_s(). It appears that many platforms are lenient about this, because we weren't doing it and yet the code appeared to work anyway. But we now find that with -std=c11, macOS is strict and doesn't declare memset_s, leading to compile failures since we try to use it anyway. (Given the lack of prior reports, perhaps this is new behavior in the latest SDK? No matter, we're clearly in the wrong.) In addition to the immediate problem, which could be fixed merely by adding the needed #define to explicit_bzero.c, it seems possible that our configure-time probe for memset_s() could fail in case a platform implements the function in some odd way due to this spec requirement. This concern can be fixed in largely the same way that we dealt with strchrnul() in 6da2ba1d8: switch to using a declaration-based configure probe instead of a does-it-link probe. Back-patch to v13 where we started using memset_s(). Reported-by: Lakshmi Narayana Velayudam <dev.narayana.v@gmail.com> Author: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/CAA4pTnLcKGG78xeOjiBr5yS7ZeE-Rh=FaFQQGOO=nPzA1L8yEA@mail.gmail.com Backpatch-through: 13
Diffstat (limited to 'src/common/jsonapi.c')
0 files changed, 0 insertions, 0 deletions