From: Marcus Boerger Date: Mon, 14 Feb 2005 21:03:52 +0000 (+0000) Subject: - MFH X-Git-Tag: php-5.0.4RC1~163 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1c840f70e2c3967ac846fbfdbf0c4a353ed87c17;p=php - MFH --- diff --git a/ext/standard/var_unserializer.c b/ext/standard/var_unserializer.c index 6ac7e04c07..c5651f9c5b 100644 --- a/ext/standard/var_unserializer.c +++ b/ext/standard/var_unserializer.c @@ -1,5 +1,5 @@ -/* Generated by re2c 0.9.3 on Sun Jan 30 11:27:32 2005 */ -#line 1 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +/* Generated by re2c 0.9.4 on Mon Feb 14 22:03:31 2005 */ +#line 1 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" /* +----------------------------------------------------------------------+ | PHP Version 5 | @@ -147,7 +147,7 @@ PHPAPI void var_destroy(php_unserialize_data_t *var_hashx) #define YYMARKER marker -#line 154 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 154 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" @@ -406,7 +406,7 @@ yy0: goto yy16; } else { if(yych <= '}') goto yy14; - if(yych <= '\277') goto yy16; + if(yych <= 0xBF) goto yy16; goto yy2; } } @@ -420,7 +420,7 @@ yy3: yyaccept = 0; if(yych == ':') goto yy87; goto yy4; yy4: -#line 574 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 581 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { return 0; } #line 102 "" yy5: yyaccept = 0; @@ -461,7 +461,7 @@ yy13: yyaccept = 0; yy14: ++YYCURSOR; goto yy15; yy15: -#line 568 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 575 "/usr/src/PHP_5_0/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,9 +490,9 @@ yy21: yych = *++YYCURSOR; yy22: ++YYCURSOR; goto yy23; yy23: -#line 475 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 475 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { - size_t len, len2, maxlen; + size_t len, len2, len3, maxlen; int elements; char *class_name; zend_class_entry *ce; @@ -525,6 +525,13 @@ yy23: return 0; } + len3 = strspn(class_name, "0123456789_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"); + if (len3 != len) + { + *p = YYCURSOR + len3 - len; + return 0; + } + class_name = estrndup(class_name, len); do { @@ -583,7 +590,7 @@ yy23: return object_common2(UNSERIALIZE_PASSTHRU, elements); } -#line 264 "" +#line 271 "" yy24: yych = *++YYCURSOR; if(yych <= ','){ if(yych != '+') goto yy2; @@ -612,7 +619,7 @@ yy28: yych = *++YYCURSOR; yy29: ++YYCURSOR; goto yy30; yy30: -#line 467 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 467 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { INIT_PZVAL(*rval); @@ -620,7 +627,7 @@ yy30: return object_common2(UNSERIALIZE_PASSTHRU, object_common1(UNSERIALIZE_PASSTHRU, ZEND_STANDARD_CLASS_DEF_PTR)); } -#line 302 "" +#line 309 "" yy31: yych = *++YYCURSOR; if(yych == '+') goto yy32; if(yych <= '/') goto yy2; @@ -644,7 +651,7 @@ yy35: yych = *++YYCURSOR; yy36: ++YYCURSOR; goto yy37; yy37: -#line 449 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 449 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { int elements = parse_iv(start + 2); @@ -662,7 +669,7 @@ yy37: return finish_nested_data(UNSERIALIZE_PASSTHRU); } -#line 345 "" +#line 352 "" yy38: yych = *++YYCURSOR; if(yych == '+') goto yy39; if(yych <= '/') goto yy2; @@ -686,7 +693,7 @@ yy42: yych = *++YYCURSOR; yy43: ++YYCURSOR; goto yy44; yy44: -#line 421 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 421 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { size_t len, maxlen; char *str; @@ -714,7 +721,7 @@ yy44: ZVAL_STRINGL(*rval, str, len, 1); return 1; } -#line 398 "" +#line 405 "" yy45: yych = *++YYCURSOR; if(yych <= '/'){ if(yych <= ','){ @@ -803,14 +810,14 @@ yy54: if(yych <= ';'){ yy55: ++YYCURSOR; goto yy56; yy56: -#line 414 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 414 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); ZVAL_DOUBLE(*rval, zend_strtod(start + 2, NULL)); return 1; } -#line 496 "" +#line 503 "" yy57: yych = *++YYCURSOR; if(yych <= ','){ if(yych != '+') goto yy2; @@ -870,7 +877,7 @@ yy65: yych = *++YYCURSOR; yy66: ++YYCURSOR; goto yy67; yy67: -#line 399 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 399 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); @@ -885,7 +892,7 @@ yy67: return 1; } -#line 573 "" +#line 580 "" yy68: yych = *++YYCURSOR; if(yych == 'N') goto yy65; goto yy2; @@ -914,14 +921,14 @@ yy72: if(yych <= '/') goto yy2; yy73: ++YYCURSOR; goto yy74; yy74: -#line 392 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 392 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); ZVAL_LONG(*rval, parse_iv(start + 2)); return 1; } -#line 610 "" +#line 617 "" yy75: yych = *++YYCURSOR; if(yych <= '/') goto yy2; if(yych >= '2') goto yy2; @@ -932,25 +939,25 @@ yy76: yych = *++YYCURSOR; yy77: ++YYCURSOR; goto yy78; yy78: -#line 385 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 385 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); ZVAL_BOOL(*rval, parse_iv(start + 2)); return 1; } -#line 628 "" +#line 635 "" yy79: ++YYCURSOR; goto yy80; yy80: -#line 378 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 378 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { *p = YYCURSOR; INIT_PZVAL(*rval); ZVAL_NULL(*rval); return 1; } -#line 639 "" +#line 646 "" yy81: yych = *++YYCURSOR; if(yych <= ','){ if(yych != '+') goto yy2; @@ -976,7 +983,7 @@ yy84: if(yych <= '/') goto yy2; yy85: ++YYCURSOR; goto yy86; yy86: -#line 355 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 355 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { int id; @@ -999,7 +1006,7 @@ yy86: return 1; } -#line 689 "" +#line 696 "" yy87: yych = *++YYCURSOR; if(yych <= ','){ if(yych != '+') goto yy2; @@ -1025,7 +1032,7 @@ yy90: if(yych <= '/') goto yy2; yy91: ++YYCURSOR; goto yy92; yy92: -#line 334 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 334 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" { int id; @@ -1046,9 +1053,9 @@ yy92: return 1; } -#line 737 "" +#line 744 "" } -#line 576 "/home/rei/php_dev/php5/ext/standard/var_unserializer.re" +#line 583 "/usr/src/PHP_5_0/ext/standard/var_unserializer.re" return 0; diff --git a/ext/standard/var_unserializer.re b/ext/standard/var_unserializer.re index bb804545a2..482149c5c4 100644 --- a/ext/standard/var_unserializer.re +++ b/ext/standard/var_unserializer.re @@ -473,7 +473,7 @@ PHPAPI int php_var_unserialize(UNSERIALIZE_PARAMETER) } "O:" uiv ":" ["] { - size_t len, len2, maxlen; + size_t len, len2, len3, maxlen; int elements; char *class_name; zend_class_entry *ce; @@ -506,6 +506,13 @@ PHPAPI int php_var_unserialize(UNSERIALIZE_PARAMETER) return 0; } + len3 = strspn(class_name, "0123456789_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"); + if (len3 != len) + { + *p = YYCURSOR + len3 - len; + return 0; + } + class_name = estrndup(class_name, len); do {