X-Authentication-Warning: delorie.com: mail set sender to geda-user-bounces using -f X-Recipient: geda-user AT delorie DOT com Message-ID: <55E1C156.2000902@xs4all.nl> Date: Sat, 29 Aug 2015 16:27:34 +0200 From: "Bert Timmerman (bert DOT timmerman AT xs4all DOT nl) [via geda-user AT delorie DOT com]" User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.1.19) Gecko/20110429 Fedora/2.0.14-1.fc13 SeaMonkey/2.0.14 MIME-Version: 1.0 To: geda-user AT delorie DOT com Subject: Re: [geda-user] National Language Support (NLS) now fixed. References: <55E1A647 DOT 5080306 AT jump-ing DOT de> In-Reply-To: <55E1A647.5080306@jump-ing.de> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Reply-To: geda-user AT delorie DOT com Markus Hitter (mah AT jump-ing DOT de) [via geda-user AT delorie DOT com] wrote: > Folks, > > it was a long standing issue that NLS support of pcb was kind of broken. It was handled by environment variables like LC_ALL or LC_NUMERIC to values of best guess and relying on this. > > To the non-involved: well known functions like printf() and fprintf() change behaviour depending on these variables. They don't always put a '.' as decimal separator, but the one the national language expects. Accordingly, using such functions to write to files leads to different file contents, often making them unusable for the tools they're intended for. Making printf()& co. dependant on environment variables is a broken concept, still pcb happened to use it a lot. An issue almost invisible on english locales, after all. > > After some back and forth a bunch of functions replacing printf() were written which can (depending on modifiers) write in "file mode", i.e. with always a '.' as decimal separator. That's pcb_printf(), pcb_fprintf() and pcb_snprintf(), the modifier is a back-apostrophe (`). Not all my work, these functions were there before, just without this generic file mode. > > All tests in the testsuite pass now, independently on wether pcb is built with NLS or not, and also independently from the users current locale. I think this is the first time pcb achieved such a state. > > > Enjoy, > Markus > > Hi Markus, Good work ;-) Kind regards, Bert Timmerman.