]> 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)
commitf60d25986288f453360cb5d1902945d9417d0da0
tree42d95d12917e79d686f41d503999599dc429cea4
parent0b196d3db7138967d135b72ed9296a9ad7c06846
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