pgsql: Fix over-allocation of space for array_out()'s result string.
От | Tom Lane |
---|---|
Тема | pgsql: Fix over-allocation of space for array_out()'s result string. |
Дата | |
Msg-id | E1g4Spd-0004qC-EW@gemulon.postgresql.org обсуждение исходный текст |
Список | pgsql-committers |
Fix over-allocation of space for array_out()'s result string. array_out overestimated the space needed for its output, possibly by a very substantial amount if the array is multi-dimensional, because of wrong order of operations in the loop that counts the number of curly-brace pairs needed. While the output string is normally short-lived, this could still cause problems in extreme cases. An additional minor error was that it counted one more delimiter than is actually needed. Repair those errors, add an Assert that the space is now correctly calculated, and make some minor improvements in the comments. I also failed to resist the temptation to get rid of an integer modulus operation per array element; a simple comparison is sufficient. This bug dates clear back to Berkeley days, so back-patch to all supported versions. Keiichi Hirobe, minor additional work by me Discussion: https://postgr.es/m/CAH=EFxE9W0tRvQkixR2XJRRCToUYUEDkJZk6tnADXugPBRdcdg@mail.gmail.com Branch ------ REL_10_STABLE Details ------- https://git.postgresql.org/pg/commitdiff/103511723ee2c3304a6991a49accf51b674b6907 Modified Files -------------- src/backend/utils/adt/arrayfuncs.c | 32 ++++++++++++++++++++++---------- 1 file changed, 22 insertions(+), 10 deletions(-)
В списке pgsql-committers по дате отправления: