From: Michael Meskes Date: Thu, 1 Sep 2011 13:27:38 +0000 (+0200) Subject: In ecpglib restore LC_NUMERIC in case of an error. X-Git-Tag: REL8_4_9~14 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a6d72ac344a8643142d76abe2c9d0b1ea68847fb;p=postgresql In ecpglib restore LC_NUMERIC in case of an error. --- diff --git a/src/interfaces/ecpg/ecpglib/execute.c b/src/interfaces/ecpg/ecpglib/execute.c index 6836df65f6..05cbb3ecb1 100644 --- a/src/interfaces/ecpg/ecpglib/execute.c +++ b/src/interfaces/ecpg/ecpglib/execute.c @@ -1503,8 +1503,12 @@ ECPGdo(const int lineno, const int compat, const int force_indicator, const char */ if (statement_type == ECPGst_prepnormal) { - if (!ecpg_auto_prepare(lineno, connection_name, compat, &prepname, query)) + if (!ecpg_auto_prepare(lineno, connection_name, compat, &prepname, query)) { + setlocale(LC_NUMERIC, oldlocale); + ecpg_free(oldlocale); + va_end(args); return (false); + } /* * statement is now prepared, so instead of the query we have to