ECPGdo fails to restore LC_NUMERIC - Mailing list pgsql-bugs

From Heikki Linnakangas
Subject ECPGdo fails to restore LC_NUMERIC
Date
Msg-id 4E5F6C0B.6030708@enterprisedb.com
Whole thread Raw
Responses Re: ECPGdo fails to restore LC_NUMERIC  (Michael Meskes <meskes@postgresql.org>)
List pgsql-bugs
ECPGdo function in ecpglib sets LC_NUMERIC locale temporarily to C, to
make sure it uses the '.' as the decimal separator for any numerics it
sends to the backend. However, it fails to restore it back to the
original locale in some error cases. I can see two returns from the
function that neglect that, on lines 1776 and 1803 in execute.c.

Attached is a test program to showcase the first of those. It produces
this output for me:

LC_NUMERIC before: fi_FI.utf8
number: 1,230000
LC_NUMERIC after: C
number: 1.230000

--
   Heikki Linnakangas
   EnterpriseDB   http://www.enterprisedb.com

Attachment

pgsql-bugs by date:

Previous
From: Valentine Gogichashvili
Date:
Subject: Re: BUG #6186: out of memory while analyze
Next
From: "Kevin Grittner"
Date:
Subject: Re: The translation into Bulgarian