From: Ilia Alshanetsky Date: Wed, 10 Aug 2005 22:36:20 +0000 (+0000) Subject: Fixed bug #34068 (Numeric string as array key not cast to integer in X-Git-Tag: BEFORE_UNICODE_MERGE~6 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=46ef5b170886325e9c0c85e2277386a23c7759eb;p=php Fixed bug #34068 (Numeric string as array key not cast to integer in wddx_deserialize()). --- diff --git a/ext/wddx/wddx.c b/ext/wddx/wddx.c index 7396dfdfca..d6084475f9 100644 --- a/ext/wddx/wddx.c +++ b/ext/wddx/wddx.c @@ -997,10 +997,20 @@ static void php_wddx_pop_element(void *user_data, const XML_Char *name) ent1->data->refcount--; add_property_zval(ent2->data, ent1->varname, ent1->data); EG(scope) = old_scope; - } else - zend_hash_update(target_hash, - ent1->varname, strlen(ent1->varname)+1, - &ent1->data, sizeof(zval *), NULL); + } else { + long l; + double d; + + switch (is_numeric_string(ent1->varname, strlen(ent1->varname), &l, &d, 0)) { + case IS_DOUBLE: + l = (long) d; + case IS_LONG: + zend_hash_index_update(target_hash, l, &ent1->data, sizeof(zval *), NULL); + break; + default: + zend_hash_update(target_hash,ent1->varname, strlen(ent1->varname)+1, &ent1->data, sizeof(zval *), NULL); + } + } efree(ent1->varname); } else { zend_hash_next_index_insert(target_hash,