summaryrefslogtreecommitdiff
path: root/ext/mysqlnd/mysqlnd_reverse_api.c
diff options
context:
space:
mode:
authorXinchen Hui <laruence@php.net>2014-06-18 15:43:15 +0800
committerXinchen Hui <laruence@php.net>2014-06-18 15:43:15 +0800
commit98afbc7f75580386a86b1f616ed96416d1a97b7e (patch)
tree5946fcfe2f57b2a0c1be14d21ac02fdfc1653c2c /ext/mysqlnd/mysqlnd_reverse_api.c
parentac1d6abbef5b046f768da7d596a59b7209f3ee1b (diff)
downloadphp-git-98afbc7f75580386a86b1f616ed96416d1a97b7e.tar.gz
Fixed segfaults
Diffstat (limited to 'ext/mysqlnd/mysqlnd_reverse_api.c')
-rw-r--r--ext/mysqlnd/mysqlnd_reverse_api.c19
1 files changed, 7 insertions, 12 deletions
diff --git a/ext/mysqlnd/mysqlnd_reverse_api.c b/ext/mysqlnd/mysqlnd_reverse_api.c
index 332669d6c6..49684876a4 100644
--- a/ext/mysqlnd/mysqlnd_reverse_api.c
+++ b/ext/mysqlnd/mysqlnd_reverse_api.c
@@ -60,7 +60,7 @@ mysqlnd_reverse_api_get_api_list(TSRMLS_D)
PHPAPI void
mysqlnd_reverse_api_register_api(MYSQLND_REVERSE_API * apiext TSRMLS_DC)
{
- zend_hash_str_add_ptr(&mysqlnd_api_ext_ht, apiext->module->name, strlen(apiext->module->name), &apiext);
+ zend_hash_str_add_ptr(&mysqlnd_api_ext_ht, apiext->module->name, strlen(apiext->module->name), apiext);
}
/* }}} */
@@ -72,12 +72,9 @@ zval_to_mysqlnd(zval * zv, const unsigned int client_api_capabilities, unsigned
MYSQLND * retval;
#ifdef OLD_CODE
MYSQLND_REVERSE_API * elem;
- for (zend_hash_internal_pointer_reset(&mysqlnd_api_ext_ht);
- zend_hash_get_current_data(&mysqlnd_api_ext_ht, (void **)&elem) == SUCCESS;
- zend_hash_move_forward(&mysqlnd_api_ext_ht))
- {
- if ((*elem)->conversion_cb) {
- retval = (*elem)->conversion_cb(zv TSRMLS_CC);
+ ZEND_HASH_FOREACH_PTR(&mysqlnd_api_ext_ht, elem) {
+ if (elem->conversion_cb) {
+ retval = elem->conversion_cb(zv TSRMLS_CC);
if (retval) {
if (retval->data) {
*save_client_api_capabilities = retval->data->m->negotiate_client_api_capabilities(retval->data, client_api_capabilities TSRMLS_CC);
@@ -85,11 +82,10 @@ zval_to_mysqlnd(zval * zv, const unsigned int client_api_capabilities, unsigned
return retval;
}
}
- }
+ } ZEND_HASH_FOREACH_END();
#else
- zval * elem;
- ZEND_HASH_FOREACH_VAL(&mysqlnd_api_ext_ht, elem) {
- MYSQLND_REVERSE_API * api = (MYSQLND_REVERSE_API *) Z_PTR_P(elem);
+ MYSQLND_REVERSE_API * api;
+ ZEND_HASH_FOREACH_PTR(&mysqlnd_api_ext_ht, api) {
if (api && api->conversion_cb) {
retval = api->conversion_cb(zv TSRMLS_CC);
if (retval) {
@@ -99,7 +95,6 @@ zval_to_mysqlnd(zval * zv, const unsigned int client_api_capabilities, unsigned
return retval;
}
}
-
} ZEND_HASH_FOREACH_END();
#endif
return NULL;