Edit report at https://bugs.php.net/bug.php?id=17079&edit=1

 ID:                 17079
 Comment by:         schindler dot andor at empo dot deletethis dot hu
 Reported by:        jonathan at tricolon dot com
 Summary:            setlocale changes the internal representation of
                     floats
 Status:             Not a bug
 Type:               Bug
 Package:            Scripting Engine problem
 Operating System:   Red Hat Linux 7.1
 PHP Version:        4.3.0 RC2
 Assigned To:        hholzgra
 Block user comment: N
 Private report:     N

 New Comment:

Yes, this is not a bug. This is a huge epic fail. This is a great example, why 
people hate PHP.


Previous Comments:
------------------------------------------------------------------------
[2004-10-23 16:58:47] erki at lap dot ttu dot ee

Having the setlocale function in string.c execute 

if ((lc.decimal_point)[0] != '.') {
        /* set locale back to C */
        setlocale(LC_NUMERIC, "C");     
}

is not a solution. The particular "fix" broke other things. In many countries, 
comma is used as a decimal separator. Case in point: 3 weeks ago, a certain 
financial database of a major telco company in Europe was upgraded to use PHP 
4.3.8 (formerly 4.2.2). The system uses Oracle for persistence, where the 
decimal separator is a comma, as is a custom in that country. So numbers came 
in from Oracle, and then PHP was unable to process them correctly. For example, 
if a client had a debt of 25,12€, and the client paid 5€, then the comparison 
($paid_amount > $debt) said incorrectly that the paid amount was more than the 
debt.

Result: hundreds of wasted man-hours. In the end we recompiled PHP without that 
"fix".

------------------------------------------------------------------------
[2003-07-05 06:13:19] dMNz at one dot lt

am pabandymuj..

------------------------------------------------------------------------
[2003-03-24 10:18:13] moriyo...@php.net

Related discussion: http://news.php.net/article.php?group=php.dev&article=95211


------------------------------------------------------------------------
[2003-01-02 13:58:52] php at zeguigui dot com

I switched to PHP 4.3 (in dev only) and I saw this change in locale handling. 
It is not OS dependant as I have the problem with Windows XP.

In PHP < 4.3.0 I have a MySQL database with floats. To handle those floats I 
had to make some convertions (with str_replace) as results were not locale 
dependant (I use fr_FR). For instance if I had 1.234 stored in db, $row = mysql 
mysql_fetch_row($handle) would return in $row[0] the value "1.234" and $row[0] 
* 100 would return 100 whereas of 123,4 (if outputed).

In PHP = 4.3.0 I do not need those convertion routines anymore (it was a 
workaround in my opinion).

So starting with PHP 4.3:
$a = 1.234 ==> OK whatever locale is
$b = "1.234" ==> OK whatever locale is
$c = "1,234" ==> NOT OK whatever locale is

If I have some user inputs I have to convert from locale representation to 
number representation before processing them... it would be great to have a 
function that do the job for us (didn't find one, sorry!)... but maybe that's 
not the good place to ask for this!

------------------------------------------------------------------------
[2003-01-02 10:13:59] martin at mermaidconsulting dot com

I also ran across this problem and have been messing with it for like 3 days 
before i finally ran across this post. 

If you do not consider it a bug I would recommend you at least include it in 
the documentation and make it very clear that you cannot perform calculations 
using thousands-seperators based on the locale settings. 

If you have a look at the following sample you can see that user-inputs will 
get totally messed up in case they use thousand-seperators.

<?
setlocale(LC_NUMERIC, "en_US") ; // setting the numeric locale to
us-conventions
setlocale(LC_MONETARY, "en_US") ; // setting the monetary locale to
us-conventions

$locale_info = localeconv();
  echo "mon_decimal_point: {$locale_info["mon_decimal_point"]}<br>"; //
displays the monetary decimal point used for the locale
  echo "mon_thousands_sep: {$locale_info["mon_thousands_sep"]}<br>"; //
displays the monetary thousands seperator used for the locale
  echo "decimal_point: {$locale_info["decimal_point"]}<br>"; // displays the
decimal point used for the locale
  echo "thousands_sep: {$locale_info["thousands_sep"]}<br>"; // displays the
thousands seperator used for the locale

// defines 2 variables that should be 1000000 and 750000
$a = "1,000,000";
$b = "750,000";

print "A = $a<br>";
print "B = $b<br>";

// performing a simple calculation that illustrates how PHP handles the
numbers
print "A * 1 = " . ($a*1) . "<br>";
print "B * 1 = " . ($b*1) . "<br>";
?>

Imho there is no point in having locale settings for currencies and numeric 
values if you cannot use it for doing calculations.

Thanks

/Martin

------------------------------------------------------------------------


The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at

    https://bugs.php.net/bug.php?id=17079


-- 
Edit this bug report at https://bugs.php.net/bug.php?id=17079&edit=1

Reply via email to