summaryrefslogtreecommitdiff
path: root/Zend/zend_execute.c
diff options
context:
space:
mode:
authorStanislav Malyshev <stas@php.net>2011-12-19 02:05:03 +0000
committerStanislav Malyshev <stas@php.net>2011-12-19 02:05:03 +0000
commit622412d8e6e3c9d8ab87a3ae5d507eb83406d338 (patch)
treea9797e26ab1fd4fd421839ef40874e19f7dd66fe /Zend/zend_execute.c
parentbeda5efd418b54965cb5756741903f8014ac4758 (diff)
downloadphp-git-622412d8e6e3c9d8ab87a3ae5d507eb83406d338.tar.gz
implement the solution for isset/string offsets, fix bug #60362
Diffstat (limited to 'Zend/zend_execute.c')
-rw-r--r--Zend/zend_execute.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c
index e24a3dd6f2..3474ee43cd 100644
--- a/Zend/zend_execute.c
+++ b/Zend/zend_execute.c
@@ -1147,13 +1147,22 @@ convert_to_array:
}
if (Z_TYPE_P(dim) != IS_LONG) {
+
switch(Z_TYPE_P(dim)) {
/* case IS_LONG: */
case IS_STRING:
+ if (IS_LONG == is_numeric_string(Z_STRVAL_P(dim), Z_STRLEN_P(dim), NULL, NULL, -1)) {
+ break;
+ }
+ if (type != BP_VAR_UNSET) {
+ zend_error(E_WARNING, "Illegal string offset '%s'", dim->value.str.val);
+ }
+
+ break;
case IS_DOUBLE:
case IS_NULL:
case IS_BOOL:
- /* do nothing */
+ zend_error(E_NOTICE, "String offset cast occured");
break;
default:
zend_error(E_WARNING, "Illegal offset type");
@@ -1265,10 +1274,19 @@ static void zend_fetch_dimension_address_read(temp_variable *result, zval **cont
switch(Z_TYPE_P(dim)) {
/* case IS_LONG: */
case IS_STRING:
+ if (IS_LONG == is_numeric_string(Z_STRVAL_P(dim), Z_STRLEN_P(dim), NULL, NULL, -1)) {
+ break;
+ }
+ if (type != BP_VAR_IS) {
+ zend_error(E_WARNING, "Illegal string offset '%s'", dim->value.str.val);
+ }
+ break;
case IS_DOUBLE:
case IS_NULL:
case IS_BOOL:
- /* do nothing */
+ if (type != BP_VAR_IS) {
+ zend_error(E_NOTICE, "String offset cast occured");
+ }
break;
default:
zend_error(E_WARNING, "Illegal offset type");