]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Guard against overly-long numeric formatting symbols from locale.
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 22 Apr 2026 16:41:01 +0000 (12:41 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 22 Apr 2026 16:41:01 +0000 (12:41 -0400)
commit8a6f08c0c7c3769ba32e302c95c7950179e5b87e
tree289f656b09248750a32a8a2c916bf1266327ace2
parent21a24d70950000741cc09866bc86e8be274f65df
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
src/backend/utils/adt/formatting.c