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(-)

Reply via email to