]> granicus.if.org Git - php/commitdiff
MFH: fix #41403 (json_decode cannot decode floats if localeconv decimal_point is...
authorAntony Dovgal <tony2001@php.net>
Wed, 16 May 2007 12:54:30 +0000 (12:54 +0000)
committerAntony Dovgal <tony2001@php.net>
Wed, 16 May 2007 12:54:30 +0000 (12:54 +0000)
NEWS
ext/json/JSON_parser.c
ext/json/tests/bug41403.phpt [new file with mode: 0644]

diff --git a/NEWS b/NEWS
index e6d5b3f0fe7ae14e5a2f1187d344d177367eda97..9edc9b953631d0e601f0566072a7721c0c1ddbca 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -10,6 +10,8 @@ PHP                                                                        NEWS
 - Fixed altering $this via argument named "this". (Dmitry)
 - Fixed PHP CLI to use the php.ini from the binary location. (Hannes)
 - Fixed segfault in strripos(). (Tony, Joxean Koret)
+- Fixed bug #41403 (json_decode cannot decode floats if localeconv 
+  decimal_point is not '.'). (Tony)
 - Fixed bug #41390 (Clarify error message with invalid protocol scheme).
   (Scott)
 - Fixed bug #41378 (fastcgi protocol lacks support for Reason-Phrase in 
index b57d65174eb234f3c003474c200c0a9946b81e0b..ae8e7522e04ae37e6cb954b26dca940f0730f755 100644 (file)
@@ -288,7 +288,7 @@ static void json_create_zval(zval **z, smart_str *buf, int type)
     }
     else if (type == IS_DOUBLE)
     {
-        ZVAL_DOUBLE(*z, atof(buf->c));
+        ZVAL_DOUBLE(*z, zend_strtod(buf->c, NULL));
     }
     else if (type == IS_STRING)
     {
diff --git a/ext/json/tests/bug41403.phpt b/ext/json/tests/bug41403.phpt
new file mode 100644 (file)
index 0000000..80576c8
--- /dev/null
@@ -0,0 +1,41 @@
+--TEST--
+Bug #41403 (json_decode cannot decode floats if localeconv decimal_point is not '.')
+--SKIPIF--
+<?php
+if (setlocale(LC_NUMERIC, "de_DE") === false) {
+       die("skip no de_DE locale");
+}
+?>
+--INI--
+precision=14
+--FILE--
+<?php
+
+setlocale(LC_NUMERIC, 'de_DE');
+var_dump(json_decode('[2.1]'));
+var_dump(json_decode('[0.15]'));
+var_dump(json_decode('[123.13452345]'));
+var_dump(json_decode('[123,13452345]'));
+
+echo "Done\n";
+?>
+--EXPECTF--    
+array(1) {
+  [0]=>
+  float(2,1)
+}
+array(1) {
+  [0]=>
+  float(0,15)
+}
+array(1) {
+  [0]=>
+  float(123,13452345)
+}
+array(2) {
+  [0]=>
+  int(123)
+  [1]=>
+  int(13452345)
+}
+Done