diff options
author | Andrey Hristov <andrey@php.net> | 2014-05-20 19:57:11 +0300 |
---|---|---|
committer | Andrey Hristov <andrey@php.net> | 2014-05-20 19:57:11 +0300 |
commit | 5d57e17a15cf89bf8b20d718ce5070b42ee446e0 (patch) | |
tree | 63ffe65e89412e6e37e267d3889a28d0823d3672 /ext/mysqlnd/mysqlnd_reverse_api.c | |
parent | 2312af04a7ca7a43166a7a1be20067e632ff917a (diff) | |
download | php-git-5d57e17a15cf89bf8b20d718ce5070b42ee446e0.tar.gz |
First set of phpng changes for mysqlnd
Diffstat (limited to 'ext/mysqlnd/mysqlnd_reverse_api.c')
-rw-r--r-- | ext/mysqlnd/mysqlnd_reverse_api.c | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/ext/mysqlnd/mysqlnd_reverse_api.c b/ext/mysqlnd/mysqlnd_reverse_api.c index d8b1a41511..332669d6c6 100644 --- a/ext/mysqlnd/mysqlnd_reverse_api.c +++ b/ext/mysqlnd/mysqlnd_reverse_api.c @@ -60,8 +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_add(&mysqlnd_api_ext_ht, apiext->module->name, strlen(apiext->module->name) + 1, &apiext, - sizeof(MYSQLND_REVERSE_API *), NULL); + zend_hash_str_add_ptr(&mysqlnd_api_ext_ht, apiext->module->name, strlen(apiext->module->name), &apiext); } /* }}} */ @@ -71,8 +70,8 @@ PHPAPI MYSQLND * zval_to_mysqlnd(zval * zv, const unsigned int client_api_capabilities, unsigned int * save_client_api_capabilities TSRMLS_DC) { MYSQLND * retval; - MYSQLND_REVERSE_API ** elem; - +#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)) @@ -87,7 +86,22 @@ zval_to_mysqlnd(zval * zv, const unsigned int client_api_capabilities, unsigned } } } - +#else + zval * elem; + ZEND_HASH_FOREACH_VAL(&mysqlnd_api_ext_ht, elem) { + MYSQLND_REVERSE_API * api = (MYSQLND_REVERSE_API *) Z_PTR_P(elem); + if (api && api->conversion_cb) { + retval = api->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); + } + return retval; + } + } + + } ZEND_HASH_FOREACH_END(); +#endif return NULL; } /* }}} */ |