pgsql: Clean up impenetrable logic in pg_basebackup/receivelog.c.
В списке pgsql-committers по дате отправления:
| От | Tom Lane |
|---|---|
| Тема | pgsql: Clean up impenetrable logic in pg_basebackup/receivelog.c. |
| Дата | |
| Msg-id | E1tiJxW-006nUC-9u@gemulon.postgresql.org обсуждение |
| Список | pgsql-committers |
Clean up impenetrable logic in pg_basebackup/receivelog.c. Coverity complained about possible double free of HandleCopyStream's "copybuf". AFAICS it's mistaken, but it is easy to see why it's confused, because management of that buffer is impossibly confusing. It's unreasonable that HandleEndOfCopyStream frees the buffer in some cases but not others, updates the caller's state for that in no case, and has not a single comment about how complicated that makes things. Let's put all the responsibility for freeing copybuf in the actual owner of that variable, HandleCopyStream. This results in one more PQfreemem call than before, but the logic is far easier to follow, both for humans and machines. Since this isn't (quite) actually broken, no back-patch. Branch ------ master Details ------- https://git.postgresql.org/pg/commitdiff/fd602f29c19d4f483f54d93abe240c12219d9f51 Modified Files -------------- src/bin/pg_basebackup/receivelog.c | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-)
В списке pgsql-committers по дате отправления:
Сайт использует файлы cookie для корректной работы и повышения удобства. Нажимая кнопку «Принять» или продолжая пользоваться сайтом, вы соглашаетесь на их использование в соответствии с Политикой в отношении обработки cookie ООО «ППГ», в том числе на передачу данных из файлов cookie сторонним статистическим и рекламным службам. Вы можете управлять настройками cookie через параметры вашего браузера