| modification, are permitted provided that the conditions mentioned |
| in the accompanying LICENSE file are met. |
+--------------------------------------------------------------------+
- | Copyright (c) 2004-2006, Michael Wallner <mike@php.net> |
+ | Copyright (c) 2004-2007, Michael Wallner <mike@php.net> |
+--------------------------------------------------------------------+
*/
HTTP_ARG_VAL(flags, 0)
HTTP_END_ARGS;
+HTTP_BEGIN_ARGS(factory, 0)
+ HTTP_ARG_VAL(flags, 0)
+ HTTP_ARG_VAL(class_name, 0)
+HTTP_END_ARGS;
+
HTTP_BEGIN_ARGS(update, 1)
HTTP_ARG_VAL(data, 0)
HTTP_END_ARGS;
HTTP_DEFLATE_ME(flush, ZEND_ACC_PUBLIC)
HTTP_DEFLATE_ME(finish, ZEND_ACC_PUBLIC)
+ HTTP_DEFLATE_ME(factory, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
+
EMPTY_FUNCTION_ENTRY
};
static zend_object_handlers http_deflatestream_object_handlers;
}
/* {{{ proto void HttpDeflateStream::__construct([int flags = 0])
- *
- * Creates a new HttpDeflateStream object instance.
- *
- * Accepts an optional int parameter specifying how to initialize the deflate stream.
- */
+ Creates a new HttpDeflateStream object instance. */
PHP_METHOD(HttpDeflateStream, __construct)
{
long flags = 0;
}
/* }}} */
+/* {{{ proto HttpDeflateStream HttpDeflateStream::factory([int flags[, string class = "HttpDeflateStream"]])
+ Creates a new HttpDeflateStream object instance. */
+PHP_METHOD(HttpDeflateStream, factory)
+{
+ long flags = 0;
+ char *cn = NULL;
+ int cl = 0;
+
+ SET_EH_THROW_HTTP();
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|ls", &flags, &cn, &cl)) {
+ zend_object_value ov;
+ http_encoding_stream *s = http_encoding_deflate_stream_init(NULL, flags & 0x0fffffff);
+
+ if (SUCCESS == http_object_new(&ov, cn, cl, _http_deflatestream_object_new_ex, http_deflatestream_object_ce, s, NULL)) {
+ RETVAL_OBJVAL(ov, 0);
+ }
+ }
+ SET_EH_NORMAL();
+}
+/* }}} */
+
/* {{{ proto string HttpDeflateStream::update(string data)
- *
- * Passes more data through the deflate stream.
- *
- * Expects a string parameter containing (a part of) the data to deflate.
- *
- * Returns deflated data on success or FALSE on failure.
- */
+ Passes more data through the deflate stream. */
PHP_METHOD(HttpDeflateStream, update)
{
int data_len;
/* }}} */
/* {{{ proto string HttpDeflateStream::flush([string data])
- *
- * Flushes the deflate stream.
- *
- * Returns some deflated data as string on success or FALSE on failure.
- */
+ Flushes the deflate stream. */
PHP_METHOD(HttpDeflateStream, flush)
{
int data_len = 0;
/* }}} */
/* {{{ proto string HttpDeflateStream::finish([string data])
- *
- * Finalizes the deflate stream. The deflate stream can be reused after finalizing.
- *
- * Returns the final part of deflated data.
- */
+ Finalizes the deflate stream. The deflate stream can be reused after finalizing. */
PHP_METHOD(HttpDeflateStream, finish)
{
int data_len = 0;
}
/* }}} */
-
#endif /* ZEND_ENGINE_2 && HTTP_HAVE_ZLIB*/
/*