iliaa Wed Jan 26 11:55:17 2005 EDT Modified files: /php-src/ext/standard var_unserializer.c var_unserializer.re Log: Fixed bug #31699 (unserialize() float problem on non-English locales). http://cvs.php.net/diff.php/php-src/ext/standard/var_unserializer.c?r1=1.50&r2=1.51&ty=u Index: php-src/ext/standard/var_unserializer.c diff -u php-src/ext/standard/var_unserializer.c:1.50 php-src/ext/standard/var_unserializer.c:1.51 --- php-src/ext/standard/var_unserializer.c:1.50 Tue Jan 18 05:57:05 2005 +++ php-src/ext/standard/var_unserializer.c Wed Jan 26 11:55:17 2005 @@ -1,5 +1,5 @@ -/* Generated by re2c 0.9.4 on Mon Sep 13 22:00:00 2004 */ -#line 1 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +/* Generated by re2c 0.9.3 on Wed Jan 26 11:09:50 2005 */ +#line 1 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" /* +----------------------------------------------------------------------+ | PHP Version 5 | @@ -18,7 +18,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: var_unserializer.c,v 1.50 2005/01/18 10:57:05 sniper Exp $ */ +/* $Id: var_unserializer.c,v 1.51 2005/01/26 16:55:17 iliaa Exp $ */ #include "php.h" #include "ext/standard/php_var.h" @@ -125,7 +125,7 @@ efree(var_hash); var_hash = next; } - + var_hash = var_hashx->first_dtor; while (var_hash) { @@ -147,7 +147,7 @@ #define YYMARKER marker -#line 118 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 154 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" @@ -406,7 +406,7 @@ goto yy16; } else { if(yych <= '}') goto yy14; - if(yych <= 0xBF) goto yy16; + if(yych <= '\277') goto yy16; goto yy2; } } @@ -420,7 +420,7 @@ if(yych == ':') goto yy87; goto yy4; yy4: -#line 532 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 576 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { return 0; } #line 102 "<stdout>" yy5: yyaccept = 0; @@ -461,7 +461,7 @@ yy14: ++YYCURSOR; goto yy15; yy15: -#line 526 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 570 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { /* this is the case where we have less data than planned */ php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Unexpected end of serialized data"); @@ -490,7 +490,7 @@ yy22: ++YYCURSOR; goto yy23; yy23: -#line 433 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 477 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { size_t len, len2, maxlen; int elements; @@ -612,7 +612,7 @@ yy29: ++YYCURSOR; goto yy30; yy30: -#line 425 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 469 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { INIT_PZVAL(*rval); @@ -644,7 +644,7 @@ yy36: ++YYCURSOR; goto yy37; yy37: -#line 407 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 451 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { int elements = parse_iv(start + 2); @@ -686,7 +686,7 @@ yy43: ++YYCURSOR; goto yy44; yy44: -#line 379 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 423 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { size_t len, maxlen; char *str; @@ -803,11 +803,11 @@ yy55: ++YYCURSOR; goto yy56; yy56: -#line 372 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 416 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); - ZVAL_DOUBLE(*rval, atof(start + 2)); + ZVAL_DOUBLE(*rval, zend_strtod(start + 2, NULL)); return 1; } #line 496 "<stdout>" @@ -870,12 +870,12 @@ yy66: ++YYCURSOR; goto yy67; yy67: -#line 355 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 399 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); #if defined(HAVE_ATOF_ACCEPTS_NAN) && defined(HAVE_ATOF_ACCEPTS_INF) - ZVAL_DOUBLE(*rval, atof(start + 2)); + ZVAL_DOUBLE(*rval, zend_strtod(start + 2, NULL)); #else if (!strncmp(start + 2, "NAN", 3)) { ZVAL_DOUBLE(*rval, php_get_nan()); @@ -916,7 +916,7 @@ yy73: ++YYCURSOR; goto yy74; yy74: -#line 348 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 392 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); @@ -934,7 +934,7 @@ yy77: ++YYCURSOR; goto yy78; yy78: -#line 341 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 385 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); @@ -945,7 +945,7 @@ yy79: ++YYCURSOR; goto yy80; yy80: -#line 334 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 378 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); @@ -978,7 +978,7 @@ yy85: ++YYCURSOR; goto yy86; yy86: -#line 313 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 355 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { int id; @@ -989,7 +989,7 @@ if (id == -1 || var_access(var_hash, id, &rval_ref) != SUCCESS) { return 0; } - + if (*rval == *rval_ref) return 0; if (*rval != NULL) { @@ -1001,7 +1001,7 @@ return 1; } -#line 689 "<stdout>" +#line 691 "<stdout>" yy87: yych = *++YYCURSOR; if(yych <= ','){ if(yych != '+') goto yy2; @@ -1027,7 +1027,7 @@ yy91: ++YYCURSOR; goto yy92; yy92: -#line 292 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 334 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" { int id; @@ -1048,9 +1048,9 @@ return 1; } -#line 737 "<stdout>" +#line 739 "<stdout>" } -#line 534 "/usr/src/php-cvs/ext/standard/var_unserializer.re" +#line 578 "/home/rei/php_dev/php5.1/ext/standard/var_unserializer.re" return 0; http://cvs.php.net/diff.php/php-src/ext/standard/var_unserializer.re?r1=1.38&r2=1.39&ty=u Index: php-src/ext/standard/var_unserializer.re diff -u php-src/ext/standard/var_unserializer.re:1.38 php-src/ext/standard/var_unserializer.re:1.39 --- php-src/ext/standard/var_unserializer.re:1.38 Mon Jan 17 06:45:09 2005 +++ php-src/ext/standard/var_unserializer.re Wed Jan 26 11:55:17 2005 @@ -16,7 +16,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: var_unserializer.re,v 1.38 2005/01/17 11:45:09 sesser Exp $ */ +/* $Id: var_unserializer.re,v 1.39 2005/01/26 16:55:17 iliaa Exp $ */ #include "php.h" #include "ext/standard/php_var.h" @@ -400,7 +400,7 @@ *p = YYCURSOR; INIT_PZVAL(*rval); #if defined(HAVE_ATOF_ACCEPTS_NAN) && defined(HAVE_ATOF_ACCEPTS_INF) - ZVAL_DOUBLE(*rval, atof(start + 2)); + ZVAL_DOUBLE(*rval, zend_strtod(start + 2, NULL)); #else if (!strncmp(start + 2, "NAN", 3)) { ZVAL_DOUBLE(*rval, php_get_nan()); @@ -416,7 +416,7 @@ "d:" (iv | nv | nvexp) ";" { *p = YYCURSOR; INIT_PZVAL(*rval); - ZVAL_DOUBLE(*rval, atof(start + 2)); + ZVAL_DOUBLE(*rval, zend_strtod(start + 2, NULL)); return 1; }
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php