X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=http_inflatestream_object.c;h=c46a4f162b6e3919292780b9e202156141b505ca;hb=30f23d359aff10b458f036226a8e10bceb0a2da9;hp=c54d094f86c4ab0aef69a9da6c920c19b431caa0;hpb=f0bcc141e62c022101d8d19c1d73e7b9ae41d0e9;p=m6w6%2Fext-http diff --git a/http_inflatestream_object.c b/http_inflatestream_object.c index c54d094..c46a4f1 100644 --- a/http_inflatestream_object.c +++ b/http_inflatestream_object.c @@ -6,17 +6,12 @@ | modification, are permitted provided that the conditions mentioned | | in the accompanying LICENSE file are met. | +--------------------------------------------------------------------+ - | Copyright (c) 2004-2005, Michael Wallner | + | Copyright (c) 2004-2006, Michael Wallner | +--------------------------------------------------------------------+ */ /* $Id$ */ - -#ifdef HAVE_CONFIG_H -# include "config.h" -#endif - #define HTTP_WANT_ZLIB #include "php_http.h" @@ -27,26 +22,23 @@ #include "php_http_exception_object.h" #include "php_http_inflatestream_object.h" -#define HTTP_BEGIN_ARGS(method, ret_ref, req_args) HTTP_BEGIN_ARGS_EX(HttpInflateStream, method, ret_ref, req_args) -#define HTTP_EMPTY_ARGS(method, ret_ref) HTTP_EMPTY_ARGS_EX(HttpInflateStream, method, ret_ref) -#define HTTP_INFLATE_ME(method, visibility) PHP_ME(HttpInflateStream, method, HTTP_ARGS(HttpInflateStream, method), visibility) - -HTTP_BEGIN_ARGS(__construct, 0, 0) - HTTP_ARG_VAL(flags, 0) -HTTP_END_ARGS; +#define HTTP_BEGIN_ARGS(method, req_args) HTTP_BEGIN_ARGS_EX(HttpInflateStream, method, 0, req_args) +#define HTTP_EMPTY_ARGS(method) HTTP_EMPTY_ARGS_EX(HttpInflateStream, method, 0) +#define HTTP_INFLATE_ME(method, visibility) PHP_ME(HttpInflateStream, method, HTTP_ARGS(HttpInflateStream, method), visibility) -HTTP_BEGIN_ARGS(update, 0, 1) +HTTP_BEGIN_ARGS(update, 1) HTTP_ARG_VAL(data, 0) HTTP_END_ARGS; -HTTP_BEGIN_ARGS(flush, 0, 0) +HTTP_BEGIN_ARGS(flush, 0) HTTP_ARG_VAL(data, 0) HTTP_END_ARGS; -HTTP_BEGIN_ARGS(finish, 0, 0) +HTTP_BEGIN_ARGS(finish, 0) HTTP_ARG_VAL(data, 0) HTTP_END_ARGS; +#define OBJ_PROP_CE http_inflatestream_object_ce zend_class_entry *http_inflatestream_object_ce; zend_function_entry http_inflatestream_object_fe[] = { HTTP_INFLATE_ME(update, ZEND_ACC_PUBLIC) @@ -57,8 +49,6 @@ zend_function_entry http_inflatestream_object_fe[] = { }; static zend_object_handlers http_inflatestream_object_handlers; -static inline void http_inflatestream_object_declare_default_properties() { return; } - PHP_MINIT_FUNCTION(http_inflatestream_object) { HTTP_REGISTER_CLASS_EX(HttpInflateStream, http_inflatestream_object, NULL, 0); @@ -171,7 +161,9 @@ PHP_METHOD(HttpInflateStream, flush) char *decoded = NULL, *data = NULL; getObject(http_inflatestream_object, obj); - if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|s", &data, &data_len)); + if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|s", &data, &data_len)) { + RETURN_FALSE; + } if (!obj->stream && !(obj->stream = http_encoding_inflate_stream_init(NULL, 0))) { RETURN_FALSE; @@ -220,14 +212,15 @@ PHP_METHOD(HttpInflateStream, finish) updated = erealloc(updated, updated_len + decoded_len + 1); updated[updated_len + decoded_len] = '\0'; memcpy(updated + updated_len, decoded, decoded_len); + STR_FREE(decoded); updated_len += decoded_len; RETVAL_STRINGL(updated, updated_len, 0); - STR_FREE(decoded); } else { - RETVAL_STRINGL(decoded, decoded_len, 0); STR_FREE(updated); + RETVAL_STRINGL(decoded, decoded_len, 0); } } else { + STR_FREE(updated); RETVAL_FALSE; }