Tighten up make_libc_collator() and make_icu_collator(). Ensure that error paths within these functions do not leak a collator, and return the result rather than using an out parameter. (Error paths in the caller may still result in a leaked collator, which will be addressed separately.)
In make_libc_collator(), if the first newlocale() succeeds and the second one fails, close the first locale_t object. The function make_icu_collator() doesn't have any external callers, so change it to be static. Discussion: https://postgr.es/m/54d20e812bd6c3e44c10eddcd757ec494ebf1803.ca...@j-davis.com Branch ------ master Details ------- https://git.postgresql.org/pg/commitdiff/ceeaaed87aa39425f1f2c2409f927c76efb8de89 Modified Files -------------- src/backend/utils/adt/pg_locale.c | 176 ++++++++++++++++++++++++-------------- src/include/utils/pg_locale.h | 4 - 2 files changed, 111 insertions(+), 69 deletions(-)