diff options
author | Felipe Pena <felipe@php.net> | 2008-06-20 19:57:25 +0000 |
---|---|---|
committer | Felipe Pena <felipe@php.net> | 2008-06-20 19:57:25 +0000 |
commit | f23acf749d45a8af811dc2fa23d6cbf86eb706be (patch) | |
tree | 75db5a5c6f64f654f227f4575248c352223bf20a /ext/wddx | |
parent | 8a65886bb960d4206856bdfa685b0471304a736a (diff) | |
download | php-git-f23acf749d45a8af811dc2fa23d6cbf86eb706be.tar.gz |
- New parameter parsing API
Diffstat (limited to 'ext/wddx')
-rw-r--r-- | ext/wddx/wddx.c | 53 |
1 files changed, 18 insertions, 35 deletions
diff --git a/ext/wddx/wddx.c b/ext/wddx/wddx.c index cf0f9bec82..df0e0a8dd7 100644 --- a/ext/wddx/wddx.c +++ b/ext/wddx/wddx.c @@ -1148,20 +1148,12 @@ PHP_FUNCTION(wddx_serialize_value) Creates a new packet and serializes given variables into a struct */ PHP_FUNCTION(wddx_serialize_vars) { - int argc, i; + int num_args, i; wddx_packet *packet; - zval ***args; - - argc = ZEND_NUM_ARGS(); - if (argc < 1) { - WRONG_PARAM_COUNT; - } + zval ***args = NULL; - /* Allocate arguments array and get the arguments, checking for errors. */ - args = (zval ***)safe_emalloc(argc, sizeof(zval **), 0); - if (zend_get_parameters_array_ex(argc, args) == FAILURE) { - efree(args); - WRONG_PARAM_COUNT; + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "+", &args, &num_args) == FAILURE) { + return; } packet = php_wddx_constructor(); @@ -1169,9 +1161,10 @@ PHP_FUNCTION(wddx_serialize_vars) php_wddx_packet_start(packet, NULL, 0); php_wddx_add_chunk_static(packet, WDDX_STRUCT_S); - for (i=0; i<argc; i++) { - if (Z_TYPE_PP(args[i]) != IS_ARRAY && Z_TYPE_PP(args[i]) != IS_OBJECT) + for (i=0; i<num_args; i++) { + if (Z_TYPE_PP(args[i]) != IS_ARRAY && Z_TYPE_PP(args[i]) != IS_OBJECT) { convert_to_string_ex(args[i]); + } php_wddx_add_var(packet, *args[i]); } @@ -1256,39 +1249,29 @@ PHP_FUNCTION(wddx_packet_end) Serializes given variables and adds them to packet given by packet_id */ PHP_FUNCTION(wddx_add_vars) { - int argc, i; - zval ***args; - zval **packet_id; + int num_args, i; + zval ***args = NULL; + long packet_id; wddx_packet *packet = NULL; - argc = ZEND_NUM_ARGS(); - if (argc < 2) { - WRONG_PARAM_COUNT; - } - - /* Allocate arguments array and get the arguments, checking for errors. */ - args = (zval ***)safe_emalloc(argc, sizeof(zval **), 0); - if (zend_get_parameters_array_ex(argc, args) == FAILURE) { - efree(args); - WRONG_PARAM_COUNT; + if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l+", packet_id, &args, &num_args) == FAILURE) { + return; } - - packet_id = args[0]; - packet = (wddx_packet *)zend_fetch_resource(packet_id TSRMLS_CC, -1, "WDDX packet ID", NULL, 1, le_wddx); - if (!packet) - { + packet = (wddx_packet *)zend_fetch_resource(&packet_id TSRMLS_CC, -1, "WDDX packet ID", NULL, 1, le_wddx); + if (!packet) { efree(args); RETURN_FALSE; } - for (i=1; i<argc; i++) { - if (Z_TYPE_PP(args[i]) != IS_ARRAY && Z_TYPE_PP(args[i]) != IS_OBJECT) + for (i=1; i<num_args; i++) { + if (Z_TYPE_PP(args[i]) != IS_ARRAY && Z_TYPE_PP(args[i]) != IS_OBJECT) { convert_to_string_ex(args[i]); + } php_wddx_add_var(packet, (*args[i])); } - efree(args); + efree(args); RETURN_TRUE; } /* }}} */ |