pgsql: Guard against overly-long numeric formatting symbols from locale - Mailing list pgsql-committers

From Tom Lane
Subject pgsql: Guard against overly-long numeric formatting symbols from locale
Date
Msg-id E1wFadW-002Bev-1y@gemulon.postgresql.org
Whole thread
List pgsql-committers
Guard against overly-long numeric formatting symbols from locale.

to_char() allocates its output buffer with 8 bytes per formatting
code in the pattern.  If the locale's currency symbol, thousands
separator, or decimal or sign symbol is more than 8 bytes long,
in principle we could overrun the output buffer.  No such locales
exist in the real world, so it seems sufficient to truncate the
symbol if we do see it's too long.

Reported-by: Xint Code
Author: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/638232.1776790821@sss.pgh.pa.us
Backpatch-through: 14

Branch
------
REL_17_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/c97a2861851d3f92fb235ec80bd426b3f5a3d28c

Modified Files
--------------
src/backend/utils/adt/formatting.c | 61 +++++++++++++++++++++++++++-----------
1 file changed, 43 insertions(+), 18 deletions(-)


pgsql-committers by date:

Previous
From: Tom Lane
Date:
Subject: pgsql: Prevent some buffer overruns in spell.c's parsing of affix files
Next
From: Peter Geoghegan
Date:
Subject: pgsql: Harmonize function parameter names for Postgres 19.