summaryrefslogtreecommitdiff
path: root/Zend/zend_execute.c
diff options
context:
space:
mode:
authorMatt Wilmas <mattwil@php.net>2009-06-04 18:20:45 +0000
committerMatt Wilmas <mattwil@php.net>2009-06-04 18:20:45 +0000
commitb907aa43311ab0b5430d2713a54414baaf9c7e20 (patch)
tree397f1697ff3ff689eea6ff04611831939df02ef0 /Zend/zend_execute.c
parent1787a2272a7d9f3f7c7932f61b57054755e99135 (diff)
downloadphp-git-b907aa43311ab0b5430d2713a54414baaf9c7e20.tar.gz
MFH:
Restored double->long conversion behavior to that of PHP 5.2 (on most platforms) and prior: * Out-of-range numbers overflow/preserve least significant bits (no LONG_MAX/MIN limit) * See bug #42868 (presumably-rare platform with different results in 5.2) * On 32-bit platforms with 64-bit long type, a zend_long64 cast has been added, otherwise it's the same as 5.2 * Use this conversion method everywhere instead of some plain (long) casts Added 'L' parameter parsing specifier to ensure a LONG_MAX/MIN limit: * Essentially what 5.3's new conversion was doing in most cases * Functions with "limit" or "length" type params could be updated to use this, and prevent confusing overflow behavior with huge numbers (*also* in 5.2) - See bug #47854, for example; or even #42868 again # Test updates coming
Diffstat (limited to 'Zend/zend_execute.c')
-rw-r--r--Zend/zend_execute.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c
index 1c7636476c..9216a6441f 100644
--- a/Zend/zend_execute.c
+++ b/Zend/zend_execute.c
@@ -823,10 +823,9 @@ fetch_string_dim:
}
}
break;
- case IS_DOUBLE: {
- DVAL_TO_LVAL(Z_DVAL_P(dim), index);
+ case IS_DOUBLE:
+ index = zend_dval_to_lval(Z_DVAL_P(dim));
goto num_index;
- }
case IS_RESOURCE:
zend_error(E_STRICT, "Resource ID#%ld used as offset, casting to integer (%ld)", Z_LVAL_P(dim), Z_LVAL_P(dim));
/* Fall Through */