]> granicus.if.org Git - php/commitdiff
MFH: Avoid 2 conversions when decoding numbers
authorMatt Wilmas <mattwil@php.net>
Thu, 19 Mar 2009 19:26:00 +0000 (19:26 +0000)
committerMatt Wilmas <mattwil@php.net>
Thu, 19 Mar 2009 19:26:00 +0000 (19:26 +0000)
ext/json/JSON_parser.c

index 71250126106ef2f55f4768115ae4698b5678b43e..6aae849f1627855f8e24e7f71cc98779d94db458 100644 (file)
@@ -289,16 +289,27 @@ static void json_create_zval(zval **z, smart_str *buf, int type)
 
     if (type == IS_LONG)
     {
-               long l = strtol(buf->c, NULL, 10);
-               double d = zend_strtod(buf->c, NULL);
-               if (d > LONG_MAX || d < LONG_MIN) {
-                       ZVAL_DOUBLE(*z, d);
-               } else {
-                       ZVAL_LONG(*z, l);
+               if (buf->c[0] == '-') {
+                       buf->len--;
+               }
+
+               if (buf->len >= MAX_LENGTH_OF_LONG - 1) {
+                       if (buf->len == MAX_LENGTH_OF_LONG - 1) {
+                               int cmp = strcmp(buf->c + (buf->c[0] == '-'), long_min_digits);
+
+                               if (!(cmp < 0 || (cmp == 0 && buf->c[0] == '-'))) {
+                                       goto use_double;
+                               }
+                       } else {
+                               goto use_double;
+                       }
                }
+
+               ZVAL_LONG(*z, strtol(buf->c, NULL, 10));
     }
     else if (type == IS_DOUBLE)
     {
+use_double:
         ZVAL_DOUBLE(*z, zend_strtod(buf->c, NULL));
     }
     else if (type == IS_STRING)