iliaa Sun Jan 30 11:39:55 2005 EDT
Modified files: (Branch: PHP_4_3)
/php-src/ext/standard var_unserializer.c var_unserializer.re
Log:
MFH: Fix handling of INF/NAN in unserialize().
http://cvs.php.net/diff.php/php-src/ext/standard/var_unserializer.c?r1=1.18.4.19&r2=1.18.4.20&ty=u
Index: php-src/ext/standard/var_unserializer.c
diff -u php-src/ext/standard/var_unserializer.c:1.18.4.19
php-src/ext/standard/var_unserializer.c:1.18.4.20
--- php-src/ext/standard/var_unserializer.c:1.18.4.19 Wed Jan 26 11:56:14 2005
+++ php-src/ext/standard/var_unserializer.c Sun Jan 30 11:39:55 2005
@@ -1,4 +1,4 @@
-/* Generated by re2c 0.9.3 on Wed Jan 26 11:07:03 2005 */
+/* Generated by re2c 0.9.3 on Sun Jan 30 11:35:55 2005 */
#line 1 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
/*
+----------------------------------------------------------------------+
@@ -18,7 +18,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: var_unserializer.c,v 1.18.4.19 2005/01/26 16:56:14 iliaa Exp $ */
+/* $Id: var_unserializer.c,v 1.18.4.20 2005/01/30 16:39:55 iliaa Exp $ */
#include "php.h"
#include "ext/standard/php_var.h"
@@ -432,7 +432,7 @@
if(yych == ':') goto yy87;
goto yy4;
yy4:
-#line 576 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 574 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
{ return 0; }
#line 102 "<stdout>"
yy5: yyaccept = 0;
@@ -473,7 +473,7 @@
yy14: ++YYCURSOR;
goto yy15;
yy15:
-#line 570 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 568 "/home/rei/php_dev/php4/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");
@@ -502,7 +502,7 @@
yy22: ++YYCURSOR;
goto yy23;
yy23:
-#line 489 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 487 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
{
size_t len, len2, maxlen;
int elements;
@@ -612,7 +612,7 @@
yy29: ++YYCURSOR;
goto yy30;
yy30:
-#line 481 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 479 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
{
INIT_PZVAL(*rval);
@@ -644,7 +644,7 @@
yy36: ++YYCURSOR;
goto yy37;
yy37:
-#line 463 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 461 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
{
int elements = parse_iv(start + 2);
@@ -686,7 +686,7 @@
yy43: ++YYCURSOR;
goto yy44;
yy44:
-#line 435 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 433 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
{
size_t len, maxlen;
char *str;
@@ -803,7 +803,7 @@
yy55: ++YYCURSOR;
goto yy56;
yy56:
-#line 428 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 426 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
{
*p = YYCURSOR;
INIT_PZVAL(*rval);
@@ -874,9 +874,7 @@
{
*p = YYCURSOR;
INIT_PZVAL(*rval);
-#if defined(HAVE_ATOF_ACCEPTS_NAN) && defined(HAVE_ATOF_ACCEPTS_INF)
- ZVAL_DOUBLE(*rval, zend_strtod(start + 2, NULL));
-#else
+
if (!strncmp(start + 2, "NAN", 3)) {
ZVAL_DOUBLE(*rval, php_get_nan());
} else if (!strncmp(start + 2, "INF", 3)) {
@@ -884,10 +882,10 @@
} else if (!strncmp(start + 2, "-INF", 4)) {
ZVAL_DOUBLE(*rval, -php_get_inf());
}
-#endif
+
return 1;
}
-#line 563 "<stdout>"
+#line 561 "<stdout>"
yy68: yych = *++YYCURSOR;
if(yych == 'N') goto yy65;
goto yy2;
@@ -923,7 +921,7 @@
ZVAL_LONG(*rval, parse_iv(start + 2));
return 1;
}
-#line 600 "<stdout>"
+#line 598 "<stdout>"
yy75: yych = *++YYCURSOR;
if(yych <= '/') goto yy2;
if(yych >= '2') goto yy2;
@@ -941,7 +939,7 @@
ZVAL_BOOL(*rval, parse_iv(start + 2));
return 1;
}
-#line 618 "<stdout>"
+#line 616 "<stdout>"
yy79: ++YYCURSOR;
goto yy80;
yy80:
@@ -952,7 +950,7 @@
ZVAL_NULL(*rval);
return 1;
}
-#line 629 "<stdout>"
+#line 627 "<stdout>"
yy81: yych = *++YYCURSOR;
if(yych <= ','){
if(yych != '+') goto yy2;
@@ -1001,7 +999,7 @@
return 1;
}
-#line 679 "<stdout>"
+#line 677 "<stdout>"
yy87: yych = *++YYCURSOR;
if(yych <= ','){
if(yych != '+') goto yy2;
@@ -1048,9 +1046,9 @@
return 1;
}
-#line 727 "<stdout>"
+#line 725 "<stdout>"
}
-#line 578 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
+#line 576 "/home/rei/php_dev/php4/ext/standard/var_unserializer.re"
return 0;
http://cvs.php.net/diff.php/php-src/ext/standard/var_unserializer.re?r1=1.11.4.12&r2=1.11.4.13&ty=u
Index: php-src/ext/standard/var_unserializer.re
diff -u php-src/ext/standard/var_unserializer.re:1.11.4.12
php-src/ext/standard/var_unserializer.re:1.11.4.13
--- php-src/ext/standard/var_unserializer.re:1.11.4.12 Wed Jan 26 11:56:14 2005
+++ php-src/ext/standard/var_unserializer.re Sun Jan 30 11:39:55 2005
@@ -16,7 +16,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: var_unserializer.re,v 1.11.4.12 2005/01/26 16:56:14 iliaa Exp $ */
+/* $Id: var_unserializer.re,v 1.11.4.13 2005/01/30 16:39:55 iliaa Exp $ */
#include "php.h"
#include "ext/standard/php_var.h"
@@ -411,9 +411,7 @@
"d:" ("NAN" | "-"? "INF") ";" {
*p = YYCURSOR;
INIT_PZVAL(*rval);
-#if defined(HAVE_ATOF_ACCEPTS_NAN) && defined(HAVE_ATOF_ACCEPTS_INF)
- ZVAL_DOUBLE(*rval, zend_strtod(start + 2, NULL));
-#else
+
if (!strncmp(start + 2, "NAN", 3)) {
ZVAL_DOUBLE(*rval, php_get_nan());
} else if (!strncmp(start + 2, "INF", 3)) {
@@ -421,7 +419,7 @@
} else if (!strncmp(start + 2, "-INF", 4)) {
ZVAL_DOUBLE(*rval, -php_get_inf());
}
-#endif
+
return 1;
}
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php