[-]
[+]
|
Changed |
php5-pecl_http.changes
|
|
[-]
[+]
|
Changed |
php5-pecl_http.spec
^
|
|
[-]
[+]
|
Deleted |
pecl_http-1.7.5.tar.bz2/pecl_http-1.7.5/http_message_object.c
^
|
@@ -1,1555 +0,0 @@
-/*
- +--------------------------------------------------------------------+
- | PECL :: http |
- +--------------------------------------------------------------------+
- | Redistribution and use in source and binary forms, with or without |
- | modification, are permitted provided that the conditions mentioned |
- | in the accompanying LICENSE file are met. |
- +--------------------------------------------------------------------+
- | Copyright (c) 2004-2010, Michael Wallner <mike@php.net> |
- +--------------------------------------------------------------------+
-*/
-
-/* $Id: http_message_object.c 323304 2012-02-17 21:13:24Z mike $ */
-
-#define HTTP_WANT_SAPI
-#define HTTP_WANT_CURL
-#define HTTP_WANT_MAGIC
-#include "php_http.h"
-
-#ifdef ZEND_ENGINE_2
-
-#include "zend_interfaces.h"
-#include "ext/standard/url.h"
-#include "php_variables.h"
-
-#include "php_http_api.h"
-#include "php_http_send_api.h"
-#include "php_http_url_api.h"
-#include "php_http_message_api.h"
-#include "php_http_message_object.h"
-#include "php_http_exception_object.h"
-#include "php_http_response_object.h"
-#include "php_http_request_method_api.h"
-#include "php_http_request_api.h"
-#include "php_http_request_object.h"
-#include "php_http_headers_api.h"
-
-#if defined(HTTP_HAVE_SPL) && !defined(WONKY)
-/* SPL doesn't install its headers */
-extern PHPAPI zend_class_entry *spl_ce_Countable;
-#endif
-
-#define HTTP_BEGIN_ARGS(method, req_args) HTTP_BEGIN_ARGS_EX(HttpMessage, method, 0, req_args)
-#define HTTP_EMPTY_ARGS(method) HTTP_EMPTY_ARGS_EX(HttpMessage, method, 0)
-#define HTTP_MESSAGE_ME(method, visibility) PHP_ME(HttpMessage, method, HTTP_ARGS(HttpMessage, method), visibility)
-
-HTTP_BEGIN_ARGS(__construct, 0)
- HTTP_ARG_VAL(message, 0)
-HTTP_END_ARGS;
-
-HTTP_BEGIN_ARGS(factory, 0)
- HTTP_ARG_VAL(message, 0)
- HTTP_ARG_VAL(class_name, 0)
-HTTP_END_ARGS;
-
-HTTP_BEGIN_ARGS(fromEnv, 1)
- HTTP_ARG_VAL(type, 0)
- HTTP_ARG_VAL(class_name, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getBody);
-HTTP_BEGIN_ARGS(setBody, 1)
- HTTP_ARG_VAL(body, 0)
-HTTP_END_ARGS;
-
-HTTP_BEGIN_ARGS(getHeader, 1)
- HTTP_ARG_VAL(header, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getHeaders);
-HTTP_BEGIN_ARGS(setHeaders, 1)
- HTTP_ARG_VAL(headers, 0)
-HTTP_END_ARGS;
-
-HTTP_BEGIN_ARGS(addHeaders, 1)
- HTTP_ARG_VAL(headers, 0)
- HTTP_ARG_VAL(append, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getType);
-HTTP_BEGIN_ARGS(setType, 1)
- HTTP_ARG_VAL(type, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getInfo);
-HTTP_BEGIN_ARGS(setInfo, 1)
- HTTP_ARG_VAL(http_info, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getResponseCode);
-HTTP_BEGIN_ARGS(setResponseCode, 1)
- HTTP_ARG_VAL(response_code, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getResponseStatus);
-HTTP_BEGIN_ARGS(setResponseStatus, 1)
- HTTP_ARG_VAL(response_status, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getRequestMethod);
-HTTP_BEGIN_ARGS(setRequestMethod, 1)
- HTTP_ARG_VAL(request_method, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getRequestUrl);
-HTTP_BEGIN_ARGS(setRequestUrl, 1)
- HTTP_ARG_VAL(url, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getHttpVersion);
-HTTP_BEGIN_ARGS(setHttpVersion, 1)
- HTTP_ARG_VAL(http_version, 0)
-HTTP_END_ARGS;
-
-HTTP_BEGIN_ARGS(guessContentType, 1)
- HTTP_ARG_VAL(magic_file, 0)
- HTTP_ARG_VAL(magic_mode, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(getParentMessage);
-HTTP_EMPTY_ARGS(send);
-HTTP_EMPTY_ARGS(__toString);
-HTTP_BEGIN_ARGS(toString, 0)
- HTTP_ARG_VAL(include_parent, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(toMessageTypeObject);
-
-HTTP_EMPTY_ARGS(count);
-
-HTTP_EMPTY_ARGS(serialize);
-HTTP_BEGIN_ARGS(unserialize, 1)
- HTTP_ARG_VAL(serialized, 0)
-HTTP_END_ARGS;
-
-HTTP_EMPTY_ARGS(rewind);
-HTTP_EMPTY_ARGS(valid);
-HTTP_EMPTY_ARGS(key);
-HTTP_EMPTY_ARGS(current);
-HTTP_EMPTY_ARGS(next);
-
-HTTP_EMPTY_ARGS(detach);
-HTTP_BEGIN_ARGS(prepend, 1)
- HTTP_ARG_OBJ(HttpMessage, message, 0)
-HTTP_END_ARGS;
-HTTP_EMPTY_ARGS(reverse);
-
-#define http_message_object_read_prop _http_message_object_read_prop
-static zval *_http_message_object_read_prop(zval *object, zval *member, int type ZEND_LITERAL_KEY_DC TSRMLS_DC);
-#define http_message_object_write_prop _http_message_object_write_prop
-static void _http_message_object_write_prop(zval *object, zval *member, zval *value ZEND_LITERAL_KEY_DC TSRMLS_DC);
-#define http_message_object_get_prop_ptr _http_message_object_get_prop_ptr
-static zval **_http_message_object_get_prop_ptr(zval *object, zval *member ZEND_LITERAL_KEY_DC TSRMLS_DC);
-#define http_message_object_get_props _http_message_object_get_props
-static HashTable *_http_message_object_get_props(zval *object TSRMLS_DC);
-
-#define THIS_CE http_message_object_ce
-zend_class_entry *http_message_object_ce;
-zend_function_entry http_message_object_fe[] = {
- HTTP_MESSAGE_ME(__construct, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR)
- HTTP_MESSAGE_ME(getBody, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setBody, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getHeader, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getHeaders, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setHeaders, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(addHeaders, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getType, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setType, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getInfo, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setInfo, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getResponseCode, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setResponseCode, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getResponseStatus, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setResponseStatus, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getRequestMethod, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setRequestMethod, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getRequestUrl, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setRequestUrl, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getHttpVersion, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(setHttpVersion, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(guessContentType, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(getParentMessage, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(send, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(toString, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(toMessageTypeObject, ZEND_ACC_PUBLIC)
-
- /* implements Countable */
- HTTP_MESSAGE_ME(count, ZEND_ACC_PUBLIC)
-
- /* implements Serializable */
- HTTP_MESSAGE_ME(serialize, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(unserialize, ZEND_ACC_PUBLIC)
-
- /* implements Iterator */
- HTTP_MESSAGE_ME(rewind, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(valid, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(current, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(key, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(next, ZEND_ACC_PUBLIC)
-
- ZEND_MALIAS(HttpMessage, __toString, toString, HTTP_ARGS(HttpMessage, __toString), ZEND_ACC_PUBLIC)
-
- HTTP_MESSAGE_ME(factory, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
- ZEND_MALIAS(HttpMessage, fromString, factory, HTTP_ARGS(HttpMessage, factory), ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
- HTTP_MESSAGE_ME(fromEnv, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
-
- HTTP_MESSAGE_ME(detach, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(prepend, ZEND_ACC_PUBLIC)
- HTTP_MESSAGE_ME(reverse, ZEND_ACC_PUBLIC)
-
- EMPTY_FUNCTION_ENTRY
-};
-static zend_object_handlers http_message_object_handlers;
-
-static HashTable http_message_object_prophandlers;
-
-typedef void (*http_message_object_prophandler_func)(http_message_object *o, zval *v TSRMLS_DC);
-
-typedef struct _http_message_object_prophandler {
- http_message_object_prophandler_func read;
- http_message_object_prophandler_func write;
-} http_message_object_prophandler;
-
-static STATUS http_message_object_add_prophandler(const char *prop_str, size_t prop_len, http_message_object_prophandler_func read, http_message_object_prophandler_func write) {
- http_message_object_prophandler h = { read, write };
- return zend_hash_add(&http_message_object_prophandlers, prop_str, prop_len, (void *) &h, sizeof(h), NULL);
-}
-static STATUS http_message_object_get_prophandler(const char *prop_str, size_t prop_len, http_message_object_prophandler **handler) {
- return zend_hash_find(&http_message_object_prophandlers, prop_str, prop_len, (void *) handler);
-}
-static void http_message_object_prophandler_get_type(http_message_object *obj, zval *return_value TSRMLS_DC) {
- RETVAL_LONG(obj->message->type);
-}
-static void http_message_object_prophandler_set_type(http_message_object *obj, zval *value TSRMLS_DC) {
- zval *cpy = http_zsep(IS_LONG, value);
- http_message_set_type(obj->message, Z_LVAL_P(cpy));
- zval_ptr_dtor(&cpy);
-}
-static void http_message_object_prophandler_get_body(http_message_object *obj, zval *return_value TSRMLS_DC) {
- phpstr_fix(PHPSTR(obj->message));
- RETVAL_PHPSTR(PHPSTR(obj->message), 0, 1);
-}
-static void http_message_object_prophandler_set_body(http_message_object *obj, zval *value TSRMLS_DC) {
- zval *cpy = http_zsep(IS_STRING, value);
- phpstr_dtor(PHPSTR(obj->message));
- phpstr_from_string_ex(PHPSTR(obj->message), Z_STRVAL_P(cpy), Z_STRLEN_P(cpy));
- zval_ptr_dtor(&cpy);
-}
-static void http_message_object_prophandler_get_request_method(http_message_object *obj, zval *return_value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(REQUEST, obj->message) && obj->message->http.info.request.method) {
- RETVAL_STRING(obj->message->http.info.request.method, 1);
- } else {
- RETVAL_NULL();
- }
-}
-static void http_message_object_prophandler_set_request_method(http_message_object *obj, zval *value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(REQUEST, obj->message)) {
- zval *cpy = http_zsep(IS_STRING, value);
- STR_SET(obj->message->http.info.request.method, estrndup(Z_STRVAL_P(cpy), Z_STRLEN_P(cpy)));
- zval_ptr_dtor(&cpy);
- }
-}
-static void http_message_object_prophandler_get_request_url(http_message_object *obj, zval *return_value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(REQUEST, obj->message) && obj->message->http.info.request.url) {
- RETVAL_STRING(obj->message->http.info.request.url, 1);
- } else {
- RETVAL_NULL();
- }
-}
-static void http_message_object_prophandler_set_request_url(http_message_object *obj, zval *value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(REQUEST, obj->message)) {
- zval *cpy = http_zsep(IS_STRING, value);
- STR_SET(obj->message->http.info.request.url, estrndup(Z_STRVAL_P(cpy), Z_STRLEN_P(cpy)));
- zval_ptr_dtor(&cpy);
- }
-}
-static void http_message_object_prophandler_get_response_status(http_message_object *obj, zval *return_value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(RESPONSE, obj->message) && obj->message->http.info.response.status) {
- RETVAL_STRING(obj->message->http.info.response.status, 1);
- } else {
- RETVAL_NULL();
- }
-}
-static void http_message_object_prophandler_set_response_status(http_message_object *obj, zval *value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(RESPONSE, obj->message)) {
- zval *cpy = http_zsep(IS_STRING, value);
- STR_SET(obj->message->http.info.response.status, estrndup(Z_STRVAL_P(cpy), Z_STRLEN_P(cpy)));
- zval_ptr_dtor(&cpy);
- }
-}
-static void http_message_object_prophandler_get_response_code(http_message_object *obj, zval *return_value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(RESPONSE, obj->message)) {
- RETVAL_LONG(obj->message->http.info.response.code);
- } else {
- RETVAL_NULL();
- }
-}
-static void http_message_object_prophandler_set_response_code(http_message_object *obj, zval *value TSRMLS_DC) {
- if (HTTP_MSG_TYPE(RESPONSE, obj->message)) {
- zval *cpy = http_zsep(IS_LONG, value);
- obj->message->http.info.response.code = Z_LVAL_P(cpy);
- zval_ptr_dtor(&cpy);
- }
-}
-static void http_message_object_prophandler_get_http_version(http_message_object *obj, zval *return_value TSRMLS_DC) {
- RETVAL_DOUBLE(obj->message->http.version);
-}
-static void http_message_object_prophandler_set_http_version(http_message_object *obj, zval *value TSRMLS_DC) {
- zval *cpy = http_zsep(IS_DOUBLE, value);
- obj->message->http.version = Z_DVAL_P(cpy);
- zval_ptr_dtor(&cpy);
-}
-static void http_message_object_prophandler_get_headers(http_message_object *obj, zval *return_value TSRMLS_DC) {
- array_init(return_value);
- zend_hash_copy(Z_ARRVAL_P(return_value), &obj->message->hdrs, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
-}
-static void http_message_object_prophandler_set_headers(http_message_object *obj, zval *value TSRMLS_DC) {
- zval *cpy = http_zsep(IS_ARRAY, value);
- zend_hash_clean(&obj->message->hdrs);
- zend_hash_copy(&obj->message->hdrs, Z_ARRVAL_P(cpy), (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
- zval_ptr_dtor(&cpy);
-}
-static void http_message_object_prophandler_get_parent_message(http_message_object *obj, zval *return_value TSRMLS_DC) {
- if (obj->message->parent) {
- RETVAL_OBJVAL(obj->parent, 1);
- } else {
- RETVAL_NULL();
- }
-}
-static void http_message_object_prophandler_set_parent_message(http_message_object *obj, zval *value TSRMLS_DC) {
- if (Z_TYPE_P(value) == IS_OBJECT && instanceof_function(Z_OBJCE_P(value), http_message_object_ce TSRMLS_CC)) {
- if (obj->message->parent) {
- zval tmp;
- tmp.value.obj = obj->parent;
- Z_OBJ_DELREF(tmp);
- }
- Z_OBJ_ADDREF_P(value);
- obj->parent = value->value.obj;
- }
-}
-
-PHP_MINIT_FUNCTION(http_message_object)
-{
- HTTP_REGISTER_CLASS_EX(HttpMessage, http_message_object, NULL, 0);
-
-#ifndef WONKY
-# ifdef HTTP_HAVE_SPL
- zend_class_implements(http_message_object_ce TSRMLS_CC, 3, spl_ce_Countable, zend_ce_serializable, zend_ce_iterator);
-# else
- zend_class_implements(http_message_object_ce TSRMLS_CC, 2, zend_ce_serializable, zend_ce_iterator);
-# endif
-#else
- zend_class_implements(http_message_object_ce TSRMLS_CC, 1, zend_ce_iterator);
-#endif
-
- http_message_object_handlers.clone_obj = _http_message_object_clone_obj;
- http_message_object_handlers.read_property = http_message_object_read_prop;
- http_message_object_handlers.write_property = http_message_object_write_prop;
- http_message_object_handlers.get_properties = http_message_object_get_props;
- http_message_object_handlers.get_property_ptr_ptr = http_message_object_get_prop_ptr;
-
- zend_hash_init(&http_message_object_prophandlers, 9, NULL, NULL, 1);
- zend_declare_property_long(THIS_CE, ZEND_STRS("type")-1, HTTP_MSG_NONE, ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("type")-1, http_message_object_prophandler_get_type, http_message_object_prophandler_set_type);
- zend_declare_property_string(THIS_CE, ZEND_STRS("body")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("body")-1, http_message_object_prophandler_get_body, http_message_object_prophandler_set_body);
- zend_declare_property_string(THIS_CE, ZEND_STRS("requestMethod")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("requestMethod")-1, http_message_object_prophandler_get_request_method, http_message_object_prophandler_set_request_method);
- zend_declare_property_string(THIS_CE, ZEND_STRS("requestUrl")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("requestUrl")-1, http_message_object_prophandler_get_request_url, http_message_object_prophandler_set_request_url);
- zend_declare_property_string(THIS_CE, ZEND_STRS("responseStatus")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("responseStatus")-1, http_message_object_prophandler_get_response_status, http_message_object_prophandler_set_response_status);
- zend_declare_property_long(THIS_CE, ZEND_STRS("responseCode")-1, 0, ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("responseCode")-1, http_message_object_prophandler_get_response_code, http_message_object_prophandler_set_response_code);
- zend_declare_property_null(THIS_CE, ZEND_STRS("httpVersion")-1, ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("httpVersion")-1, http_message_object_prophandler_get_http_version, http_message_object_prophandler_set_http_version);
- zend_declare_property_null(THIS_CE, ZEND_STRS("headers")-1, ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("headers")-1, http_message_object_prophandler_get_headers, http_message_object_prophandler_set_headers);
- zend_declare_property_null(THIS_CE, ZEND_STRS("parentMessage")-1, ZEND_ACC_PROTECTED TSRMLS_CC);
- http_message_object_add_prophandler(ZEND_STRS("parentMessage")-1, http_message_object_prophandler_get_parent_message, http_message_object_prophandler_set_parent_message);
-
-#ifndef WONKY
- zend_declare_class_constant_long(THIS_CE, ZEND_STRS("TYPE_NONE")-1, HTTP_MSG_NONE TSRMLS_CC);
- zend_declare_class_constant_long(THIS_CE, ZEND_STRS("TYPE_REQUEST")-1, HTTP_MSG_REQUEST TSRMLS_CC);
- zend_declare_class_constant_long(THIS_CE, ZEND_STRS("TYPE_RESPONSE")-1, HTTP_MSG_RESPONSE TSRMLS_CC);
-#endif
-
- HTTP_LONG_CONSTANT("HTTP_MSG_NONE", HTTP_MSG_NONE);
- HTTP_LONG_CONSTANT("HTTP_MSG_REQUEST", HTTP_MSG_REQUEST);
- HTTP_LONG_CONSTANT("HTTP_MSG_RESPONSE", HTTP_MSG_RESPONSE);
-
- return SUCCESS;
-}
-
-PHP_MSHUTDOWN_FUNCTION(http_message_object)
-{
- zend_hash_destroy(&http_message_object_prophandlers);
-
- return SUCCESS;
-}
-
-void _http_message_object_reverse(zval *this_ptr, zval *return_value TSRMLS_DC)
-{
- int i;
- getObject(http_message_object, obj);
-
- /* count */
- http_message_count(i, obj->message);
-
- if (i > 1) {
- zval o;
- zend_object_value *ovalues = NULL;
- http_message_object **objects = NULL;
- int last = i - 1;
-
- objects = ecalloc(i, sizeof(http_message_object *));
- ovalues = ecalloc(i, sizeof(zend_object_value));
-
- /* we are the first message */
- objects[0] = obj;
- ovalues[0] = getThis()->value.obj;
-
- /* fetch parents */
- INIT_PZVAL(&o);
- o.type = IS_OBJECT;
- for (i = 1; obj->parent.handle; ++i) {
- o.value.obj = obj->parent;
- ovalues[i] = o.value.obj;
- objects[i] = obj = zend_object_store_get_object(&o TSRMLS_CC);
- }
-
- /* reorder parents */
- for (last = --i; i; --i) {
- objects[i]->message->parent = objects[i-1]->message;
- objects[i]->parent = ovalues[i-1];
- }
- objects[0]->message->parent = NULL;
- objects[0]->parent.handle = 0;
- objects[0]->parent.handlers = NULL;
-
- /* add ref (why?) */
- Z_OBJ_ADDREF_P(getThis());
- RETVAL_OBJVAL(ovalues[last], 1);
-
- efree(objects);
- efree(ovalues);
- } else {
- RETURN_ZVAL(getThis(), 1, 0);
- }
-}
-
-void _http_message_object_prepend_ex(zval *this_ptr, zval *prepend, zend_bool top TSRMLS_DC)
-{
- zval m;
- http_message *save_parent_msg = NULL;
- zend_object_value save_parent_obj = {0, NULL};
- getObject(http_message_object, obj);
- getObjectEx(http_message_object, prepend_obj, prepend);
-
- INIT_PZVAL(&m);
- m.type = IS_OBJECT;
-
- if (!top) {
- save_parent_obj = obj->parent;
- save_parent_msg = obj->message->parent;
- } else {
- /* iterate to the most parent object */
- while (obj->parent.handle) {
- m.value.obj = obj->parent;
- obj = zend_object_store_get_object(&m TSRMLS_CC);
- }
- }
-
- /* prepend */
- obj->parent = prepend->value.obj;
- obj->message->parent = prepend_obj->message;
-
- /* add ref */
- zend_objects_store_add_ref(prepend TSRMLS_CC);
- while (prepend_obj->parent.handle) {
- m.value.obj = prepend_obj->parent;
- zend_objects_store_add_ref(&m TSRMLS_CC);
- prepend_obj = zend_object_store_get_object(&m TSRMLS_CC);
- }
-
- if (!top) {
- prepend_obj->parent = save_parent_obj;
- prepend_obj->message->parent = save_parent_msg;
- }
-}
-
-zend_object_value _http_message_object_new(zend_class_entry *ce TSRMLS_DC)
-{
- return http_message_object_new_ex(ce, NULL, NULL);
-}
-
-zend_object_value _http_message_object_new_ex(zend_class_entry *ce, http_message *msg, http_message_object **ptr TSRMLS_DC)
-{
- zend_object_value ov;
- http_message_object *o;
-
- o = ecalloc(1, sizeof(http_message_object));
- o->zo.ce = ce;
-
- if (ptr) {
- *ptr = o;
- }
-
- if (msg) {
- o->message = msg;
- if (msg->parent) {
- o->parent = http_message_object_new_ex(ce, msg->parent, NULL);
- }
- }
-
-
-#ifdef ZEND_ENGINE_2_4
- zend_object_std_init(o, ce TSRMLS_CC);
- object_properties_init(o, ce);
-#else
- ALLOC_HASHTABLE(OBJ_PROP(o));
- zend_hash_init(OBJ_PROP(o), zend_hash_num_elements(&ce->default_properties), NULL, ZVAL_PTR_DTOR, 0);
- zend_hash_copy(OBJ_PROP(o), &ce->default_properties, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
-#endif
-
- ov.handle = putObject(http_message_object, o);
- ov.handlers = &http_message_object_handlers;
-
- return ov;
-}
-
-zend_object_value _http_message_object_clone_obj(zval *this_ptr TSRMLS_DC)
-{
- zend_object_value new_ov;
- http_message_object *new_obj = NULL;
- getObject(http_message_object, old_obj);
-
- new_ov = http_message_object_new_ex(old_obj->zo.ce, http_message_dup(old_obj->message), &new_obj);
- zend_objects_clone_members(&new_obj->zo, new_ov, &old_obj->zo, Z_OBJ_HANDLE_P(this_ptr) TSRMLS_CC);
-
- return new_ov;
-}
-
-void _http_message_object_free(zend_object *object TSRMLS_DC)
-{
- http_message_object *o = (http_message_object *) object;
-
- if (o->iterator) {
- zval_ptr_dtor(&o->iterator);
- o->iterator = NULL;
- }
- if (o->message) {
- http_message_dtor(o->message);
- efree(o->message);
- }
- if (o->parent.handle) {
- zval p;
-
- INIT_PZVAL(&p);
- p.type = IS_OBJECT;
- p.value.obj = o->parent;
- zend_objects_store_del_ref(&p TSRMLS_CC);
- }
- freeObject(o);
-}
-
-static zval **_http_message_object_get_prop_ptr(zval *object, zval *member ZEND_LITERAL_KEY_DC TSRMLS_DC) {
- getObjectEx(http_message_object, obj, object);
- http_message_object_prophandler *handler;
-
- if (SUCCESS == http_message_object_get_prophandler(Z_STRVAL_P(member), Z_STRLEN_P(member), &handler)) {
- zend_error(E_ERROR, "Cannot access HttpMessage properties by reference or array key/index");
- return NULL;
- }
-
- return zend_get_std_object_handlers()->get_property_ptr_ptr(object, member ZEND_LITERAL_KEY_CC TSRMLS_CC);
-}
-
-static zval *_http_message_object_read_prop(zval *object, zval *member, int type ZEND_LITERAL_KEY_DC TSRMLS_DC)
-{
- getObjectEx(http_message_object, obj, object);
- http_message_object_prophandler *handler;
- zval *return_value;
-
- if (SUCCESS == http_message_object_get_prophandler(Z_STRVAL_P(member), Z_STRLEN_P(member), &handler)) {
- if (type == BP_VAR_W) {
- zend_error(E_ERROR, "Cannot access HttpMessage properties by reference or array key/index");
- return NULL;
- }
-
- ALLOC_ZVAL(return_value);
-#ifdef Z_SET_REFCOUNT
- Z_SET_REFCOUNT_P(return_value, 0);
- Z_UNSET_ISREF_P(return_value);
-#else
- return_value->refcount = 0;
- return_value->is_ref = 0;
-#endif
-
- handler->read(obj, return_value TSRMLS_CC);
-
- } else {
- return_value = zend_get_std_object_handlers()->read_property(object, member, type ZEND_LITERAL_KEY_CC TSRMLS_CC);
- }
-
- return return_value;
-}
-
-static void _http_message_object_write_prop(zval *object, zval *member, zval *value ZEND_LITERAL_KEY_DC TSRMLS_DC)
-{
- getObjectEx(http_message_object, obj, object);
- http_message_object_prophandler *handler;
-
- if (SUCCESS == http_message_object_get_prophandler(Z_STRVAL_P(member), Z_STRLEN_P(member), &handler)) {
- handler->write(obj, value TSRMLS_CC);
- } else {
- zend_get_std_object_handlers()->write_property(object, member, value ZEND_LITERAL_KEY_CC TSRMLS_CC);
- }
-}
-
-static HashTable *_http_message_object_get_props(zval *object TSRMLS_DC)
-{
- zval *headers;
- getObjectEx(http_message_object, obj, object);
- http_message *msg = obj->message;
- zval array, *parent;
-#ifdef ZEND_ENGINE_2_4
- HashTable *props = zend_get_std_object_handlers()->get_properties(object TSRMLS_CC);
-#else
- HashTable *props = OBJ_PROP(obj);
-#endif
- INIT_ZARR(array, props);
-
-#define ASSOC_PROP(array, ptype, name, val) \
- { \
- char *m_prop_name; \
- int m_prop_len; \
- zend_mangle_property_name(&m_prop_name, &m_prop_len, "*", 1, name, lenof(name), 0); \
- add_assoc_ ##ptype## _ex(&array, m_prop_name, sizeof(name)+3, val); \
- efree(m_prop_name); \
- }
-#define ASSOC_STRING(array, name, val) ASSOC_STRINGL(array, name, val, strlen(val))
-#define ASSOC_STRINGL(array, name, val, len) \
- { \
- char *m_prop_name; \
- int m_prop_len; \
- zend_mangle_property_name(&m_prop_name, &m_prop_len, "*", 1, name, lenof(name), 0); \
- add_assoc_stringl_ex(&array, m_prop_name, sizeof(name)+3, val, len, 1); \
- efree(m_prop_name); \
- }
-
- ASSOC_PROP(array, long, "type", msg->type);
- ASSOC_PROP(array, double, "httpVersion", msg->http.version);
-
- switch (msg->type) {
- case HTTP_MSG_REQUEST:
- ASSOC_PROP(array, long, "responseCode", 0);
- ASSOC_STRINGL(array, "responseStatus", "", 0);
- ASSOC_STRING(array, "requestMethod", STR_PTR(msg->http.info.request.method));
- ASSOC_STRING(array, "requestUrl", STR_PTR(msg->http.info.request.url));
- break;
-
- case HTTP_MSG_RESPONSE:
- ASSOC_PROP(array, long, "responseCode", msg->http.info.response.code);
- ASSOC_STRING(array, "responseStatus", STR_PTR(msg->http.info.response.status));
- ASSOC_STRINGL(array, "requestMethod", "", 0);
- ASSOC_STRINGL(array, "requestUrl", "", 0);
- break;
-
- case HTTP_MSG_NONE:
- default:
- ASSOC_PROP(array, long, "responseCode", 0);
- ASSOC_STRINGL(array, "responseStatus", "", 0);
- ASSOC_STRINGL(array, "requestMethod", "", 0);
- ASSOC_STRINGL(array, "requestUrl", "", 0);
- break;
- }
-
- MAKE_STD_ZVAL(headers);
- array_init(headers);
- zend_hash_copy(Z_ARRVAL_P(headers), &msg->hdrs, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
- ASSOC_PROP(array, zval, "headers", headers);
- ASSOC_STRINGL(array, "body", PHPSTR_VAL(msg), PHPSTR_LEN(msg));
-
- MAKE_STD_ZVAL(parent);
- if (msg->parent) {
- ZVAL_OBJVAL(parent, obj->parent, 1);
- } else {
- ZVAL_NULL(parent);
- }
- ASSOC_PROP(array, zval, "parentMessage", parent);
-
- return props;
-}
-
-/* ### USERLAND ### */
-
-/* {{{ proto void HttpMessage::__construct([string message])
- Create a new HttpMessage object instance. */
-PHP_METHOD(HttpMessage, __construct)
-{
- int length = 0;
- char *message = NULL;
-
- getObject(http_message_object, obj);
-
- SET_EH_THROW_HTTP();
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|s", &message, &length) && message && length) {
- http_message *msg = obj->message;
-
- http_message_dtor(msg);
- if ((obj->message = http_message_parse_ex(msg, message, length))) {
- if (obj->message->parent) {
- obj->parent = http_message_object_new_ex(Z_OBJCE_P(getThis()), obj->message->parent, NULL);
- }
- } else {
- obj->message = http_message_init(msg);
- }
- }
- if (!obj->message) {
- obj->message = http_message_new();
- }
- SET_EH_NORMAL();
-}
-/* }}} */
-
-/* {{{ proto static HttpMessage HttpMessage::factory([string raw_message[, string class_name = "HttpMessage"]])
- Create a new HttpMessage object instance. */
-PHP_METHOD(HttpMessage, factory)
-{
- char *string = NULL, *cn = NULL;
- int length = 0, cl = 0;
- http_message *msg = NULL;
- zend_object_value ov;
- http_message_object *obj = NULL;
-
- RETVAL_NULL();
-
- SET_EH_THROW_HTTP();
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|ss", &string, &length, &cn, &cl)) {
- if (length) {
- msg = http_message_parse(string, length);
- }
- if ((msg || !length) && SUCCESS == http_object_new(&ov, cn, cl, _http_message_object_new_ex, http_message_object_ce, msg, &obj)) {
- RETVAL_OBJVAL(ov, 0);
- }
- if (obj && !obj->message) {
- obj->message = http_message_new();
- }
- }
- SET_EH_NORMAL();
-}
-/* }}} */
-
-/* {{{ proto static HttpMessage HttpMessage::fromEnv(int type[, string class_name = "HttpMessage"])
- Create a new HttpMessage object from environment representing either current request or response */
-PHP_METHOD(HttpMessage, fromEnv)
-{
- char *cn = NULL;
- int cl = 0;
- long type;
- http_message_object *obj = NULL;
- zend_object_value ov;
-
- RETVAL_NULL();
- SET_EH_THROW_HTTP();
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l|s", &type, &cn, &cl)) {
- if (SUCCESS == http_object_new(&ov, cn, cl, _http_message_object_new_ex, http_message_object_ce, http_message_init_env(NULL, type), &obj)) {
- RETVAL_OBJVAL(ov, 0);
- }
- if (obj && !obj->message) {
- obj->message = http_message_new();
- }
- }
- SET_EH_NORMAL();
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::getBody()
- Get the body of the parsed HttpMessage. */
-PHP_METHOD(HttpMessage, getBody)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
- RETURN_PHPSTR(&obj->message->body, PHPSTR_FREE_NOT, 1);
- }
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::setBody(string body)
- Set the body of the HttpMessage. NOTE: Don't forget to update any headers accordingly. */
-PHP_METHOD(HttpMessage, setBody)
-{
- char *body;
- int len;
- getObject(http_message_object, obj);
-
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &body, &len)) {
- phpstr_dtor(PHPSTR(obj->message));
- phpstr_from_string_ex(PHPSTR(obj->message), body, len);
- }
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::getHeader(string header)
- Get message header. */
-PHP_METHOD(HttpMessage, getHeader)
-{
- zval *header;
- char *orig_header, *nice_header;
- int header_len;
- getObject(http_message_object, obj);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &orig_header, &header_len)) {
- RETURN_FALSE;
- }
-
- nice_header = pretty_key(estrndup(orig_header, header_len), header_len, 1, 1);
- if ((header = http_message_header_ex(obj->message, nice_header, header_len + 1, 0))) {
- RETVAL_ZVAL(header, 1, 1);
- }
- efree(nice_header);
-}
-/* }}} */
-
-/* {{{ proto array HttpMessage::getHeaders()
- Get Message Headers. */
-PHP_METHOD(HttpMessage, getHeaders)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
-
- array_init(return_value);
- array_copy(&obj->message->hdrs, Z_ARRVAL_P(return_value));
- }
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::setHeaders(array headers)
- Sets new headers. */
-PHP_METHOD(HttpMessage, setHeaders)
-{
- zval *new_headers = NULL;
- getObject(http_message_object, obj);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a/!", &new_headers)) {
- return;
- }
-
- zend_hash_clean(&obj->message->hdrs);
- if (new_headers) {
- array_copy(Z_ARRVAL_P(new_headers), &obj->message->hdrs);
- }
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::addHeaders(array headers[, bool append = false])
- Add headers. If append is true, headers with the same name will be separated, else overwritten. */
-PHP_METHOD(HttpMessage, addHeaders)
-{
- zval *new_headers;
- zend_bool append = 0;
- getObject(http_message_object, obj);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a|b", &new_headers, &append)) {
- return;
- }
-
- array_join(Z_ARRVAL_P(new_headers), &obj->message->hdrs, append, ARRAY_JOIN_STRONLY|ARRAY_JOIN_PRETTIFY);
-}
-/* }}} */
-
-/* {{{ proto int HttpMessage::getType()
- Get Message Type. (HTTP_MSG_NONE|HTTP_MSG_REQUEST|HTTP_MSG_RESPONSE) */
-PHP_METHOD(HttpMessage, getType)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
- RETURN_LONG(obj->message->type);
- }
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::setType(int type)
- Set Message Type. (HTTP_MSG_NONE|HTTP_MSG_REQUEST|HTTP_MSG_RESPONSE) */
-PHP_METHOD(HttpMessage, setType)
-{
- long type;
- getObject(http_message_object, obj);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &type)) {
- return;
- }
- http_message_set_type(obj->message, type);
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::getInfo(void)
- Get the HTTP request/response line */
-PHP_METHOD(HttpMessage, getInfo)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
-
- switch (obj->message->type) {
- case HTTP_MSG_REQUEST:
- Z_STRLEN_P(return_value) = spprintf(&Z_STRVAL_P(return_value), 0, HTTP_INFO_REQUEST_FMT_ARGS(&obj->message->http, ""));
- break;
- case HTTP_MSG_RESPONSE:
- Z_STRLEN_P(return_value) = spprintf(&Z_STRVAL_P(return_value), 0, HTTP_INFO_RESPONSE_FMT_ARGS(&obj->message->http, ""));
- break;
- default:
- RETURN_NULL();
- break;
- }
- Z_TYPE_P(return_value) = IS_STRING;
- }
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::setInfo(string http_info)
- Set type and request or response info with a standard HTTP request or response line */
-PHP_METHOD(HttpMessage, setInfo)
-{
- char *str;
- int len;
- http_info inf;
-
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &str, &len) && SUCCESS == http_info_parse_ex(str, &inf, 0)) {
- getObject(http_message_object, obj);
-
- http_message_set_info(obj->message, &inf);
- http_info_dtor(&inf);
- RETURN_TRUE;
- }
- RETURN_FALSE;
-}
-/* }}} */
-
-/* {{{ proto int HttpMessage::getResponseCode()
- Get the Response Code of the Message. */
-PHP_METHOD(HttpMessage, getResponseCode)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
- HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
- RETURN_LONG(obj->message->http.info.response.code);
- }
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::setResponseCode(int code)
- Set the response code of an HTTP Response Message. */
-PHP_METHOD(HttpMessage, setResponseCode)
-{
- long code;
- getObject(http_message_object, obj);
-
- HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &code)) {
- RETURN_FALSE;
- }
- if (code < 100 || code > 599) {
- http_error_ex(HE_WARNING, HTTP_E_INVALID_PARAM, "Invalid response code (100-599): %ld", code);
- RETURN_FALSE;
- }
-
- obj->message->http.info.response.code = code;
- RETURN_TRUE;
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::getResponseStatus()
- Get the Response Status of the message (i.e. the string following the response code). */
-PHP_METHOD(HttpMessage, getResponseStatus)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
- HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
- if (obj->message->http.info.response.status) {
- RETURN_STRING(obj->message->http.info.response.status, 1);
- } else {
- RETURN_EMPTY_STRING();
- }
- }
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::setResponseStatus(string status)
- Set the Response Status of the HTTP message (i.e. the string following the response code). */
-PHP_METHOD(HttpMessage, setResponseStatus)
-{
- char *status;
- int status_len;
- getObject(http_message_object, obj);
-
- HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &status, &status_len)) {
- RETURN_FALSE;
- }
- STR_SET(obj->message->http.info.response.status, estrndup(status, status_len));
- RETURN_TRUE;
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::getRequestMethod()
- Get the Request Method of the Message. */
-PHP_METHOD(HttpMessage, getRequestMethod)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
- HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
- if (obj->message->http.info.request.method) {
- RETURN_STRING(obj->message->http.info.request.method, 1);
- } else {
- RETURN_EMPTY_STRING();
- }
- }
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::setRequestMethod(string method)
- Set the Request Method of the HTTP Message. */
-PHP_METHOD(HttpMessage, setRequestMethod)
-{
- char *method;
- int method_len;
- getObject(http_message_object, obj);
-
- HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &method, &method_len)) {
- RETURN_FALSE;
- }
- if (method_len < 1) {
- http_error(HE_WARNING, HTTP_E_INVALID_PARAM, "Cannot set HttpMessage::requestMethod to an empty string");
- RETURN_FALSE;
- }
- if (!http_request_method_exists(1, 0, method)) {
- http_error_ex(HE_WARNING, HTTP_E_REQUEST_METHOD, "Unknown request method: %s", method);
- RETURN_FALSE;
- }
-
- STR_SET(obj->message->http.info.request.method, estrndup(method, method_len));
- RETURN_TRUE;
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::getRequestUrl()
- Get the Request URL of the Message. */
-PHP_METHOD(HttpMessage, getRequestUrl)
-{
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
- HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
- if (obj->message->http.info.request.url) {
- RETURN_STRING(obj->message->http.info.request.url, 1);
- } else {
- RETURN_EMPTY_STRING();
- }
- }
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::setRequestUrl(string url)
- Set the Request URL of the HTTP Message. */
-PHP_METHOD(HttpMessage, setRequestUrl)
-{
- char *URI;
- int URIlen;
- getObject(http_message_object, obj);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &URI, &URIlen)) {
- RETURN_FALSE;
- }
- HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
- if (URIlen < 1) {
- http_error(HE_WARNING, HTTP_E_INVALID_PARAM, "Cannot set HttpMessage::requestUrl to an empty string");
- RETURN_FALSE;
- }
-
- STR_SET(obj->message->http.info.request.url, estrndup(URI, URIlen));
- RETURN_TRUE;
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::getHttpVersion()
- Get the HTTP Protocol Version of the Message. */
-PHP_METHOD(HttpMessage, getHttpVersion)
-{
- NO_ARGS;
-
- if (return_value_used) {
- char *version;
- getObject(http_message_object, obj);
-
- spprintf(&version, 0, "%1.1F", obj->message->http.version);
- RETURN_STRING(version, 0);
- }
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::setHttpVersion(string version)
- Set the HTTP Protocol version of the Message. */
-PHP_METHOD(HttpMessage, setHttpVersion)
-{
- zval *zv;
- char *version;
- getObject(http_message_object, obj);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z/", &zv)) {
- return;
- }
-
- convert_to_double(zv);
- spprintf(&version, 0, "%1.1F", Z_DVAL_P(zv));
- if (strcmp(version, "1.0") && strcmp(version, "1.1")) {
- efree(version);
- http_error_ex(HE_WARNING, HTTP_E_INVALID_PARAM, "Invalid HTTP protocol version (1.0 or 1.1): %g", Z_DVAL_P(zv));
- RETURN_FALSE;
- }
- efree(version);
- obj->message->http.version = Z_DVAL_P(zv);
- RETURN_TRUE;
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::guessContentType(string magic_file[, int magic_mode = MAGIC_MIME])
- Attempts to guess the content type of supplied payload through libmagic. */
-PHP_METHOD(HttpMessage, guessContentType)
-{
-#ifdef HTTP_HAVE_MAGIC
- char *magic_file, *ct = NULL;
- int magic_file_len;
- long magic_mode = MAGIC_MIME;
-
- RETVAL_FALSE;
- SET_EH_THROW_HTTP();
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s|l", &magic_file, &magic_file_len, &magic_mode)) {
- getObject(http_message_object, obj);
- if ((ct = http_guess_content_type(magic_file, magic_mode, PHPSTR_VAL(&obj->message->body), PHPSTR_LEN(&obj->message->body), SEND_DATA))) {
- RETVAL_STRING(ct, 0);
- }
- }
- SET_EH_NORMAL();
-#else
- http_error(HE_THROW, HTTP_E_RUNTIME, "Cannot guess Content-Type; libmagic not available");
- RETURN_FALSE;
-#endif
-}
-/* }}} */
-
-/* {{{ proto HttpMessage HttpMessage::getParentMessage()
- Get parent Message. */
-PHP_METHOD(HttpMessage, getParentMessage)
-{
- SET_EH_THROW_HTTP();
- NO_ARGS {
- getObject(http_message_object, obj);
-
- if (obj->message->parent) {
- RETVAL_OBJVAL(obj->parent, 1);
- } else {
- http_error(HE_WARNING, HTTP_E_RUNTIME, "HttpMessage does not have a parent message");
- }
- }
- SET_EH_NORMAL();
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::send()
- Send the Message according to its type as Response or Request. */
-PHP_METHOD(HttpMessage, send)
-{
- getObject(http_message_object, obj);
-
- NO_ARGS;
-
- RETURN_SUCCESS(http_message_send(obj->message));
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::toString([bool include_parent = false])
- Get the string representation of the Message. */
-PHP_METHOD(HttpMessage, toString)
-{
- if (return_value_used) {
- char *string;
- size_t length;
- zend_bool include_parent = 0;
- getObject(http_message_object, obj);
-
- if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|b", &include_parent)) {
- RETURN_FALSE;
- }
-
- if (include_parent) {
- http_message_serialize(obj->message, &string, &length);
- } else {
- http_message_tostring(obj->message, &string, &length);
- }
- RETURN_STRINGL(string, length, 0);
- }
-}
-/* }}} */
-
-/* {{{ proto HttpRequest|HttpResponse HttpMessage::toMessageTypeObject(void)
- Creates an object regarding to the type of the message. Returns either an HttpRequest or HttpResponse object on success, or NULL on failure. */
-PHP_METHOD(HttpMessage, toMessageTypeObject)
-{
- SET_EH_THROW_HTTP();
-
- NO_ARGS;
-
- if (return_value_used) {
- getObject(http_message_object, obj);
-
- switch (obj->message->type) {
- case HTTP_MSG_REQUEST:
- {
-#ifdef HTTP_HAVE_CURL
- int method;
- char *url;
- zval post, body, *array, *headers, *host = http_message_header(obj->message, "Host");
- php_url hurl, *purl = php_url_parse(STR_PTR(obj->message->http.info.request.url));
-
- MAKE_STD_ZVAL(array);
- array_init(array);
-
- memset(&hurl, 0, sizeof(php_url));
- if (host) {
- hurl.host = Z_STRVAL_P(host);
- zval_ptr_dtor(&host);
- }
- http_build_url(HTTP_URL_REPLACE, purl, &hurl, NULL, &url, NULL);
- php_url_free(purl);
- add_assoc_string(array, "url", url, 0);
-
- if ( obj->message->http.info.request.method &&
- ((method = http_request_method_exists(1, 0, obj->message->http.info.request.method)) ||
- (method = http_request_method_register(obj->message->http.info.request.method, strlen(obj->message->http.info.request.method))))) {
- add_assoc_long(array, "method", method);
- }
-
- if (10 == (int) (obj->message->http.version * 10)) {
- add_assoc_long(array, "protocol", CURL_HTTP_VERSION_1_0);
- }
-
- MAKE_STD_ZVAL(headers);
- array_init(headers);
- array_copy(&obj->message->hdrs, Z_ARRVAL_P(headers));
- add_assoc_zval(array, "headers", headers);
-
- object_init_ex(return_value, http_request_object_ce);
- zend_call_method_with_1_params(&return_value, http_request_object_ce, NULL, "setoptions", NULL, array);
- zval_ptr_dtor(&array);
-
- if (PHPSTR_VAL(obj->message) && PHPSTR_LEN(obj->message)) {
- phpstr_fix(PHPSTR(obj->message));
- INIT_PZVAL(&body);
- ZVAL_STRINGL(&body, PHPSTR_VAL(obj->message), PHPSTR_LEN(obj->message), 0);
- if (method != HTTP_POST) {
- zend_call_method_with_1_params(&return_value, http_request_object_ce, NULL, "setbody", NULL, &body);
- } else {
- INIT_PZVAL(&post);
- array_init(&post);
-
- zval_copy_ctor(&body);
- sapi_module.treat_data(PARSE_STRING, Z_STRVAL(body), &post TSRMLS_CC);
- zend_call_method_with_1_params(&return_value, http_request_object_ce, NULL, "setpostfields", NULL, &post);
- zval_dtor(&post);
- }
- }
-#else
- http_error(HE_WARNING, HTTP_E_RUNTIME, "Cannot transform HttpMessage to HttpRequest (missing curl support)");
-#endif
- break;
- }
-
- case HTTP_MSG_RESPONSE:
- {
-#ifndef WONKY
- HashPosition pos1, pos2;
- HashKey key = initHashKey(0);
- zval **header, **h, *body;
-
- if (obj->message->http.info.response.code) {
- http_send_status(obj->message->http.info.response.code);
- }
-
- object_init_ex(return_value, http_response_object_ce);
-
- FOREACH_HASH_KEYVAL(pos1, &obj->message->hdrs, key, header) {
- if (key.type == HASH_KEY_IS_STRING) {
- zval *zkey;
-
- MAKE_STD_ZVAL(zkey);
- ZVAL_STRINGL(zkey, key.str, key.len - 1, 1);
-
- switch (Z_TYPE_PP(header)) {
- case IS_ARRAY:
- case IS_OBJECT:
- FOREACH_HASH_VAL(pos2, HASH_OF(*header), h) {
- ZVAL_ADDREF(*h);
- zend_call_method_with_2_params(&return_value, http_response_object_ce, NULL, "setheader", NULL, zkey, *h);
- zval_ptr_dtor(h);
- }
- break;
-
- default:
- ZVAL_ADDREF(*header);
- zend_call_method_with_2_params(&return_value, http_response_object_ce, NULL, "setheader", NULL, zkey, *header);
- zval_ptr_dtor(header);
- break;
- }
- zval_ptr_dtor(&zkey);
- }
- }
-
- MAKE_STD_ZVAL(body);
- ZVAL_STRINGL(body, PHPSTR_VAL(obj->message), PHPSTR_LEN(obj->message), 1);
- zend_call_method_with_1_params(&return_value, http_response_object_ce, NULL, "setdata", NULL, body);
- zval_ptr_dtor(&body);
-#else
- http_error(HE_WARNING, HTTP_E_RUNTIME, "Cannot transform HttpMessage to HttpResponse (need PHP 5.1+)");
-#endif
- break;
- }
-
- default:
- http_error(HE_WARNING, HTTP_E_MESSAGE_TYPE, "HttpMessage is neither of type HttpMessage::TYPE_REQUEST nor HttpMessage::TYPE_RESPONSE");
- break;
- }
- }
- SET_EH_NORMAL();
-}
-/* }}} */
-
-/* {{{ proto int HttpMessage::count()
- Implements Countable::count(). Returns the number of parent messages + 1. */
-PHP_METHOD(HttpMessage, count)
-{
- NO_ARGS {
- long i;
- getObject(http_message_object, obj);
-
- http_message_count(i, obj->message);
- RETURN_LONG(i);
- }
-}
-/* }}} */
-
-/* {{{ proto string HttpMessage::serialize()
- Implements Serializable::serialize(). Returns the serialized representation of the HttpMessage. */
-PHP_METHOD(HttpMessage, serialize)
-{
- NO_ARGS {
- char *string;
- size_t length;
- getObject(http_message_object, obj);
-
- http_message_serialize(obj->message, &string, &length);
- RETURN_STRINGL(string, length, 0);
- }
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::unserialize(string serialized)
- Implements Serializable::unserialize(). Re-constructs the HttpMessage based upon the serialized string. */
-PHP_METHOD(HttpMessage, unserialize)
-{
- int length;
- char *serialized;
- getObject(http_message_object, obj);
-
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &serialized, &length)) {
- http_message *msg;
-
- http_message_dtor(obj->message);
- if ((msg = http_message_parse_ex(obj->message, serialized, (size_t) length))) {
- obj->message = msg;
- } else {
- http_message_init(obj->message);
- http_error(HE_ERROR, HTTP_E_RUNTIME, "Could not unserialize HttpMessage");
- }
- }
-}
-/* }}} */
-
-/* {{{ proto HttpMessage HttpMessage::detach(void)
- Returns a clone of an HttpMessage object detached from any parent messages. */
-PHP_METHOD(HttpMessage, detach)
-{
- http_info info;
- http_message *msg;
- getObject(http_message_object, obj);
-
- NO_ARGS;
-
- info.type = obj->message->type;
- memcpy(&HTTP_INFO(&info), &HTTP_INFO(obj->message), sizeof(struct http_info));
-
- msg = http_message_new();
- http_message_set_info(msg, &info);
-
- zend_hash_copy(&msg->hdrs, &obj->message->hdrs, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
- phpstr_append(&msg->body, PHPSTR_VAL(obj->message), PHPSTR_LEN(obj->message));
-
- RETVAL_OBJVAL(http_message_object_new_ex(Z_OBJCE_P(getThis()), msg, NULL), 0);
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::prepend(HttpMessage message[, bool top = true])
- Prepends message(s) to the HTTP message. Throws HttpInvalidParamException if the message is located within the same message chain. */
-PHP_METHOD(HttpMessage, prepend)
-{
- zval *prepend;
- zend_bool top = 1;
-
- if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "O|b", &prepend, http_message_object_ce, &top)) {
- http_message *msg[2];
- getObject(http_message_object, obj);
- getObjectEx(http_message_object, prepend_obj, prepend);
-
- /* safety check */
- for (msg[0] = obj->message; msg[0]; msg[0] = msg[0]->parent) {
- for (msg[1] = prepend_obj->message; msg[1]; msg[1] = msg[1]->parent) {
- if (msg[0] == msg[1]) {
- http_error(HE_THROW, HTTP_E_INVALID_PARAM, "Cannot prepend a message located within the same message chain");
- return;
- }
- }
- }
-
- http_message_object_prepend_ex(getThis(), prepend, top);
- }
-}
-/* }}} */
-
-/* {{{ proto HttpMessage HttpMessage::reverse()
- Reorders the message chain in reverse order. Returns the most parent HttpMessage object. */
-PHP_METHOD(HttpMessage, reverse)
-{
- NO_ARGS {
- http_message_object_reverse(getThis(), return_value);
- }
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::rewind(void)
- Implements Iterator::rewind(). */
-PHP_METHOD(HttpMessage, rewind)
-{
- NO_ARGS {
- getObject(http_message_object, obj);
-
- if (obj->iterator) {
- zval_ptr_dtor(&obj->iterator);
- }
- ZVAL_ADDREF(getThis());
- obj->iterator = getThis();
- }
-}
-/* }}} */
-
-/* {{{ proto bool HttpMessage::valid(void)
- Implements Iterator::valid(). */
-PHP_METHOD(HttpMessage, valid)
-{
- NO_ARGS {
- getObject(http_message_object, obj);
-
- RETURN_BOOL(obj->iterator != NULL);
- }
-}
-/* }}} */
-
-/* {{{ proto void HttpMessage::next(void)
- Implements Iterator::next(). */
-PHP_METHOD(HttpMessage, next)
-{
- NO_ARGS {
- getObject(http_message_object, obj);
- if (obj->iterator) {
- getObjectEx(http_message_object, itr, obj->iterator);
-
- if (itr && itr->parent.handle) {
- zval *old = obj->iterator;
- MAKE_STD_ZVAL(obj->iterator);
- ZVAL_OBJVAL(obj->iterator, itr->parent, 1);
- zval_ptr_dtor(&old);
- } else {
- zval_ptr_dtor(&obj->iterator);
- obj->iterator = NULL;
- }
- }
- }
-}
-/* }}} */
-
-/* {{{ proto int HttpMessage::key(void)
- Implements Iterator::key(). */
-PHP_METHOD(HttpMessage, key)
-{
- NO_ARGS {
- getObject(http_message_object, obj);
-
- RETURN_LONG(obj->iterator ? obj->iterator->value.obj.handle:0);
- }
-}
-/* }}} */
-
-/* {{{ proto HttpMessage HttpMessage::current(void)
- Implements Iterator::current(). */
-PHP_METHOD(HttpMessage, current)
-{
- NO_ARGS {
- getObject(http_message_object, obj);
-
- if (obj->iterator) {
- RETURN_ZVAL(obj->iterator, 1, 0);
- }
- }
-}
-/* }}} */
-
-#endif /* ZEND_ENGINE_2 */
-
-/*
- * Local variables:
- * tab-width: 4
- * c-basic-offset: 4
- * End:
- * vim600: noet sw=4 ts=4 fdm=marker
- * vim<600: noet sw=4 ts=4
- */
-
|
[-]
[+]
|
Deleted |
pecl_http-1.7.5.tar.bz2/pecl_http-1.7.5/missing.h
^
|
@@ -1,184 +0,0 @@
-/*
- +--------------------------------------------------------------------+
- | PECL :: http |
- +--------------------------------------------------------------------+
- | Redistribution and use in source and binary forms, with or without |
- | modification, are permitted provided that the conditions mentioned |
- | in the accompanying LICENSE file are met. |
- +--------------------------------------------------------------------+
- | Copyright (c) 2004-2010, Michael Wallner <mike@php.net> |
- +--------------------------------------------------------------------+
-*/
-
-/* $Id: missing.h 323304 2012-02-17 21:13:24Z mike $ */
-
-#ifndef PHP_HTTP_MISSING
-#define PHP_HTTP_MISSING
-
-#include "php_version.h"
-
-#if ZEND_MODULE_API_NO >= 20100409
-#define ZEND_ENGINE_2_4
-#endif
-
-#if defined(PHP_VERSION_ID) && (PHP_VERSION_ID >= 50399)
-# define ZEND_LITERAL_KEY_DC , const zend_literal *_zend_literal_key
-# define ZEND_LITERAL_KEY_CC , _zend_literal_key
-# define ZEND_LITERAL_NIL_CC , NULL
-# define HTTP_CHECK_OPEN_BASEDIR(file, act) \
- if ((PG(open_basedir) && *PG(open_basedir))) \
- { \
- const char *tmp = file; \
- \
- if (!strncasecmp(tmp, "file:", lenof("file:"))) { \
- tmp += lenof("file:"); \
- while ((tmp - (const char *)file < 7) && (*tmp == '/' || *tmp == '\\')) ++tmp; \
- } \
- \
- if ( (tmp != file || !strstr(file, "://")) && \
- (!*tmp || php_check_open_basedir(tmp TSRMLS_CC))) { \
- act; \
- } \
- }
-
-#else
-# define ZEND_LITERAL_KEY_DC
-# define ZEND_LITERAL_KEY_CC
-# define ZEND_LITERAL_NIL_CC
-# define HTTP_CHECK_OPEN_BASEDIR(file, act) \
- if ((PG(open_basedir) && *PG(open_basedir)) || PG(safe_mode)) \
- { \
- const char *tmp = file; \
- \
- if (!strncasecmp(tmp, "file:", lenof("file:"))) { \
- tmp += lenof("file:"); \
- while ((tmp - (const char *)file < 7) && (*tmp == '/' || *tmp == '\\')) ++tmp; \
- } \
- \
- if ( (tmp != file || !strstr(file, "://")) && \
- (!*tmp || php_check_open_basedir(tmp TSRMLS_CC) || \
- (PG(safe_mode) && !php_checkuid(tmp, "rb+", CHECKUID_CHECK_MODE_PARAM)))) { \
- act; \
- } \
- }
-
-#endif
-
-#if (PHP_MAJOR_VERSION == 5) && (PHP_MINOR_VERSION >= 3)
-# define HTTP_ZAPI_HASH_TSRMLS_CC TSRMLS_CC
-# define HTTP_ZAPI_HASH_TSRMLS_DC TSRMLS_DC
-# define HTTP_ZAPI_CONST_CAST(t) (const t)
-# define GLOBAL_ERROR_HANDLING EG(error_handling)
-# define GLOBAL_EXCEPTION_CLASS EG(exception_class)
-# define HTTP_IS_CALLABLE(cb_zv, flags, cb_sp) zend_is_callable((cb_zv), (flags), (cb_sp) TSRMLS_CC)
-# define HTTP_STATIC_ARG_INFO
-#else
-# define HTTP_ZAPI_HASH_TSRMLS_CC
-# define HTTP_ZAPI_HASH_TSRMLS_DC
-# define HTTP_ZAPI_CONST_CAST(t) (t)
-# define GLOBAL_ERROR_HANDLING PG(error_handling)
-# define GLOBAL_EXCEPTION_CLASS PG(exception_class)
-# define HTTP_IS_CALLABLE(cb_zv, flags, cb_sp) zend_is_callable((cb_zv), (flags), (cb_sp))
-# define HTTP_STATIC_ARG_INFO static
-#endif
-
-#if (PHP_MAJOR_VERSION == 5) && (PHP_MINOR_VERSION == 0)
-# define WONKY
-#endif
-
-#ifndef pemalloc_rel
-# define pemalloc_rel(size, persistent) ((persistent)?malloc(size):emalloc_rel(size))
-#endif
-
-#ifndef ZEND_ACC_DEPRECATED
-# define ZEND_ACC_DEPRECATED 0
-#endif
-
-#if PHP_MAJOR_VERSION == 4 && PHP_MINOR_VERSION == 3 && PHP_RELEASE_VERSION < 10
-# define php_url_parse_ex(u, l) php_url_parse(u)
-#endif
-
-#ifndef TSRMLS_FETCH_FROM_CTX
-# ifdef ZTS
-# define TSRMLS_FETCH_FROM_CTX(ctx) void ***tsrm_ls = (void ***) ctx
-# else
-# define TSRMLS_FETCH_FROM_CTX(ctx)
-# endif
-#endif
-
-#ifndef TSRMLS_SET_CTX
-# ifdef ZTS
-# define TSRMLS_SET_CTX(ctx) ctx = (void ***) tsrm_ls
-# else
-# define TSRMLS_SET_CTX(ctx)
-# endif
-#endif
-
-#ifndef ZVAL_ADDREF
-# define ZVAL_ADDREF Z_ADDREF_P
-#endif
-
-#ifndef SEPARATE_ARG_IF_REF
-#define SEPARATE_ARG_IF_REF(zv) \
- if (PZVAL_IS_REF(zv)) { \
- zval *ov = zv; \
- ALLOC_INIT_ZVAL(zv); \
- Z_TYPE_P(zv) = Z_TYPE_P(ov); \
- zv->value = ov->value; \
- zval_copy_ctor(zv); \
- } else { \
- ZVAL_ADDREF(zv); \
- }
-#endif
-
-#ifndef ZVAL_ZVAL
-#define ZVAL_ZVAL(z, zv, copy, dtor) { \
- int is_ref, refcount; \
- is_ref = (z)->is_ref; \
- refcount = (z)->refcount; \
- *(z) = *(zv); \
- if (copy) { \
- zval_copy_ctor(z); \
- } \
- if (dtor) { \
- if (!copy) { \
- ZVAL_NULL(zv); \
- } \
- zval_ptr_dtor(&zv); \
- } \
- (z)->is_ref = is_ref; \
- (z)->refcount = refcount; \
- }
-#endif
-#ifndef RETVAL_ZVAL
-# define RETVAL_ZVAL(zv, copy, dtor) ZVAL_ZVAL(return_value, zv, copy, dtor)
-#endif
-#ifndef RETURN_ZVAL
-# define RETURN_ZVAL(zv, copy, dtor) { RETVAL_ZVAL(zv, copy, dtor); return; }
-#endif
-
-#ifndef ZEND_MN
-# define ZEND_MN(name) ZEND_FN(name)
-#endif
-
-#ifdef WONKY
-extern int zend_declare_property_double(zend_class_entry *ce, char *name, int name_length, double value, int access_type TSRMLS_DC);
-extern void zend_update_property_double(zend_class_entry *scope, zval *object, char *name, int name_length, double value TSRMLS_DC);
-
-extern int zend_declare_property_bool(zend_class_entry *ce, char *name, int name_length, long value, int access_type TSRMLS_DC);
-extern void zend_update_property_bool(zend_class_entry *scope, zval *object, char *name, int name_length, long value TSRMLS_DC);
-
-extern void zend_update_property_stringl(zend_class_entry *scope, zval *object, char *name, int name_length, char *value, int value_len TSRMLS_DC);
-#endif
-
-#endif
-
-/*
- * Local variables:
- * tab-width: 4
- * c-basic-offset: 4
- * End:
- * vim600: noet sw=4 ts=4 fdm=marker
- * vim<600: noet sw=4 ts=4
- */
-
|
[-]
[+]
|
Deleted |
pecl_http-1.7.5.tar.bz2/pecl_http-1.7.5/php_http.h
^
|
@@ -1,262 +0,0 @@
-/*
- +--------------------------------------------------------------------+
- | PECL :: http |
- +--------------------------------------------------------------------+
- | Redistribution and use in source and binary forms, with or without |
- | modification, are permitted provided that the conditions mentioned |
- | in the accompanying LICENSE file are met. |
- +--------------------------------------------------------------------+
- | Copyright (c) 2004-2010, Michael Wallner <mike@php.net> |
- +--------------------------------------------------------------------+
-*/
-
-/* $Id: php_http.h 329632 2013-03-03 07:14:52Z mike $ */
-
-#ifndef PHP_EXT_HTTP_H
-#define PHP_EXT_HTTP_H
-
-#define PHP_HTTP_VERSION "1.7.5"
-
-#ifdef HAVE_CONFIG_H
-# include "config.h"
-#else
-# ifndef PHP_WIN32
-# include "php_config.h"
-# endif
-#endif
-
-#include "php.h"
-#include "missing.h"
-#include "php_http_std_defs.h"
-#include "phpstr/phpstr.h"
-
-#ifdef HTTP_WANT_SAPI
-# if PHP_API_VERSION > 20041225
-# define HTTP_HAVE_SAPI_RTIME
-# endif
-# include "SAPI.h"
-#endif
-
-#ifdef HTTP_WANT_NETDB
-# ifdef PHP_WIN32
-# define HTTP_HAVE_NETDB
-# include <winsock2.h>
-# elif defined(HAVE_NETDB_H)
-# define HTTP_HAVE_NETDB
-# include <netdb.h>
-# ifdef HAVE_UNISTD_H
-# include <unistd.h>
-# endif
-# endif
-#endif
-
-#if defined(HTTP_WANT_CURL) && defined(HTTP_HAVE_CURL)
-# ifdef PHP_WIN32
-# include <winsock2.h>
-# define CURL_STATICLIB
-# endif
-# include <curl/curl.h>
-# define HTTP_CURL_VERSION(x, y, z) (LIBCURL_VERSION_NUM >= (((x)<<16) + ((y)<<8) + (z)))
-#
-# if defined(HTTP_WANT_EVENT) && defined(HTTP_HAVE_EVENT)
-# include <event.h>
-# endif
-#endif
-
-#if defined(HTTP_WANT_MAGIC) && defined(HTTP_HAVE_MAGIC)
-# if defined(PHP_WIN32) && !defined(USE_MAGIC_DLL) && !defined(USE_MAGIC_STATIC)
-# define USE_MAGIC_STATIC
-# endif
-# include <magic.h>
-#endif
-
-#if defined(HTTP_WANT_ZLIB) && defined(HTTP_HAVE_ZLIB)
-# include <zlib.h>
-#endif
-
-#include <ctype.h>
-#define HTTP_IS_CTYPE(type, c) is##type((int) (unsigned char) (c))
-#define HTTP_TO_CTYPE(type, c) to##type((int) (unsigned char) (c))
-
-extern zend_module_entry http_module_entry;
-#define phpext_http_ptr &http_module_entry
-
-extern int http_module_number;
-
-ZEND_BEGIN_MODULE_GLOBALS(http)
-
- struct _http_globals_etag {
- char *mode;
- void *ctx;
- zend_bool started;
- } etag;
-
- struct _http_globals_log {
- char *cache;
- char *redirect;
- char *not_found;
- char *allowed_methods;
- char *composite;
- } log;
-
- struct _http_globals_send {
- double throttle_delay;
- size_t buffer_size;
- char *content_type;
- char *unquoted_etag;
- time_t last_modified;
- struct _http_globals_send_deflate {
- zend_bool response;
- zend_bool start_auto;
- long start_flags;
- int encoding;
- void *stream;
- } deflate;
- struct _http_globals_send_inflate {
- zend_bool start_auto;
- long start_flags;
- void *stream;
- } inflate;
- zend_bool not_found_404;
- } send;
-
- struct _http_globals_request {
- time_t time;
- HashTable *headers;
- struct _http_globals_request_methods {
- HashTable registered;
- char *allowed;
- char *custom;
- } methods;
-#if defined(ZEND_ENGINE_2) && defined(HTTP_HAVE_CURL)
- struct _http_globals_request_datashare {
- zend_llist handles;
- zend_bool cookie;
- zend_bool dns;
- zend_bool ssl;
- zend_bool connect;
- } datashare;
-#endif
-#if defined(ZEND_ENGINE_2) && defined(HTTP_HAVE_EVENT)
- struct _http_globals_request_pool {
- struct _http_globals_request_pool_event {
- void *base;
- } event;
- } pool;
-#endif
- } request;
-
- struct _http_globals_persistent {
- struct _http_globals_persistent_handles {
- ulong limit;
- struct _http_globals_persistent_handles_ident {
- ulong h;
- char *s;
- size_t l;
- } ident;
- } handles;
- } persistent;
-
-#ifdef ZEND_ENGINE_2
- zend_bool only_exceptions;
-#endif
-
- zend_bool force_exit;
- zend_bool read_post_data;
- zval *server_var;
-
-ZEND_END_MODULE_GLOBALS(http)
-
-ZEND_EXTERN_MODULE_GLOBALS(http);
-
-#ifdef ZTS
-# include "TSRM.h"
-# define HTTP_G ((zend_http_globals *) (*((void ***) tsrm_ls))[TSRM_UNSHUFFLE_RSRC_ID(http_globals_id)])
-#else
-# define HTTP_G (&http_globals)
-#endif
-
-#if defined(HAVE_ICONV) && (HTTP_SHARED_DEPS || !defined(COMPILE_DL_ICONV))
-# define HTTP_HAVE_ICONV
-#endif
-
-#if defined(HAVE_PHP_SESSION) && (HTTP_SHARED_DEPS || !defined(COMPILE_DL_SESSION))
-# define HTTP_HAVE_SESSION
-#endif
-
-#if defined(HAVE_HASH_EXT) && (HTTP_SHARED_DEPS || !defined(COMPILE_DL_HASH)) && defined(HTTP_HAVE_PHP_HASH_H)
-# define HTTP_HAVE_HASH
-#endif
-
-#if defined(HAVE_SPL)
-# define HTTP_HAVE_SPL
-#endif
-
-PHP_FUNCTION(http_date);
-PHP_FUNCTION(http_build_url);
-PHP_FUNCTION(http_build_str);
-PHP_FUNCTION(http_negotiate_language);
-PHP_FUNCTION(http_negotiate_charset);
-PHP_FUNCTION(http_negotiate_content_type);
-PHP_FUNCTION(http_negotiate);
-PHP_FUNCTION(http_redirect);
-PHP_FUNCTION(http_throttle);
-PHP_FUNCTION(http_send_status);
-PHP_FUNCTION(http_send_last_modified);
-PHP_FUNCTION(http_send_content_type);
-PHP_FUNCTION(http_send_content_disposition);
-PHP_FUNCTION(http_match_modified);
-PHP_FUNCTION(http_match_etag);
-PHP_FUNCTION(http_cache_last_modified);
-PHP_FUNCTION(http_cache_etag);
-PHP_FUNCTION(http_send_data);
-PHP_FUNCTION(http_send_file);
-PHP_FUNCTION(http_send_stream);
-PHP_FUNCTION(http_chunked_decode);
-PHP_FUNCTION(http_parse_message);
-PHP_FUNCTION(http_parse_headers);
-PHP_FUNCTION(http_parse_cookie);
-PHP_FUNCTION(http_build_cookie);
-PHP_FUNCTION(http_parse_params);
-PHP_FUNCTION(http_get_request_headers);
-PHP_FUNCTION(http_get_request_body);
-PHP_FUNCTION(http_get_request_body_stream);
-PHP_FUNCTION(http_match_request_header);
-PHP_FUNCTION(http_persistent_handles_count);
-PHP_FUNCTION(http_persistent_handles_clean);
-PHP_FUNCTION(http_persistent_handles_ident);
-#ifdef HTTP_HAVE_CURL
-PHP_FUNCTION(http_get);
-PHP_FUNCTION(http_head);
-PHP_FUNCTION(http_post_data);
-PHP_FUNCTION(http_post_fields);
-PHP_FUNCTION(http_put_data);
-PHP_FUNCTION(http_put_file);
-PHP_FUNCTION(http_put_stream);
-PHP_FUNCTION(http_request);
-PHP_FUNCTION(http_request_body_encode);
-#endif /* HTTP_HAVE_CURL */
-PHP_FUNCTION(http_request_method_register);
-PHP_FUNCTION(http_request_method_unregister);
-PHP_FUNCTION(http_request_method_exists);
-PHP_FUNCTION(http_request_method_name);
-PHP_FUNCTION(ob_etaghandler);
-#ifdef HTTP_HAVE_ZLIB
-PHP_FUNCTION(http_deflate);
-PHP_FUNCTION(http_inflate);
-PHP_FUNCTION(ob_deflatehandler);
-PHP_FUNCTION(ob_inflatehandler);
-#endif
-PHP_FUNCTION(http_support);
-
-#endif /* PHP_HTTP_H */
-
-/*
- * Local variables:
- * tab-width: 4
- * c-basic-offset: 4
- * End:
- * vim600: noet sw=4 ts=4 fdm=marker
- * vim<600: noet sw=4 ts=4
- */
-
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/package.xml
^
|
@@ -19,10 +19,10 @@
<email>mike@php.net</email>
<active>yes</active>
</lead>
- <date>2013-03-03</date>
- <time>07:15:01</time>
+ <date>2013-06-20</date>
+ <time>13:20:44</time>
<version>
- <release>1.7.5</release>
+ <release>1.7.6</release>
<api>1.7.0</api>
</version>
<stability>
@@ -31,7 +31,7 @@
</stability>
<license>BSD, revised</license>
<notes>
-* Fixed Bug #64310 (weak etags W/"abc" are quoted as "W/"abc"")
+* Fixed bug #64380 (PHP-5.5 build fails)
</notes>
<contents>
<dir name="/">
@@ -169,9 +169,9 @@
<file md5sum="9d36ebe88c36d2cd5e350ad6b0b5c7c5" name="config.m4" role="src" />
<file md5sum="72c90327d3aaf175eabed3cf5fa0341f" name="config9.m4" role="src" />
<file md5sum="4651b8f10cac719b18f1f3d70bc509f7" name="Makefile.frag" role="src" />
- <file md5sum="5ccf12d575c0eb4ef316ed9c491a9b21" name="missing.h" role="src" />
+ <file md5sum="0164ccb2f938fb17be2180efb24ef3b1" name="missing.h" role="src" />
<file md5sum="c2a9dc699482caf44122e26f823cb906" name="missing.c" role="src" />
- <file md5sum="53acc65e5206c83f5ddab34cb145fe7f" name="php_http.h" role="src" />
+ <file md5sum="e8e3d4704e9ddc76b49477372a74cd32" name="php_http.h" role="src" />
<file md5sum="388b6779d20b33c4d5e92d858c86f880" name="php_http_std_defs.h" role="src" />
<file md5sum="fb69ee5b3e11a0395e7d3d4d46d4a39f" name="php_http_api.h" role="src" />
<file md5sum="49213f4828106819dd3ebb6ef2dcbc5a" name="php_http_cache_api.h" role="src" />
@@ -226,7 +226,7 @@
<file md5sum="bb4ff06bbe9f1e768d2df6ff7a07452e" name="http_util_object.c" role="src" />
<file md5sum="d24a1c2fbb1fdf0934108c64e140b7a3" name="http_deflatestream_object.c" role="src" />
<file md5sum="ba69915fe1caac66fd972d130244a1e5" name="http_inflatestream_object.c" role="src" />
- <file md5sum="c22e5c6d6ee842c5dcc80a57b710d8be" name="http_message_object.c" role="src" />
+ <file md5sum="8c3d7607d497a49522910b635952bf14" name="http_message_object.c" role="src" />
<file md5sum="87e090bc5e87041df1b2024672dbbba9" name="http_querystring_object.c" role="src" />
<file md5sum="72489a8218e966121e7256dbf0196f64" name="http_request_object.c" role="src" />
<file md5sum="1a3a70a0301ae7e88f577719f791cf5c" name="http_requestdatashare_object.c" role="src" />
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/CREDITS
^
|
(renamed from pecl_http-1.7.5/CREDITS)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/CREDITS
^
|
(renamed from pecl_http-1.7.5/CREDITS)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/KnownIssues.txt
^
|
(renamed from pecl_http-1.7.5/KnownIssues.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/KnownIssues.txt
^
|
(renamed from pecl_http-1.7.5/KnownIssues.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/LICENSE
^
|
(renamed from pecl_http-1.7.5/LICENSE)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/LICENSE
^
|
(renamed from pecl_http-1.7.5/LICENSE)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/Makefile.frag
^
|
(renamed from pecl_http-1.7.5/Makefile.frag)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/Makefile.frag
^
|
(renamed from pecl_http-1.7.5/Makefile.frag)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/ThanksTo.txt
^
|
(renamed from pecl_http-1.7.5/ThanksTo.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/ThanksTo.txt
^
|
(renamed from pecl_http-1.7.5/ThanksTo.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/config.m4
^
|
(renamed from pecl_http-1.7.5/config.m4)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/config.m4
^
|
(renamed from pecl_http-1.7.5/config.m4)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/config.w32
^
|
(renamed from pecl_http-1.7.5/config.w32)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/config.w32
^
|
(renamed from pecl_http-1.7.5/config.w32)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/config9.m4
^
|
(renamed from pecl_http-1.7.5/config9.m4)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/config9.m4
^
|
(renamed from pecl_http-1.7.5/config9.m4)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/docs/examples/tutorial.txt
^
|
(renamed from pecl_http-1.7.5/docs/examples/tutorial.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/docs/examples/tutorial.txt
^
|
(renamed from pecl_http-1.7.5/docs/examples/tutorial.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/docs/http.ini
^
|
(renamed from pecl_http-1.7.5/docs/http.ini)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/docs/http.ini
^
|
(renamed from pecl_http-1.7.5/docs/http.ini)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http.c
^
|
(renamed from pecl_http-1.7.5/http.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http.c
^
|
(renamed from pecl_http-1.7.5/http.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http.dsp
^
|
(renamed from pecl_http-1.7.5/http.dsp)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http.dsp
^
|
(renamed from pecl_http-1.7.5/http.dsp)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_api.c
^
|
(renamed from pecl_http-1.7.5/http_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_api.c
^
|
(renamed from pecl_http-1.7.5/http_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_cache_api.c
^
|
(renamed from pecl_http-1.7.5/http_cache_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_cache_api.c
^
|
(renamed from pecl_http-1.7.5/http_cache_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_cookie_api.c
^
|
(renamed from pecl_http-1.7.5/http_cookie_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_cookie_api.c
^
|
(renamed from pecl_http-1.7.5/http_cookie_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_date_api.c
^
|
(renamed from pecl_http-1.7.5/http_date_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_date_api.c
^
|
(renamed from pecl_http-1.7.5/http_date_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_deflatestream_object.c
^
|
(renamed from pecl_http-1.7.5/http_deflatestream_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_deflatestream_object.c
^
|
(renamed from pecl_http-1.7.5/http_deflatestream_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_encoding_api.c
^
|
(renamed from pecl_http-1.7.5/http_encoding_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_encoding_api.c
^
|
(renamed from pecl_http-1.7.5/http_encoding_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_exception_object.c
^
|
(renamed from pecl_http-1.7.5/http_exception_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_exception_object.c
^
|
(renamed from pecl_http-1.7.5/http_exception_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_filter_api.c
^
|
(renamed from pecl_http-1.7.5/http_filter_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_filter_api.c
^
|
(renamed from pecl_http-1.7.5/http_filter_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_functions.c
^
|
(renamed from pecl_http-1.7.5/http_functions.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_functions.c
^
|
(renamed from pecl_http-1.7.5/http_functions.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_inflatestream_object.c
^
|
(renamed from pecl_http-1.7.5/http_inflatestream_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_inflatestream_object.c
^
|
(renamed from pecl_http-1.7.5/http_inflatestream_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_info_api.c
^
|
(renamed from pecl_http-1.7.5/http_info_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_info_api.c
^
|
(renamed from pecl_http-1.7.5/http_info_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_message_api.c
^
|
(renamed from pecl_http-1.7.5/http_message_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_message_api.c
^
|
(renamed from pecl_http-1.7.5/http_message_api.c)
|
[-]
[+]
|
Added |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_message_object.c
^
|
@@ -0,0 +1,1555 @@
+/*
+ +--------------------------------------------------------------------+
+ | PECL :: http |
+ +--------------------------------------------------------------------+
+ | Redistribution and use in source and binary forms, with or without |
+ | modification, are permitted provided that the conditions mentioned |
+ | in the accompanying LICENSE file are met. |
+ +--------------------------------------------------------------------+
+ | Copyright (c) 2004-2010, Michael Wallner <mike@php.net> |
+ +--------------------------------------------------------------------+
+*/
+
+/* $Id: http_message_object.c 329705 2013-03-08 12:59:52Z mike $ */
+
+#define HTTP_WANT_SAPI
+#define HTTP_WANT_CURL
+#define HTTP_WANT_MAGIC
+#include "php_http.h"
+
+#ifdef ZEND_ENGINE_2
+
+#include "zend_interfaces.h"
+#include "ext/standard/url.h"
+#include "php_variables.h"
+
+#include "php_http_api.h"
+#include "php_http_send_api.h"
+#include "php_http_url_api.h"
+#include "php_http_message_api.h"
+#include "php_http_message_object.h"
+#include "php_http_exception_object.h"
+#include "php_http_response_object.h"
+#include "php_http_request_method_api.h"
+#include "php_http_request_api.h"
+#include "php_http_request_object.h"
+#include "php_http_headers_api.h"
+
+#if defined(HTTP_HAVE_SPL) && !defined(WONKY)
+/* SPL doesn't install its headers */
+extern PHPAPI zend_class_entry *spl_ce_Countable;
+#endif
+
+#define HTTP_BEGIN_ARGS(method, req_args) HTTP_BEGIN_ARGS_EX(HttpMessage, method, 0, req_args)
+#define HTTP_EMPTY_ARGS(method) HTTP_EMPTY_ARGS_EX(HttpMessage, method, 0)
+#define HTTP_MESSAGE_ME(method, visibility) PHP_ME(HttpMessage, method, HTTP_ARGS(HttpMessage, method), visibility)
+
+HTTP_BEGIN_ARGS(__construct, 0)
+ HTTP_ARG_VAL(message, 0)
+HTTP_END_ARGS;
+
+HTTP_BEGIN_ARGS(factory, 0)
+ HTTP_ARG_VAL(message, 0)
+ HTTP_ARG_VAL(class_name, 0)
+HTTP_END_ARGS;
+
+HTTP_BEGIN_ARGS(fromEnv, 1)
+ HTTP_ARG_VAL(type, 0)
+ HTTP_ARG_VAL(class_name, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getBody);
+HTTP_BEGIN_ARGS(setBody, 1)
+ HTTP_ARG_VAL(body, 0)
+HTTP_END_ARGS;
+
+HTTP_BEGIN_ARGS(getHeader, 1)
+ HTTP_ARG_VAL(header, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getHeaders);
+HTTP_BEGIN_ARGS(setHeaders, 1)
+ HTTP_ARG_VAL(headers, 0)
+HTTP_END_ARGS;
+
+HTTP_BEGIN_ARGS(addHeaders, 1)
+ HTTP_ARG_VAL(headers, 0)
+ HTTP_ARG_VAL(append, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getType);
+HTTP_BEGIN_ARGS(setType, 1)
+ HTTP_ARG_VAL(type, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getInfo);
+HTTP_BEGIN_ARGS(setInfo, 1)
+ HTTP_ARG_VAL(http_info, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getResponseCode);
+HTTP_BEGIN_ARGS(setResponseCode, 1)
+ HTTP_ARG_VAL(response_code, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getResponseStatus);
+HTTP_BEGIN_ARGS(setResponseStatus, 1)
+ HTTP_ARG_VAL(response_status, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getRequestMethod);
+HTTP_BEGIN_ARGS(setRequestMethod, 1)
+ HTTP_ARG_VAL(request_method, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getRequestUrl);
+HTTP_BEGIN_ARGS(setRequestUrl, 1)
+ HTTP_ARG_VAL(url, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getHttpVersion);
+HTTP_BEGIN_ARGS(setHttpVersion, 1)
+ HTTP_ARG_VAL(http_version, 0)
+HTTP_END_ARGS;
+
+HTTP_BEGIN_ARGS(guessContentType, 1)
+ HTTP_ARG_VAL(magic_file, 0)
+ HTTP_ARG_VAL(magic_mode, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(getParentMessage);
+HTTP_EMPTY_ARGS(send);
+HTTP_EMPTY_ARGS(__toString);
+HTTP_BEGIN_ARGS(toString, 0)
+ HTTP_ARG_VAL(include_parent, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(toMessageTypeObject);
+
+HTTP_EMPTY_ARGS(count);
+
+HTTP_EMPTY_ARGS(serialize);
+HTTP_BEGIN_ARGS(unserialize, 1)
+ HTTP_ARG_VAL(serialized, 0)
+HTTP_END_ARGS;
+
+HTTP_EMPTY_ARGS(rewind);
+HTTP_EMPTY_ARGS(valid);
+HTTP_EMPTY_ARGS(key);
+HTTP_EMPTY_ARGS(current);
+HTTP_EMPTY_ARGS(next);
+
+HTTP_EMPTY_ARGS(detach);
+HTTP_BEGIN_ARGS(prepend, 1)
+ HTTP_ARG_OBJ(HttpMessage, message, 0)
+HTTP_END_ARGS;
+HTTP_EMPTY_ARGS(reverse);
+
+#define http_message_object_read_prop _http_message_object_read_prop
+static zval *_http_message_object_read_prop(zval *object, zval *member, int type ZEND_LITERAL_KEY_DC TSRMLS_DC);
+#define http_message_object_write_prop _http_message_object_write_prop
+static void _http_message_object_write_prop(zval *object, zval *member, zval *value ZEND_LITERAL_KEY_DC TSRMLS_DC);
+#define http_message_object_get_prop_ptr _http_message_object_get_prop_ptr
+static zval **_http_message_object_get_prop_ptr(zval *object, zval *member ZEND_GET_PPTR_TYPE_DC ZEND_LITERAL_KEY_DC TSRMLS_DC);
+#define http_message_object_get_props _http_message_object_get_props
+static HashTable *_http_message_object_get_props(zval *object TSRMLS_DC);
+
+#define THIS_CE http_message_object_ce
+zend_class_entry *http_message_object_ce;
+zend_function_entry http_message_object_fe[] = {
+ HTTP_MESSAGE_ME(__construct, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR)
+ HTTP_MESSAGE_ME(getBody, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setBody, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getHeader, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getHeaders, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setHeaders, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(addHeaders, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getType, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setType, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getInfo, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setInfo, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getResponseCode, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setResponseCode, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getResponseStatus, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setResponseStatus, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getRequestMethod, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setRequestMethod, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getRequestUrl, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setRequestUrl, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getHttpVersion, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(setHttpVersion, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(guessContentType, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(getParentMessage, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(send, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(toString, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(toMessageTypeObject, ZEND_ACC_PUBLIC)
+
+ /* implements Countable */
+ HTTP_MESSAGE_ME(count, ZEND_ACC_PUBLIC)
+
+ /* implements Serializable */
+ HTTP_MESSAGE_ME(serialize, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(unserialize, ZEND_ACC_PUBLIC)
+
+ /* implements Iterator */
+ HTTP_MESSAGE_ME(rewind, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(valid, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(current, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(key, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(next, ZEND_ACC_PUBLIC)
+
+ ZEND_MALIAS(HttpMessage, __toString, toString, HTTP_ARGS(HttpMessage, __toString), ZEND_ACC_PUBLIC)
+
+ HTTP_MESSAGE_ME(factory, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
+ ZEND_MALIAS(HttpMessage, fromString, factory, HTTP_ARGS(HttpMessage, factory), ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
+ HTTP_MESSAGE_ME(fromEnv, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
+
+ HTTP_MESSAGE_ME(detach, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(prepend, ZEND_ACC_PUBLIC)
+ HTTP_MESSAGE_ME(reverse, ZEND_ACC_PUBLIC)
+
+ EMPTY_FUNCTION_ENTRY
+};
+static zend_object_handlers http_message_object_handlers;
+
+static HashTable http_message_object_prophandlers;
+
+typedef void (*http_message_object_prophandler_func)(http_message_object *o, zval *v TSRMLS_DC);
+
+typedef struct _http_message_object_prophandler {
+ http_message_object_prophandler_func read;
+ http_message_object_prophandler_func write;
+} http_message_object_prophandler;
+
+static STATUS http_message_object_add_prophandler(const char *prop_str, size_t prop_len, http_message_object_prophandler_func read, http_message_object_prophandler_func write) {
+ http_message_object_prophandler h = { read, write };
+ return zend_hash_add(&http_message_object_prophandlers, prop_str, prop_len, (void *) &h, sizeof(h), NULL);
+}
+static STATUS http_message_object_get_prophandler(const char *prop_str, size_t prop_len, http_message_object_prophandler **handler) {
+ return zend_hash_find(&http_message_object_prophandlers, prop_str, prop_len, (void *) handler);
+}
+static void http_message_object_prophandler_get_type(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ RETVAL_LONG(obj->message->type);
+}
+static void http_message_object_prophandler_set_type(http_message_object *obj, zval *value TSRMLS_DC) {
+ zval *cpy = http_zsep(IS_LONG, value);
+ http_message_set_type(obj->message, Z_LVAL_P(cpy));
+ zval_ptr_dtor(&cpy);
+}
+static void http_message_object_prophandler_get_body(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ phpstr_fix(PHPSTR(obj->message));
+ RETVAL_PHPSTR(PHPSTR(obj->message), 0, 1);
+}
+static void http_message_object_prophandler_set_body(http_message_object *obj, zval *value TSRMLS_DC) {
+ zval *cpy = http_zsep(IS_STRING, value);
+ phpstr_dtor(PHPSTR(obj->message));
+ phpstr_from_string_ex(PHPSTR(obj->message), Z_STRVAL_P(cpy), Z_STRLEN_P(cpy));
+ zval_ptr_dtor(&cpy);
+}
+static void http_message_object_prophandler_get_request_method(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(REQUEST, obj->message) && obj->message->http.info.request.method) {
+ RETVAL_STRING(obj->message->http.info.request.method, 1);
+ } else {
+ RETVAL_NULL();
+ }
+}
+static void http_message_object_prophandler_set_request_method(http_message_object *obj, zval *value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(REQUEST, obj->message)) {
+ zval *cpy = http_zsep(IS_STRING, value);
+ STR_SET(obj->message->http.info.request.method, estrndup(Z_STRVAL_P(cpy), Z_STRLEN_P(cpy)));
+ zval_ptr_dtor(&cpy);
+ }
+}
+static void http_message_object_prophandler_get_request_url(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(REQUEST, obj->message) && obj->message->http.info.request.url) {
+ RETVAL_STRING(obj->message->http.info.request.url, 1);
+ } else {
+ RETVAL_NULL();
+ }
+}
+static void http_message_object_prophandler_set_request_url(http_message_object *obj, zval *value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(REQUEST, obj->message)) {
+ zval *cpy = http_zsep(IS_STRING, value);
+ STR_SET(obj->message->http.info.request.url, estrndup(Z_STRVAL_P(cpy), Z_STRLEN_P(cpy)));
+ zval_ptr_dtor(&cpy);
+ }
+}
+static void http_message_object_prophandler_get_response_status(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(RESPONSE, obj->message) && obj->message->http.info.response.status) {
+ RETVAL_STRING(obj->message->http.info.response.status, 1);
+ } else {
+ RETVAL_NULL();
+ }
+}
+static void http_message_object_prophandler_set_response_status(http_message_object *obj, zval *value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(RESPONSE, obj->message)) {
+ zval *cpy = http_zsep(IS_STRING, value);
+ STR_SET(obj->message->http.info.response.status, estrndup(Z_STRVAL_P(cpy), Z_STRLEN_P(cpy)));
+ zval_ptr_dtor(&cpy);
+ }
+}
+static void http_message_object_prophandler_get_response_code(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(RESPONSE, obj->message)) {
+ RETVAL_LONG(obj->message->http.info.response.code);
+ } else {
+ RETVAL_NULL();
+ }
+}
+static void http_message_object_prophandler_set_response_code(http_message_object *obj, zval *value TSRMLS_DC) {
+ if (HTTP_MSG_TYPE(RESPONSE, obj->message)) {
+ zval *cpy = http_zsep(IS_LONG, value);
+ obj->message->http.info.response.code = Z_LVAL_P(cpy);
+ zval_ptr_dtor(&cpy);
+ }
+}
+static void http_message_object_prophandler_get_http_version(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ RETVAL_DOUBLE(obj->message->http.version);
+}
+static void http_message_object_prophandler_set_http_version(http_message_object *obj, zval *value TSRMLS_DC) {
+ zval *cpy = http_zsep(IS_DOUBLE, value);
+ obj->message->http.version = Z_DVAL_P(cpy);
+ zval_ptr_dtor(&cpy);
+}
+static void http_message_object_prophandler_get_headers(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ array_init(return_value);
+ zend_hash_copy(Z_ARRVAL_P(return_value), &obj->message->hdrs, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
+}
+static void http_message_object_prophandler_set_headers(http_message_object *obj, zval *value TSRMLS_DC) {
+ zval *cpy = http_zsep(IS_ARRAY, value);
+ zend_hash_clean(&obj->message->hdrs);
+ zend_hash_copy(&obj->message->hdrs, Z_ARRVAL_P(cpy), (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
+ zval_ptr_dtor(&cpy);
+}
+static void http_message_object_prophandler_get_parent_message(http_message_object *obj, zval *return_value TSRMLS_DC) {
+ if (obj->message->parent) {
+ RETVAL_OBJVAL(obj->parent, 1);
+ } else {
+ RETVAL_NULL();
+ }
+}
+static void http_message_object_prophandler_set_parent_message(http_message_object *obj, zval *value TSRMLS_DC) {
+ if (Z_TYPE_P(value) == IS_OBJECT && instanceof_function(Z_OBJCE_P(value), http_message_object_ce TSRMLS_CC)) {
+ if (obj->message->parent) {
+ zval tmp;
+ tmp.value.obj = obj->parent;
+ Z_OBJ_DELREF(tmp);
+ }
+ Z_OBJ_ADDREF_P(value);
+ obj->parent = value->value.obj;
+ }
+}
+
+PHP_MINIT_FUNCTION(http_message_object)
+{
+ HTTP_REGISTER_CLASS_EX(HttpMessage, http_message_object, NULL, 0);
+
+#ifndef WONKY
+# ifdef HTTP_HAVE_SPL
+ zend_class_implements(http_message_object_ce TSRMLS_CC, 3, spl_ce_Countable, zend_ce_serializable, zend_ce_iterator);
+# else
+ zend_class_implements(http_message_object_ce TSRMLS_CC, 2, zend_ce_serializable, zend_ce_iterator);
+# endif
+#else
+ zend_class_implements(http_message_object_ce TSRMLS_CC, 1, zend_ce_iterator);
+#endif
+
+ http_message_object_handlers.clone_obj = _http_message_object_clone_obj;
+ http_message_object_handlers.read_property = http_message_object_read_prop;
+ http_message_object_handlers.write_property = http_message_object_write_prop;
+ http_message_object_handlers.get_properties = http_message_object_get_props;
+ http_message_object_handlers.get_property_ptr_ptr = http_message_object_get_prop_ptr;
+
+ zend_hash_init(&http_message_object_prophandlers, 9, NULL, NULL, 1);
+ zend_declare_property_long(THIS_CE, ZEND_STRS("type")-1, HTTP_MSG_NONE, ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("type")-1, http_message_object_prophandler_get_type, http_message_object_prophandler_set_type);
+ zend_declare_property_string(THIS_CE, ZEND_STRS("body")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("body")-1, http_message_object_prophandler_get_body, http_message_object_prophandler_set_body);
+ zend_declare_property_string(THIS_CE, ZEND_STRS("requestMethod")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("requestMethod")-1, http_message_object_prophandler_get_request_method, http_message_object_prophandler_set_request_method);
+ zend_declare_property_string(THIS_CE, ZEND_STRS("requestUrl")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("requestUrl")-1, http_message_object_prophandler_get_request_url, http_message_object_prophandler_set_request_url);
+ zend_declare_property_string(THIS_CE, ZEND_STRS("responseStatus")-1, "", ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("responseStatus")-1, http_message_object_prophandler_get_response_status, http_message_object_prophandler_set_response_status);
+ zend_declare_property_long(THIS_CE, ZEND_STRS("responseCode")-1, 0, ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("responseCode")-1, http_message_object_prophandler_get_response_code, http_message_object_prophandler_set_response_code);
+ zend_declare_property_null(THIS_CE, ZEND_STRS("httpVersion")-1, ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("httpVersion")-1, http_message_object_prophandler_get_http_version, http_message_object_prophandler_set_http_version);
+ zend_declare_property_null(THIS_CE, ZEND_STRS("headers")-1, ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("headers")-1, http_message_object_prophandler_get_headers, http_message_object_prophandler_set_headers);
+ zend_declare_property_null(THIS_CE, ZEND_STRS("parentMessage")-1, ZEND_ACC_PROTECTED TSRMLS_CC);
+ http_message_object_add_prophandler(ZEND_STRS("parentMessage")-1, http_message_object_prophandler_get_parent_message, http_message_object_prophandler_set_parent_message);
+
+#ifndef WONKY
+ zend_declare_class_constant_long(THIS_CE, ZEND_STRS("TYPE_NONE")-1, HTTP_MSG_NONE TSRMLS_CC);
+ zend_declare_class_constant_long(THIS_CE, ZEND_STRS("TYPE_REQUEST")-1, HTTP_MSG_REQUEST TSRMLS_CC);
+ zend_declare_class_constant_long(THIS_CE, ZEND_STRS("TYPE_RESPONSE")-1, HTTP_MSG_RESPONSE TSRMLS_CC);
+#endif
+
+ HTTP_LONG_CONSTANT("HTTP_MSG_NONE", HTTP_MSG_NONE);
+ HTTP_LONG_CONSTANT("HTTP_MSG_REQUEST", HTTP_MSG_REQUEST);
+ HTTP_LONG_CONSTANT("HTTP_MSG_RESPONSE", HTTP_MSG_RESPONSE);
+
+ return SUCCESS;
+}
+
+PHP_MSHUTDOWN_FUNCTION(http_message_object)
+{
+ zend_hash_destroy(&http_message_object_prophandlers);
+
+ return SUCCESS;
+}
+
+void _http_message_object_reverse(zval *this_ptr, zval *return_value TSRMLS_DC)
+{
+ int i;
+ getObject(http_message_object, obj);
+
+ /* count */
+ http_message_count(i, obj->message);
+
+ if (i > 1) {
+ zval o;
+ zend_object_value *ovalues = NULL;
+ http_message_object **objects = NULL;
+ int last = i - 1;
+
+ objects = ecalloc(i, sizeof(http_message_object *));
+ ovalues = ecalloc(i, sizeof(zend_object_value));
+
+ /* we are the first message */
+ objects[0] = obj;
+ ovalues[0] = getThis()->value.obj;
+
+ /* fetch parents */
+ INIT_PZVAL(&o);
+ o.type = IS_OBJECT;
+ for (i = 1; obj->parent.handle; ++i) {
+ o.value.obj = obj->parent;
+ ovalues[i] = o.value.obj;
+ objects[i] = obj = zend_object_store_get_object(&o TSRMLS_CC);
+ }
+
+ /* reorder parents */
+ for (last = --i; i; --i) {
+ objects[i]->message->parent = objects[i-1]->message;
+ objects[i]->parent = ovalues[i-1];
+ }
+ objects[0]->message->parent = NULL;
+ objects[0]->parent.handle = 0;
+ objects[0]->parent.handlers = NULL;
+
+ /* add ref (why?) */
+ Z_OBJ_ADDREF_P(getThis());
+ RETVAL_OBJVAL(ovalues[last], 1);
+
+ efree(objects);
+ efree(ovalues);
+ } else {
+ RETURN_ZVAL(getThis(), 1, 0);
+ }
+}
+
+void _http_message_object_prepend_ex(zval *this_ptr, zval *prepend, zend_bool top TSRMLS_DC)
+{
+ zval m;
+ http_message *save_parent_msg = NULL;
+ zend_object_value save_parent_obj = {0, NULL};
+ getObject(http_message_object, obj);
+ getObjectEx(http_message_object, prepend_obj, prepend);
+
+ INIT_PZVAL(&m);
+ m.type = IS_OBJECT;
+
+ if (!top) {
+ save_parent_obj = obj->parent;
+ save_parent_msg = obj->message->parent;
+ } else {
+ /* iterate to the most parent object */
+ while (obj->parent.handle) {
+ m.value.obj = obj->parent;
+ obj = zend_object_store_get_object(&m TSRMLS_CC);
+ }
+ }
+
+ /* prepend */
+ obj->parent = prepend->value.obj;
+ obj->message->parent = prepend_obj->message;
+
+ /* add ref */
+ zend_objects_store_add_ref(prepend TSRMLS_CC);
+ while (prepend_obj->parent.handle) {
+ m.value.obj = prepend_obj->parent;
+ zend_objects_store_add_ref(&m TSRMLS_CC);
+ prepend_obj = zend_object_store_get_object(&m TSRMLS_CC);
+ }
+
+ if (!top) {
+ prepend_obj->parent = save_parent_obj;
+ prepend_obj->message->parent = save_parent_msg;
+ }
+}
+
+zend_object_value _http_message_object_new(zend_class_entry *ce TSRMLS_DC)
+{
+ return http_message_object_new_ex(ce, NULL, NULL);
+}
+
+zend_object_value _http_message_object_new_ex(zend_class_entry *ce, http_message *msg, http_message_object **ptr TSRMLS_DC)
+{
+ zend_object_value ov;
+ http_message_object *o;
+
+ o = ecalloc(1, sizeof(http_message_object));
+ o->zo.ce = ce;
+
+ if (ptr) {
+ *ptr = o;
+ }
+
+ if (msg) {
+ o->message = msg;
+ if (msg->parent) {
+ o->parent = http_message_object_new_ex(ce, msg->parent, NULL);
+ }
+ }
+
+
+#ifdef ZEND_ENGINE_2_4
+ zend_object_std_init(o, ce TSRMLS_CC);
+ object_properties_init(o, ce);
+#else
+ ALLOC_HASHTABLE(OBJ_PROP(o));
+ zend_hash_init(OBJ_PROP(o), zend_hash_num_elements(&ce->default_properties), NULL, ZVAL_PTR_DTOR, 0);
+ zend_hash_copy(OBJ_PROP(o), &ce->default_properties, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
+#endif
+
+ ov.handle = putObject(http_message_object, o);
+ ov.handlers = &http_message_object_handlers;
+
+ return ov;
+}
+
+zend_object_value _http_message_object_clone_obj(zval *this_ptr TSRMLS_DC)
+{
+ zend_object_value new_ov;
+ http_message_object *new_obj = NULL;
+ getObject(http_message_object, old_obj);
+
+ new_ov = http_message_object_new_ex(old_obj->zo.ce, http_message_dup(old_obj->message), &new_obj);
+ zend_objects_clone_members(&new_obj->zo, new_ov, &old_obj->zo, Z_OBJ_HANDLE_P(this_ptr) TSRMLS_CC);
+
+ return new_ov;
+}
+
+void _http_message_object_free(zend_object *object TSRMLS_DC)
+{
+ http_message_object *o = (http_message_object *) object;
+
+ if (o->iterator) {
+ zval_ptr_dtor(&o->iterator);
+ o->iterator = NULL;
+ }
+ if (o->message) {
+ http_message_dtor(o->message);
+ efree(o->message);
+ }
+ if (o->parent.handle) {
+ zval p;
+
+ INIT_PZVAL(&p);
+ p.type = IS_OBJECT;
+ p.value.obj = o->parent;
+ zend_objects_store_del_ref(&p TSRMLS_CC);
+ }
+ freeObject(o);
+}
+
+static zval **_http_message_object_get_prop_ptr(zval *object, zval *member ZEND_GET_PPTR_TYPE_DC ZEND_LITERAL_KEY_DC TSRMLS_DC) {
+ getObjectEx(http_message_object, obj, object);
+ http_message_object_prophandler *handler;
+
+ if (SUCCESS == http_message_object_get_prophandler(Z_STRVAL_P(member), Z_STRLEN_P(member), &handler)) {
+ zend_error(E_ERROR, "Cannot access HttpMessage properties by reference or array key/index");
+ return NULL;
+ }
+
+ return zend_get_std_object_handlers()->get_property_ptr_ptr(object, member ZEND_GET_PPTR_TYPE_CC ZEND_LITERAL_KEY_CC TSRMLS_CC);
+}
+
+static zval *_http_message_object_read_prop(zval *object, zval *member, int type ZEND_LITERAL_KEY_DC TSRMLS_DC)
+{
+ getObjectEx(http_message_object, obj, object);
+ http_message_object_prophandler *handler;
+ zval *return_value;
+
+ if (SUCCESS == http_message_object_get_prophandler(Z_STRVAL_P(member), Z_STRLEN_P(member), &handler)) {
+ if (type == BP_VAR_W) {
+ zend_error(E_ERROR, "Cannot access HttpMessage properties by reference or array key/index");
+ return NULL;
+ }
+
+ ALLOC_ZVAL(return_value);
+#ifdef Z_SET_REFCOUNT
+ Z_SET_REFCOUNT_P(return_value, 0);
+ Z_UNSET_ISREF_P(return_value);
+#else
+ return_value->refcount = 0;
+ return_value->is_ref = 0;
+#endif
+
+ handler->read(obj, return_value TSRMLS_CC);
+
+ } else {
+ return_value = zend_get_std_object_handlers()->read_property(object, member, type ZEND_LITERAL_KEY_CC TSRMLS_CC);
+ }
+
+ return return_value;
+}
+
+static void _http_message_object_write_prop(zval *object, zval *member, zval *value ZEND_LITERAL_KEY_DC TSRMLS_DC)
+{
+ getObjectEx(http_message_object, obj, object);
+ http_message_object_prophandler *handler;
+
+ if (SUCCESS == http_message_object_get_prophandler(Z_STRVAL_P(member), Z_STRLEN_P(member), &handler)) {
+ handler->write(obj, value TSRMLS_CC);
+ } else {
+ zend_get_std_object_handlers()->write_property(object, member, value ZEND_LITERAL_KEY_CC TSRMLS_CC);
+ }
+}
+
+static HashTable *_http_message_object_get_props(zval *object TSRMLS_DC)
+{
+ zval *headers;
+ getObjectEx(http_message_object, obj, object);
+ http_message *msg = obj->message;
+ zval array, *parent;
+#ifdef ZEND_ENGINE_2_4
+ HashTable *props = zend_get_std_object_handlers()->get_properties(object TSRMLS_CC);
+#else
+ HashTable *props = OBJ_PROP(obj);
+#endif
+ INIT_ZARR(array, props);
+
+#define ASSOC_PROP(array, ptype, name, val) \
+ { \
+ char *m_prop_name; \
+ int m_prop_len; \
+ zend_mangle_property_name(&m_prop_name, &m_prop_len, "*", 1, name, lenof(name), 0); \
+ add_assoc_ ##ptype## _ex(&array, m_prop_name, sizeof(name)+3, val); \
+ efree(m_prop_name); \
+ }
+#define ASSOC_STRING(array, name, val) ASSOC_STRINGL(array, name, val, strlen(val))
+#define ASSOC_STRINGL(array, name, val, len) \
+ { \
+ char *m_prop_name; \
+ int m_prop_len; \
+ zend_mangle_property_name(&m_prop_name, &m_prop_len, "*", 1, name, lenof(name), 0); \
+ add_assoc_stringl_ex(&array, m_prop_name, sizeof(name)+3, val, len, 1); \
+ efree(m_prop_name); \
+ }
+
+ ASSOC_PROP(array, long, "type", msg->type);
+ ASSOC_PROP(array, double, "httpVersion", msg->http.version);
+
+ switch (msg->type) {
+ case HTTP_MSG_REQUEST:
+ ASSOC_PROP(array, long, "responseCode", 0);
+ ASSOC_STRINGL(array, "responseStatus", "", 0);
+ ASSOC_STRING(array, "requestMethod", STR_PTR(msg->http.info.request.method));
+ ASSOC_STRING(array, "requestUrl", STR_PTR(msg->http.info.request.url));
+ break;
+
+ case HTTP_MSG_RESPONSE:
+ ASSOC_PROP(array, long, "responseCode", msg->http.info.response.code);
+ ASSOC_STRING(array, "responseStatus", STR_PTR(msg->http.info.response.status));
+ ASSOC_STRINGL(array, "requestMethod", "", 0);
+ ASSOC_STRINGL(array, "requestUrl", "", 0);
+ break;
+
+ case HTTP_MSG_NONE:
+ default:
+ ASSOC_PROP(array, long, "responseCode", 0);
+ ASSOC_STRINGL(array, "responseStatus", "", 0);
+ ASSOC_STRINGL(array, "requestMethod", "", 0);
+ ASSOC_STRINGL(array, "requestUrl", "", 0);
+ break;
+ }
+
+ MAKE_STD_ZVAL(headers);
+ array_init(headers);
+ zend_hash_copy(Z_ARRVAL_P(headers), &msg->hdrs, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
+ ASSOC_PROP(array, zval, "headers", headers);
+ ASSOC_STRINGL(array, "body", PHPSTR_VAL(msg), PHPSTR_LEN(msg));
+
+ MAKE_STD_ZVAL(parent);
+ if (msg->parent) {
+ ZVAL_OBJVAL(parent, obj->parent, 1);
+ } else {
+ ZVAL_NULL(parent);
+ }
+ ASSOC_PROP(array, zval, "parentMessage", parent);
+
+ return props;
+}
+
+/* ### USERLAND ### */
+
+/* {{{ proto void HttpMessage::__construct([string message])
+ Create a new HttpMessage object instance. */
+PHP_METHOD(HttpMessage, __construct)
+{
+ int length = 0;
+ char *message = NULL;
+
+ getObject(http_message_object, obj);
+
+ SET_EH_THROW_HTTP();
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|s", &message, &length) && message && length) {
+ http_message *msg = obj->message;
+
+ http_message_dtor(msg);
+ if ((obj->message = http_message_parse_ex(msg, message, length))) {
+ if (obj->message->parent) {
+ obj->parent = http_message_object_new_ex(Z_OBJCE_P(getThis()), obj->message->parent, NULL);
+ }
+ } else {
+ obj->message = http_message_init(msg);
+ }
+ }
+ if (!obj->message) {
+ obj->message = http_message_new();
+ }
+ SET_EH_NORMAL();
+}
+/* }}} */
+
+/* {{{ proto static HttpMessage HttpMessage::factory([string raw_message[, string class_name = "HttpMessage"]])
+ Create a new HttpMessage object instance. */
+PHP_METHOD(HttpMessage, factory)
+{
+ char *string = NULL, *cn = NULL;
+ int length = 0, cl = 0;
+ http_message *msg = NULL;
+ zend_object_value ov;
+ http_message_object *obj = NULL;
+
+ RETVAL_NULL();
+
+ SET_EH_THROW_HTTP();
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|ss", &string, &length, &cn, &cl)) {
+ if (length) {
+ msg = http_message_parse(string, length);
+ }
+ if ((msg || !length) && SUCCESS == http_object_new(&ov, cn, cl, _http_message_object_new_ex, http_message_object_ce, msg, &obj)) {
+ RETVAL_OBJVAL(ov, 0);
+ }
+ if (obj && !obj->message) {
+ obj->message = http_message_new();
+ }
+ }
+ SET_EH_NORMAL();
+}
+/* }}} */
+
+/* {{{ proto static HttpMessage HttpMessage::fromEnv(int type[, string class_name = "HttpMessage"])
+ Create a new HttpMessage object from environment representing either current request or response */
+PHP_METHOD(HttpMessage, fromEnv)
+{
+ char *cn = NULL;
+ int cl = 0;
+ long type;
+ http_message_object *obj = NULL;
+ zend_object_value ov;
+
+ RETVAL_NULL();
+ SET_EH_THROW_HTTP();
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l|s", &type, &cn, &cl)) {
+ if (SUCCESS == http_object_new(&ov, cn, cl, _http_message_object_new_ex, http_message_object_ce, http_message_init_env(NULL, type), &obj)) {
+ RETVAL_OBJVAL(ov, 0);
+ }
+ if (obj && !obj->message) {
+ obj->message = http_message_new();
+ }
+ }
+ SET_EH_NORMAL();
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::getBody()
+ Get the body of the parsed HttpMessage. */
+PHP_METHOD(HttpMessage, getBody)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+ RETURN_PHPSTR(&obj->message->body, PHPSTR_FREE_NOT, 1);
+ }
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::setBody(string body)
+ Set the body of the HttpMessage. NOTE: Don't forget to update any headers accordingly. */
+PHP_METHOD(HttpMessage, setBody)
+{
+ char *body;
+ int len;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &body, &len)) {
+ phpstr_dtor(PHPSTR(obj->message));
+ phpstr_from_string_ex(PHPSTR(obj->message), body, len);
+ }
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::getHeader(string header)
+ Get message header. */
+PHP_METHOD(HttpMessage, getHeader)
+{
+ zval *header;
+ char *orig_header, *nice_header;
+ int header_len;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &orig_header, &header_len)) {
+ RETURN_FALSE;
+ }
+
+ nice_header = pretty_key(estrndup(orig_header, header_len), header_len, 1, 1);
+ if ((header = http_message_header_ex(obj->message, nice_header, header_len + 1, 0))) {
+ RETVAL_ZVAL(header, 1, 1);
+ }
+ efree(nice_header);
+}
+/* }}} */
+
+/* {{{ proto array HttpMessage::getHeaders()
+ Get Message Headers. */
+PHP_METHOD(HttpMessage, getHeaders)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+
+ array_init(return_value);
+ array_copy(&obj->message->hdrs, Z_ARRVAL_P(return_value));
+ }
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::setHeaders(array headers)
+ Sets new headers. */
+PHP_METHOD(HttpMessage, setHeaders)
+{
+ zval *new_headers = NULL;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a/!", &new_headers)) {
+ return;
+ }
+
+ zend_hash_clean(&obj->message->hdrs);
+ if (new_headers) {
+ array_copy(Z_ARRVAL_P(new_headers), &obj->message->hdrs);
+ }
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::addHeaders(array headers[, bool append = false])
+ Add headers. If append is true, headers with the same name will be separated, else overwritten. */
+PHP_METHOD(HttpMessage, addHeaders)
+{
+ zval *new_headers;
+ zend_bool append = 0;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "a|b", &new_headers, &append)) {
+ return;
+ }
+
+ array_join(Z_ARRVAL_P(new_headers), &obj->message->hdrs, append, ARRAY_JOIN_STRONLY|ARRAY_JOIN_PRETTIFY);
+}
+/* }}} */
+
+/* {{{ proto int HttpMessage::getType()
+ Get Message Type. (HTTP_MSG_NONE|HTTP_MSG_REQUEST|HTTP_MSG_RESPONSE) */
+PHP_METHOD(HttpMessage, getType)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+ RETURN_LONG(obj->message->type);
+ }
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::setType(int type)
+ Set Message Type. (HTTP_MSG_NONE|HTTP_MSG_REQUEST|HTTP_MSG_RESPONSE) */
+PHP_METHOD(HttpMessage, setType)
+{
+ long type;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &type)) {
+ return;
+ }
+ http_message_set_type(obj->message, type);
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::getInfo(void)
+ Get the HTTP request/response line */
+PHP_METHOD(HttpMessage, getInfo)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+
+ switch (obj->message->type) {
+ case HTTP_MSG_REQUEST:
+ Z_STRLEN_P(return_value) = spprintf(&Z_STRVAL_P(return_value), 0, HTTP_INFO_REQUEST_FMT_ARGS(&obj->message->http, ""));
+ break;
+ case HTTP_MSG_RESPONSE:
+ Z_STRLEN_P(return_value) = spprintf(&Z_STRVAL_P(return_value), 0, HTTP_INFO_RESPONSE_FMT_ARGS(&obj->message->http, ""));
+ break;
+ default:
+ RETURN_NULL();
+ break;
+ }
+ Z_TYPE_P(return_value) = IS_STRING;
+ }
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::setInfo(string http_info)
+ Set type and request or response info with a standard HTTP request or response line */
+PHP_METHOD(HttpMessage, setInfo)
+{
+ char *str;
+ int len;
+ http_info inf;
+
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &str, &len) && SUCCESS == http_info_parse_ex(str, &inf, 0)) {
+ getObject(http_message_object, obj);
+
+ http_message_set_info(obj->message, &inf);
+ http_info_dtor(&inf);
+ RETURN_TRUE;
+ }
+ RETURN_FALSE;
+}
+/* }}} */
+
+/* {{{ proto int HttpMessage::getResponseCode()
+ Get the Response Code of the Message. */
+PHP_METHOD(HttpMessage, getResponseCode)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+ HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
+ RETURN_LONG(obj->message->http.info.response.code);
+ }
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::setResponseCode(int code)
+ Set the response code of an HTTP Response Message. */
+PHP_METHOD(HttpMessage, setResponseCode)
+{
+ long code;
+ getObject(http_message_object, obj);
+
+ HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &code)) {
+ RETURN_FALSE;
+ }
+ if (code < 100 || code > 599) {
+ http_error_ex(HE_WARNING, HTTP_E_INVALID_PARAM, "Invalid response code (100-599): %ld", code);
+ RETURN_FALSE;
+ }
+
+ obj->message->http.info.response.code = code;
+ RETURN_TRUE;
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::getResponseStatus()
+ Get the Response Status of the message (i.e. the string following the response code). */
+PHP_METHOD(HttpMessage, getResponseStatus)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+ HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
+ if (obj->message->http.info.response.status) {
+ RETURN_STRING(obj->message->http.info.response.status, 1);
+ } else {
+ RETURN_EMPTY_STRING();
+ }
+ }
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::setResponseStatus(string status)
+ Set the Response Status of the HTTP message (i.e. the string following the response code). */
+PHP_METHOD(HttpMessage, setResponseStatus)
+{
+ char *status;
+ int status_len;
+ getObject(http_message_object, obj);
+
+ HTTP_CHECK_MESSAGE_TYPE_RESPONSE(obj->message, RETURN_FALSE);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &status, &status_len)) {
+ RETURN_FALSE;
+ }
+ STR_SET(obj->message->http.info.response.status, estrndup(status, status_len));
+ RETURN_TRUE;
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::getRequestMethod()
+ Get the Request Method of the Message. */
+PHP_METHOD(HttpMessage, getRequestMethod)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+ HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
+ if (obj->message->http.info.request.method) {
+ RETURN_STRING(obj->message->http.info.request.method, 1);
+ } else {
+ RETURN_EMPTY_STRING();
+ }
+ }
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::setRequestMethod(string method)
+ Set the Request Method of the HTTP Message. */
+PHP_METHOD(HttpMessage, setRequestMethod)
+{
+ char *method;
+ int method_len;
+ getObject(http_message_object, obj);
+
+ HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &method, &method_len)) {
+ RETURN_FALSE;
+ }
+ if (method_len < 1) {
+ http_error(HE_WARNING, HTTP_E_INVALID_PARAM, "Cannot set HttpMessage::requestMethod to an empty string");
+ RETURN_FALSE;
+ }
+ if (!http_request_method_exists(1, 0, method)) {
+ http_error_ex(HE_WARNING, HTTP_E_REQUEST_METHOD, "Unknown request method: %s", method);
+ RETURN_FALSE;
+ }
+
+ STR_SET(obj->message->http.info.request.method, estrndup(method, method_len));
+ RETURN_TRUE;
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::getRequestUrl()
+ Get the Request URL of the Message. */
+PHP_METHOD(HttpMessage, getRequestUrl)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+ HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
+ if (obj->message->http.info.request.url) {
+ RETURN_STRING(obj->message->http.info.request.url, 1);
+ } else {
+ RETURN_EMPTY_STRING();
+ }
+ }
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::setRequestUrl(string url)
+ Set the Request URL of the HTTP Message. */
+PHP_METHOD(HttpMessage, setRequestUrl)
+{
+ char *URI;
+ int URIlen;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &URI, &URIlen)) {
+ RETURN_FALSE;
+ }
+ HTTP_CHECK_MESSAGE_TYPE_REQUEST(obj->message, RETURN_FALSE);
+ if (URIlen < 1) {
+ http_error(HE_WARNING, HTTP_E_INVALID_PARAM, "Cannot set HttpMessage::requestUrl to an empty string");
+ RETURN_FALSE;
+ }
+
+ STR_SET(obj->message->http.info.request.url, estrndup(URI, URIlen));
+ RETURN_TRUE;
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::getHttpVersion()
+ Get the HTTP Protocol Version of the Message. */
+PHP_METHOD(HttpMessage, getHttpVersion)
+{
+ NO_ARGS;
+
+ if (return_value_used) {
+ char *version;
+ getObject(http_message_object, obj);
+
+ spprintf(&version, 0, "%1.1F", obj->message->http.version);
+ RETURN_STRING(version, 0);
+ }
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::setHttpVersion(string version)
+ Set the HTTP Protocol version of the Message. */
+PHP_METHOD(HttpMessage, setHttpVersion)
+{
+ zval *zv;
+ char *version;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z/", &zv)) {
+ return;
+ }
+
+ convert_to_double(zv);
+ spprintf(&version, 0, "%1.1F", Z_DVAL_P(zv));
+ if (strcmp(version, "1.0") && strcmp(version, "1.1")) {
+ efree(version);
+ http_error_ex(HE_WARNING, HTTP_E_INVALID_PARAM, "Invalid HTTP protocol version (1.0 or 1.1): %g", Z_DVAL_P(zv));
+ RETURN_FALSE;
+ }
+ efree(version);
+ obj->message->http.version = Z_DVAL_P(zv);
+ RETURN_TRUE;
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::guessContentType(string magic_file[, int magic_mode = MAGIC_MIME])
+ Attempts to guess the content type of supplied payload through libmagic. */
+PHP_METHOD(HttpMessage, guessContentType)
+{
+#ifdef HTTP_HAVE_MAGIC
+ char *magic_file, *ct = NULL;
+ int magic_file_len;
+ long magic_mode = MAGIC_MIME;
+
+ RETVAL_FALSE;
+ SET_EH_THROW_HTTP();
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s|l", &magic_file, &magic_file_len, &magic_mode)) {
+ getObject(http_message_object, obj);
+ if ((ct = http_guess_content_type(magic_file, magic_mode, PHPSTR_VAL(&obj->message->body), PHPSTR_LEN(&obj->message->body), SEND_DATA))) {
+ RETVAL_STRING(ct, 0);
+ }
+ }
+ SET_EH_NORMAL();
+#else
+ http_error(HE_THROW, HTTP_E_RUNTIME, "Cannot guess Content-Type; libmagic not available");
+ RETURN_FALSE;
+#endif
+}
+/* }}} */
+
+/* {{{ proto HttpMessage HttpMessage::getParentMessage()
+ Get parent Message. */
+PHP_METHOD(HttpMessage, getParentMessage)
+{
+ SET_EH_THROW_HTTP();
+ NO_ARGS {
+ getObject(http_message_object, obj);
+
+ if (obj->message->parent) {
+ RETVAL_OBJVAL(obj->parent, 1);
+ } else {
+ http_error(HE_WARNING, HTTP_E_RUNTIME, "HttpMessage does not have a parent message");
+ }
+ }
+ SET_EH_NORMAL();
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::send()
+ Send the Message according to its type as Response or Request. */
+PHP_METHOD(HttpMessage, send)
+{
+ getObject(http_message_object, obj);
+
+ NO_ARGS;
+
+ RETURN_SUCCESS(http_message_send(obj->message));
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::toString([bool include_parent = false])
+ Get the string representation of the Message. */
+PHP_METHOD(HttpMessage, toString)
+{
+ if (return_value_used) {
+ char *string;
+ size_t length;
+ zend_bool include_parent = 0;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS != zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|b", &include_parent)) {
+ RETURN_FALSE;
+ }
+
+ if (include_parent) {
+ http_message_serialize(obj->message, &string, &length);
+ } else {
+ http_message_tostring(obj->message, &string, &length);
+ }
+ RETURN_STRINGL(string, length, 0);
+ }
+}
+/* }}} */
+
+/* {{{ proto HttpRequest|HttpResponse HttpMessage::toMessageTypeObject(void)
+ Creates an object regarding to the type of the message. Returns either an HttpRequest or HttpResponse object on success, or NULL on failure. */
+PHP_METHOD(HttpMessage, toMessageTypeObject)
+{
+ SET_EH_THROW_HTTP();
+
+ NO_ARGS;
+
+ if (return_value_used) {
+ getObject(http_message_object, obj);
+
+ switch (obj->message->type) {
+ case HTTP_MSG_REQUEST:
+ {
+#ifdef HTTP_HAVE_CURL
+ int method;
+ char *url;
+ zval post, body, *array, *headers, *host = http_message_header(obj->message, "Host");
+ php_url hurl, *purl = php_url_parse(STR_PTR(obj->message->http.info.request.url));
+
+ MAKE_STD_ZVAL(array);
+ array_init(array);
+
+ memset(&hurl, 0, sizeof(php_url));
+ if (host) {
+ hurl.host = Z_STRVAL_P(host);
+ zval_ptr_dtor(&host);
+ }
+ http_build_url(HTTP_URL_REPLACE, purl, &hurl, NULL, &url, NULL);
+ php_url_free(purl);
+ add_assoc_string(array, "url", url, 0);
+
+ if ( obj->message->http.info.request.method &&
+ ((method = http_request_method_exists(1, 0, obj->message->http.info.request.method)) ||
+ (method = http_request_method_register(obj->message->http.info.request.method, strlen(obj->message->http.info.request.method))))) {
+ add_assoc_long(array, "method", method);
+ }
+
+ if (10 == (int) (obj->message->http.version * 10)) {
+ add_assoc_long(array, "protocol", CURL_HTTP_VERSION_1_0);
+ }
+
+ MAKE_STD_ZVAL(headers);
+ array_init(headers);
+ array_copy(&obj->message->hdrs, Z_ARRVAL_P(headers));
+ add_assoc_zval(array, "headers", headers);
+
+ object_init_ex(return_value, http_request_object_ce);
+ zend_call_method_with_1_params(&return_value, http_request_object_ce, NULL, "setoptions", NULL, array);
+ zval_ptr_dtor(&array);
+
+ if (PHPSTR_VAL(obj->message) && PHPSTR_LEN(obj->message)) {
+ phpstr_fix(PHPSTR(obj->message));
+ INIT_PZVAL(&body);
+ ZVAL_STRINGL(&body, PHPSTR_VAL(obj->message), PHPSTR_LEN(obj->message), 0);
+ if (method != HTTP_POST) {
+ zend_call_method_with_1_params(&return_value, http_request_object_ce, NULL, "setbody", NULL, &body);
+ } else {
+ INIT_PZVAL(&post);
+ array_init(&post);
+
+ zval_copy_ctor(&body);
+ sapi_module.treat_data(PARSE_STRING, Z_STRVAL(body), &post TSRMLS_CC);
+ zend_call_method_with_1_params(&return_value, http_request_object_ce, NULL, "setpostfields", NULL, &post);
+ zval_dtor(&post);
+ }
+ }
+#else
+ http_error(HE_WARNING, HTTP_E_RUNTIME, "Cannot transform HttpMessage to HttpRequest (missing curl support)");
+#endif
+ break;
+ }
+
+ case HTTP_MSG_RESPONSE:
+ {
+#ifndef WONKY
+ HashPosition pos1, pos2;
+ HashKey key = initHashKey(0);
+ zval **header, **h, *body;
+
+ if (obj->message->http.info.response.code) {
+ http_send_status(obj->message->http.info.response.code);
+ }
+
+ object_init_ex(return_value, http_response_object_ce);
+
+ FOREACH_HASH_KEYVAL(pos1, &obj->message->hdrs, key, header) {
+ if (key.type == HASH_KEY_IS_STRING) {
+ zval *zkey;
+
+ MAKE_STD_ZVAL(zkey);
+ ZVAL_STRINGL(zkey, key.str, key.len - 1, 1);
+
+ switch (Z_TYPE_PP(header)) {
+ case IS_ARRAY:
+ case IS_OBJECT:
+ FOREACH_HASH_VAL(pos2, HASH_OF(*header), h) {
+ ZVAL_ADDREF(*h);
+ zend_call_method_with_2_params(&return_value, http_response_object_ce, NULL, "setheader", NULL, zkey, *h);
+ zval_ptr_dtor(h);
+ }
+ break;
+
+ default:
+ ZVAL_ADDREF(*header);
+ zend_call_method_with_2_params(&return_value, http_response_object_ce, NULL, "setheader", NULL, zkey, *header);
+ zval_ptr_dtor(header);
+ break;
+ }
+ zval_ptr_dtor(&zkey);
+ }
+ }
+
+ MAKE_STD_ZVAL(body);
+ ZVAL_STRINGL(body, PHPSTR_VAL(obj->message), PHPSTR_LEN(obj->message), 1);
+ zend_call_method_with_1_params(&return_value, http_response_object_ce, NULL, "setdata", NULL, body);
+ zval_ptr_dtor(&body);
+#else
+ http_error(HE_WARNING, HTTP_E_RUNTIME, "Cannot transform HttpMessage to HttpResponse (need PHP 5.1+)");
+#endif
+ break;
+ }
+
+ default:
+ http_error(HE_WARNING, HTTP_E_MESSAGE_TYPE, "HttpMessage is neither of type HttpMessage::TYPE_REQUEST nor HttpMessage::TYPE_RESPONSE");
+ break;
+ }
+ }
+ SET_EH_NORMAL();
+}
+/* }}} */
+
+/* {{{ proto int HttpMessage::count()
+ Implements Countable::count(). Returns the number of parent messages + 1. */
+PHP_METHOD(HttpMessage, count)
+{
+ NO_ARGS {
+ long i;
+ getObject(http_message_object, obj);
+
+ http_message_count(i, obj->message);
+ RETURN_LONG(i);
+ }
+}
+/* }}} */
+
+/* {{{ proto string HttpMessage::serialize()
+ Implements Serializable::serialize(). Returns the serialized representation of the HttpMessage. */
+PHP_METHOD(HttpMessage, serialize)
+{
+ NO_ARGS {
+ char *string;
+ size_t length;
+ getObject(http_message_object, obj);
+
+ http_message_serialize(obj->message, &string, &length);
+ RETURN_STRINGL(string, length, 0);
+ }
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::unserialize(string serialized)
+ Implements Serializable::unserialize(). Re-constructs the HttpMessage based upon the serialized string. */
+PHP_METHOD(HttpMessage, unserialize)
+{
+ int length;
+ char *serialized;
+ getObject(http_message_object, obj);
+
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &serialized, &length)) {
+ http_message *msg;
+
+ http_message_dtor(obj->message);
+ if ((msg = http_message_parse_ex(obj->message, serialized, (size_t) length))) {
+ obj->message = msg;
+ } else {
+ http_message_init(obj->message);
+ http_error(HE_ERROR, HTTP_E_RUNTIME, "Could not unserialize HttpMessage");
+ }
+ }
+}
+/* }}} */
+
+/* {{{ proto HttpMessage HttpMessage::detach(void)
+ Returns a clone of an HttpMessage object detached from any parent messages. */
+PHP_METHOD(HttpMessage, detach)
+{
+ http_info info;
+ http_message *msg;
+ getObject(http_message_object, obj);
+
+ NO_ARGS;
+
+ info.type = obj->message->type;
+ memcpy(&HTTP_INFO(&info), &HTTP_INFO(obj->message), sizeof(struct http_info));
+
+ msg = http_message_new();
+ http_message_set_info(msg, &info);
+
+ zend_hash_copy(&msg->hdrs, &obj->message->hdrs, (copy_ctor_func_t) zval_add_ref, NULL, sizeof(zval *));
+ phpstr_append(&msg->body, PHPSTR_VAL(obj->message), PHPSTR_LEN(obj->message));
+
+ RETVAL_OBJVAL(http_message_object_new_ex(Z_OBJCE_P(getThis()), msg, NULL), 0);
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::prepend(HttpMessage message[, bool top = true])
+ Prepends message(s) to the HTTP message. Throws HttpInvalidParamException if the message is located within the same message chain. */
+PHP_METHOD(HttpMessage, prepend)
+{
+ zval *prepend;
+ zend_bool top = 1;
+
+ if (SUCCESS == zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "O|b", &prepend, http_message_object_ce, &top)) {
+ http_message *msg[2];
+ getObject(http_message_object, obj);
+ getObjectEx(http_message_object, prepend_obj, prepend);
+
+ /* safety check */
+ for (msg[0] = obj->message; msg[0]; msg[0] = msg[0]->parent) {
+ for (msg[1] = prepend_obj->message; msg[1]; msg[1] = msg[1]->parent) {
+ if (msg[0] == msg[1]) {
+ http_error(HE_THROW, HTTP_E_INVALID_PARAM, "Cannot prepend a message located within the same message chain");
+ return;
+ }
+ }
+ }
+
+ http_message_object_prepend_ex(getThis(), prepend, top);
+ }
+}
+/* }}} */
+
+/* {{{ proto HttpMessage HttpMessage::reverse()
+ Reorders the message chain in reverse order. Returns the most parent HttpMessage object. */
+PHP_METHOD(HttpMessage, reverse)
+{
+ NO_ARGS {
+ http_message_object_reverse(getThis(), return_value);
+ }
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::rewind(void)
+ Implements Iterator::rewind(). */
+PHP_METHOD(HttpMessage, rewind)
+{
+ NO_ARGS {
+ getObject(http_message_object, obj);
+
+ if (obj->iterator) {
+ zval_ptr_dtor(&obj->iterator);
+ }
+ ZVAL_ADDREF(getThis());
+ obj->iterator = getThis();
+ }
+}
+/* }}} */
+
+/* {{{ proto bool HttpMessage::valid(void)
+ Implements Iterator::valid(). */
+PHP_METHOD(HttpMessage, valid)
+{
+ NO_ARGS {
+ getObject(http_message_object, obj);
+
+ RETURN_BOOL(obj->iterator != NULL);
+ }
+}
+/* }}} */
+
+/* {{{ proto void HttpMessage::next(void)
+ Implements Iterator::next(). */
+PHP_METHOD(HttpMessage, next)
+{
+ NO_ARGS {
+ getObject(http_message_object, obj);
+ if (obj->iterator) {
+ getObjectEx(http_message_object, itr, obj->iterator);
+
+ if (itr && itr->parent.handle) {
+ zval *old = obj->iterator;
+ MAKE_STD_ZVAL(obj->iterator);
+ ZVAL_OBJVAL(obj->iterator, itr->parent, 1);
+ zval_ptr_dtor(&old);
+ } else {
+ zval_ptr_dtor(&obj->iterator);
+ obj->iterator = NULL;
+ }
+ }
+ }
+}
+/* }}} */
+
+/* {{{ proto int HttpMessage::key(void)
+ Implements Iterator::key(). */
+PHP_METHOD(HttpMessage, key)
+{
+ NO_ARGS {
+ getObject(http_message_object, obj);
+
+ RETURN_LONG(obj->iterator ? obj->iterator->value.obj.handle:0);
+ }
+}
+/* }}} */
+
+/* {{{ proto HttpMessage HttpMessage::current(void)
+ Implements Iterator::current(). */
+PHP_METHOD(HttpMessage, current)
+{
+ NO_ARGS {
+ getObject(http_message_object, obj);
+
+ if (obj->iterator) {
+ RETURN_ZVAL(obj->iterator, 1, 0);
+ }
+ }
+}
+/* }}} */
+
+#endif /* ZEND_ENGINE_2 */
+
+/*
+ * Local variables:
+ * tab-width: 4
+ * c-basic-offset: 4
+ * End:
+ * vim600: noet sw=4 ts=4 fdm=marker
+ * vim<600: noet sw=4 ts=4
+ */
+
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_persistent_handle_api.c
^
|
(renamed from pecl_http-1.7.5/http_persistent_handle_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_persistent_handle_api.c
^
|
(renamed from pecl_http-1.7.5/http_persistent_handle_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_querystring_api.c
^
|
(renamed from pecl_http-1.7.5/http_querystring_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_querystring_api.c
^
|
(renamed from pecl_http-1.7.5/http_querystring_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_querystring_object.c
^
|
(renamed from pecl_http-1.7.5/http_querystring_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_querystring_object.c
^
|
(renamed from pecl_http-1.7.5/http_querystring_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_body_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_body_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_body_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_body_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_datashare_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_datashare_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_datashare_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_datashare_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_info.c
^
|
(renamed from pecl_http-1.7.5/http_request_info.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_info.c
^
|
(renamed from pecl_http-1.7.5/http_request_info.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_method_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_method_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_method_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_method_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_object.c
^
|
(renamed from pecl_http-1.7.5/http_request_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_object.c
^
|
(renamed from pecl_http-1.7.5/http_request_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_pool_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_pool_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_request_pool_api.c
^
|
(renamed from pecl_http-1.7.5/http_request_pool_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_requestdatashare_object.c
^
|
(renamed from pecl_http-1.7.5/http_requestdatashare_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_requestdatashare_object.c
^
|
(renamed from pecl_http-1.7.5/http_requestdatashare_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_requestpool_object.c
^
|
(renamed from pecl_http-1.7.5/http_requestpool_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_requestpool_object.c
^
|
(renamed from pecl_http-1.7.5/http_requestpool_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_response_object.c
^
|
(renamed from pecl_http-1.7.5/http_response_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_response_object.c
^
|
(renamed from pecl_http-1.7.5/http_response_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_send_api.c
^
|
(renamed from pecl_http-1.7.5/http_send_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_send_api.c
^
|
(renamed from pecl_http-1.7.5/http_send_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_url_api.c
^
|
(renamed from pecl_http-1.7.5/http_url_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_url_api.c
^
|
(renamed from pecl_http-1.7.5/http_url_api.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_util_object.c
^
|
(renamed from pecl_http-1.7.5/http_util_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/http_util_object.c
^
|
(renamed from pecl_http-1.7.5/http_util_object.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/BigGet.php
^
|
(renamed from pecl_http-1.7.5/lib/BigGet.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/BigGet.php
^
|
(renamed from pecl_http-1.7.5/lib/BigGet.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/FeedAggregator.php
^
|
(renamed from pecl_http-1.7.5/lib/FeedAggregator.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/FeedAggregator.php
^
|
(renamed from pecl_http-1.7.5/lib/FeedAggregator.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/PgLobStream.php
^
|
(renamed from pecl_http-1.7.5/lib/PgLobStream.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/PgLobStream.php
^
|
(renamed from pecl_http-1.7.5/lib/PgLobStream.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/XmlRpcClient.php
^
|
(renamed from pecl_http-1.7.5/lib/XmlRpcClient.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/XmlRpcClient.php
^
|
(renamed from pecl_http-1.7.5/lib/XmlRpcClient.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/XmlRpcServer.php
^
|
(renamed from pecl_http-1.7.5/lib/XmlRpcServer.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/lib/XmlRpcServer.php
^
|
(renamed from pecl_http-1.7.5/lib/XmlRpcServer.php)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/missing.c
^
|
(renamed from pecl_http-1.7.5/missing.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/missing.c
^
|
(renamed from pecl_http-1.7.5/missing.c)
|
[-]
[+]
|
Added |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/missing.h
^
|
@@ -0,0 +1,192 @@
+/*
+ +--------------------------------------------------------------------+
+ | PECL :: http |
+ +--------------------------------------------------------------------+
+ | Redistribution and use in source and binary forms, with or without |
+ | modification, are permitted provided that the conditions mentioned |
+ | in the accompanying LICENSE file are met. |
+ +--------------------------------------------------------------------+
+ | Copyright (c) 2004-2010, Michael Wallner <mike@php.net> |
+ +--------------------------------------------------------------------+
+*/
+
+/* $Id: missing.h 330133 2013-04-22 17:58:30Z remi $ */
+
+#ifndef PHP_HTTP_MISSING
+#define PHP_HTTP_MISSING
+
+#include "php_version.h"
+
+#if ZEND_MODULE_API_NO >= 20100409
+#define ZEND_ENGINE_2_4
+#endif
+
+#if defined(PHP_VERSION_ID) && (PHP_VERSION_ID >= 50500)
+# define ZEND_GET_PPTR_TYPE_DC , int type
+# define ZEND_GET_PPTR_TYPE_CC , type
+#else
+# define ZEND_GET_PPTR_TYPE_DC
+# define ZEND_GET_PPTR_TYPE_CC
+#endif
+
+#if defined(PHP_VERSION_ID) && (PHP_VERSION_ID >= 50399)
+# define ZEND_LITERAL_KEY_DC , const zend_literal *_zend_literal_key
+# define ZEND_LITERAL_KEY_CC , _zend_literal_key
+# define ZEND_LITERAL_NIL_CC , NULL
+# define HTTP_CHECK_OPEN_BASEDIR(file, act) \
+ if ((PG(open_basedir) && *PG(open_basedir))) \
+ { \
+ const char *tmp = file; \
+ \
+ if (!strncasecmp(tmp, "file:", lenof("file:"))) { \
+ tmp += lenof("file:"); \
+ while ((tmp - (const char *)file < 7) && (*tmp == '/' || *tmp == '\\')) ++tmp; \
+ } \
+ \
+ if ( (tmp != file || !strstr(file, "://")) && \
+ (!*tmp || php_check_open_basedir(tmp TSRMLS_CC))) { \
+ act; \
+ } \
+ }
+
+#else
+# define ZEND_LITERAL_KEY_DC
+# define ZEND_LITERAL_KEY_CC
+# define ZEND_LITERAL_NIL_CC
+# define HTTP_CHECK_OPEN_BASEDIR(file, act) \
+ if ((PG(open_basedir) && *PG(open_basedir)) || PG(safe_mode)) \
+ { \
+ const char *tmp = file; \
+ \
+ if (!strncasecmp(tmp, "file:", lenof("file:"))) { \
+ tmp += lenof("file:"); \
+ while ((tmp - (const char *)file < 7) && (*tmp == '/' || *tmp == '\\')) ++tmp; \
+ } \
+ \
+ if ( (tmp != file || !strstr(file, "://")) && \
+ (!*tmp || php_check_open_basedir(tmp TSRMLS_CC) || \
+ (PG(safe_mode) && !php_checkuid(tmp, "rb+", CHECKUID_CHECK_MODE_PARAM)))) { \
+ act; \
+ } \
+ }
+
+#endif
+
+#if (PHP_MAJOR_VERSION == 5) && (PHP_MINOR_VERSION >= 3)
+# define HTTP_ZAPI_HASH_TSRMLS_CC TSRMLS_CC
+# define HTTP_ZAPI_HASH_TSRMLS_DC TSRMLS_DC
+# define HTTP_ZAPI_CONST_CAST(t) (const t)
+# define GLOBAL_ERROR_HANDLING EG(error_handling)
+# define GLOBAL_EXCEPTION_CLASS EG(exception_class)
+# define HTTP_IS_CALLABLE(cb_zv, flags, cb_sp) zend_is_callable((cb_zv), (flags), (cb_sp) TSRMLS_CC)
+# define HTTP_STATIC_ARG_INFO
+#else
+# define HTTP_ZAPI_HASH_TSRMLS_CC
+# define HTTP_ZAPI_HASH_TSRMLS_DC
+# define HTTP_ZAPI_CONST_CAST(t) (t)
+# define GLOBAL_ERROR_HANDLING PG(error_handling)
+# define GLOBAL_EXCEPTION_CLASS PG(exception_class)
+# define HTTP_IS_CALLABLE(cb_zv, flags, cb_sp) zend_is_callable((cb_zv), (flags), (cb_sp))
+# define HTTP_STATIC_ARG_INFO static
+#endif
+
+#if (PHP_MAJOR_VERSION == 5) && (PHP_MINOR_VERSION == 0)
+# define WONKY
+#endif
+
+#ifndef pemalloc_rel
+# define pemalloc_rel(size, persistent) ((persistent)?malloc(size):emalloc_rel(size))
+#endif
+
+#ifndef ZEND_ACC_DEPRECATED
+# define ZEND_ACC_DEPRECATED 0
+#endif
+
+#if PHP_MAJOR_VERSION == 4 && PHP_MINOR_VERSION == 3 && PHP_RELEASE_VERSION < 10
+# define php_url_parse_ex(u, l) php_url_parse(u)
+#endif
+
+#ifndef TSRMLS_FETCH_FROM_CTX
+# ifdef ZTS
+# define TSRMLS_FETCH_FROM_CTX(ctx) void ***tsrm_ls = (void ***) ctx
+# else
+# define TSRMLS_FETCH_FROM_CTX(ctx)
+# endif
+#endif
+
+#ifndef TSRMLS_SET_CTX
+# ifdef ZTS
+# define TSRMLS_SET_CTX(ctx) ctx = (void ***) tsrm_ls
+# else
+# define TSRMLS_SET_CTX(ctx)
+# endif
+#endif
+
+#ifndef ZVAL_ADDREF
+# define ZVAL_ADDREF Z_ADDREF_P
+#endif
+
+#ifndef SEPARATE_ARG_IF_REF
+#define SEPARATE_ARG_IF_REF(zv) \
+ if (PZVAL_IS_REF(zv)) { \
+ zval *ov = zv; \
+ ALLOC_INIT_ZVAL(zv); \
+ Z_TYPE_P(zv) = Z_TYPE_P(ov); \
+ zv->value = ov->value; \
+ zval_copy_ctor(zv); \
+ } else { \
+ ZVAL_ADDREF(zv); \
+ }
+#endif
+
+#ifndef ZVAL_ZVAL
+#define ZVAL_ZVAL(z, zv, copy, dtor) { \
+ int is_ref, refcount; \
+ is_ref = (z)->is_ref; \
+ refcount = (z)->refcount; \
+ *(z) = *(zv); \
+ if (copy) { \
+ zval_copy_ctor(z); \
+ } \
+ if (dtor) { \
+ if (!copy) { \
+ ZVAL_NULL(zv); \
+ } \
+ zval_ptr_dtor(&zv); \
+ } \
+ (z)->is_ref = is_ref; \
+ (z)->refcount = refcount; \
+ }
+#endif
+#ifndef RETVAL_ZVAL
+# define RETVAL_ZVAL(zv, copy, dtor) ZVAL_ZVAL(return_value, zv, copy, dtor)
+#endif
+#ifndef RETURN_ZVAL
+# define RETURN_ZVAL(zv, copy, dtor) { RETVAL_ZVAL(zv, copy, dtor); return; }
+#endif
+
+#ifndef ZEND_MN
+# define ZEND_MN(name) ZEND_FN(name)
+#endif
+
+#ifdef WONKY
+extern int zend_declare_property_double(zend_class_entry *ce, char *name, int name_length, double value, int access_type TSRMLS_DC);
+extern void zend_update_property_double(zend_class_entry *scope, zval *object, char *name, int name_length, double value TSRMLS_DC);
+
+extern int zend_declare_property_bool(zend_class_entry *ce, char *name, int name_length, long value, int access_type TSRMLS_DC);
+extern void zend_update_property_bool(zend_class_entry *scope, zval *object, char *name, int name_length, long value TSRMLS_DC);
+
+extern void zend_update_property_stringl(zend_class_entry *scope, zval *object, char *name, int name_length, char *value, int value_len TSRMLS_DC);
+#endif
+
+#endif
+
+/*
+ * Local variables:
+ * tab-width: 4
+ * c-basic-offset: 4
+ * End:
+ * vim600: noet sw=4 ts=4 fdm=marker
+ * vim<600: noet sw=4 ts=4
+ */
+
|
[-]
[+]
|
Added |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http.h
^
|
@@ -0,0 +1,262 @@
+/*
+ +--------------------------------------------------------------------+
+ | PECL :: http |
+ +--------------------------------------------------------------------+
+ | Redistribution and use in source and binary forms, with or without |
+ | modification, are permitted provided that the conditions mentioned |
+ | in the accompanying LICENSE file are met. |
+ +--------------------------------------------------------------------+
+ | Copyright (c) 2004-2010, Michael Wallner <mike@php.net> |
+ +--------------------------------------------------------------------+
+*/
+
+/* $Id: php_http.h 330562 2013-06-20 13:20:43Z mike $ */
+
+#ifndef PHP_EXT_HTTP_H
+#define PHP_EXT_HTTP_H
+
+#define PHP_HTTP_VERSION "1.7.6"
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#else
+# ifndef PHP_WIN32
+# include "php_config.h"
+# endif
+#endif
+
+#include "php.h"
+#include "missing.h"
+#include "php_http_std_defs.h"
+#include "phpstr/phpstr.h"
+
+#ifdef HTTP_WANT_SAPI
+# if PHP_API_VERSION > 20041225
+# define HTTP_HAVE_SAPI_RTIME
+# endif
+# include "SAPI.h"
+#endif
+
+#ifdef HTTP_WANT_NETDB
+# ifdef PHP_WIN32
+# define HTTP_HAVE_NETDB
+# include <winsock2.h>
+# elif defined(HAVE_NETDB_H)
+# define HTTP_HAVE_NETDB
+# include <netdb.h>
+# ifdef HAVE_UNISTD_H
+# include <unistd.h>
+# endif
+# endif
+#endif
+
+#if defined(HTTP_WANT_CURL) && defined(HTTP_HAVE_CURL)
+# ifdef PHP_WIN32
+# include <winsock2.h>
+# define CURL_STATICLIB
+# endif
+# include <curl/curl.h>
+# define HTTP_CURL_VERSION(x, y, z) (LIBCURL_VERSION_NUM >= (((x)<<16) + ((y)<<8) + (z)))
+#
+# if defined(HTTP_WANT_EVENT) && defined(HTTP_HAVE_EVENT)
+# include <event.h>
+# endif
+#endif
+
+#if defined(HTTP_WANT_MAGIC) && defined(HTTP_HAVE_MAGIC)
+# if defined(PHP_WIN32) && !defined(USE_MAGIC_DLL) && !defined(USE_MAGIC_STATIC)
+# define USE_MAGIC_STATIC
+# endif
+# include <magic.h>
+#endif
+
+#if defined(HTTP_WANT_ZLIB) && defined(HTTP_HAVE_ZLIB)
+# include <zlib.h>
+#endif
+
+#include <ctype.h>
+#define HTTP_IS_CTYPE(type, c) is##type((int) (unsigned char) (c))
+#define HTTP_TO_CTYPE(type, c) to##type((int) (unsigned char) (c))
+
+extern zend_module_entry http_module_entry;
+#define phpext_http_ptr &http_module_entry
+
+extern int http_module_number;
+
+ZEND_BEGIN_MODULE_GLOBALS(http)
+
+ struct _http_globals_etag {
+ char *mode;
+ void *ctx;
+ zend_bool started;
+ } etag;
+
+ struct _http_globals_log {
+ char *cache;
+ char *redirect;
+ char *not_found;
+ char *allowed_methods;
+ char *composite;
+ } log;
+
+ struct _http_globals_send {
+ double throttle_delay;
+ size_t buffer_size;
+ char *content_type;
+ char *unquoted_etag;
+ time_t last_modified;
+ struct _http_globals_send_deflate {
+ zend_bool response;
+ zend_bool start_auto;
+ long start_flags;
+ int encoding;
+ void *stream;
+ } deflate;
+ struct _http_globals_send_inflate {
+ zend_bool start_auto;
+ long start_flags;
+ void *stream;
+ } inflate;
+ zend_bool not_found_404;
+ } send;
+
+ struct _http_globals_request {
+ time_t time;
+ HashTable *headers;
+ struct _http_globals_request_methods {
+ HashTable registered;
+ char *allowed;
+ char *custom;
+ } methods;
+#if defined(ZEND_ENGINE_2) && defined(HTTP_HAVE_CURL)
+ struct _http_globals_request_datashare {
+ zend_llist handles;
+ zend_bool cookie;
+ zend_bool dns;
+ zend_bool ssl;
+ zend_bool connect;
+ } datashare;
+#endif
+#if defined(ZEND_ENGINE_2) && defined(HTTP_HAVE_EVENT)
+ struct _http_globals_request_pool {
+ struct _http_globals_request_pool_event {
+ void *base;
+ } event;
+ } pool;
+#endif
+ } request;
+
+ struct _http_globals_persistent {
+ struct _http_globals_persistent_handles {
+ ulong limit;
+ struct _http_globals_persistent_handles_ident {
+ ulong h;
+ char *s;
+ size_t l;
+ } ident;
+ } handles;
+ } persistent;
+
+#ifdef ZEND_ENGINE_2
+ zend_bool only_exceptions;
+#endif
+
+ zend_bool force_exit;
+ zend_bool read_post_data;
+ zval *server_var;
+
+ZEND_END_MODULE_GLOBALS(http)
+
+ZEND_EXTERN_MODULE_GLOBALS(http);
+
+#ifdef ZTS
+# include "TSRM.h"
+# define HTTP_G ((zend_http_globals *) (*((void ***) tsrm_ls))[TSRM_UNSHUFFLE_RSRC_ID(http_globals_id)])
+#else
+# define HTTP_G (&http_globals)
+#endif
+
+#if defined(HAVE_ICONV) && (HTTP_SHARED_DEPS || !defined(COMPILE_DL_ICONV))
+# define HTTP_HAVE_ICONV
+#endif
+
+#if defined(HAVE_PHP_SESSION) && (HTTP_SHARED_DEPS || !defined(COMPILE_DL_SESSION))
+# define HTTP_HAVE_SESSION
+#endif
+
+#if defined(HAVE_HASH_EXT) && (HTTP_SHARED_DEPS || !defined(COMPILE_DL_HASH)) && defined(HTTP_HAVE_PHP_HASH_H)
+# define HTTP_HAVE_HASH
+#endif
+
+#if defined(HAVE_SPL)
+# define HTTP_HAVE_SPL
+#endif
+
+PHP_FUNCTION(http_date);
+PHP_FUNCTION(http_build_url);
+PHP_FUNCTION(http_build_str);
+PHP_FUNCTION(http_negotiate_language);
+PHP_FUNCTION(http_negotiate_charset);
+PHP_FUNCTION(http_negotiate_content_type);
+PHP_FUNCTION(http_negotiate);
+PHP_FUNCTION(http_redirect);
+PHP_FUNCTION(http_throttle);
+PHP_FUNCTION(http_send_status);
+PHP_FUNCTION(http_send_last_modified);
+PHP_FUNCTION(http_send_content_type);
+PHP_FUNCTION(http_send_content_disposition);
+PHP_FUNCTION(http_match_modified);
+PHP_FUNCTION(http_match_etag);
+PHP_FUNCTION(http_cache_last_modified);
+PHP_FUNCTION(http_cache_etag);
+PHP_FUNCTION(http_send_data);
+PHP_FUNCTION(http_send_file);
+PHP_FUNCTION(http_send_stream);
+PHP_FUNCTION(http_chunked_decode);
+PHP_FUNCTION(http_parse_message);
+PHP_FUNCTION(http_parse_headers);
+PHP_FUNCTION(http_parse_cookie);
+PHP_FUNCTION(http_build_cookie);
+PHP_FUNCTION(http_parse_params);
+PHP_FUNCTION(http_get_request_headers);
+PHP_FUNCTION(http_get_request_body);
+PHP_FUNCTION(http_get_request_body_stream);
+PHP_FUNCTION(http_match_request_header);
+PHP_FUNCTION(http_persistent_handles_count);
+PHP_FUNCTION(http_persistent_handles_clean);
+PHP_FUNCTION(http_persistent_handles_ident);
+#ifdef HTTP_HAVE_CURL
+PHP_FUNCTION(http_get);
+PHP_FUNCTION(http_head);
+PHP_FUNCTION(http_post_data);
+PHP_FUNCTION(http_post_fields);
+PHP_FUNCTION(http_put_data);
+PHP_FUNCTION(http_put_file);
+PHP_FUNCTION(http_put_stream);
+PHP_FUNCTION(http_request);
+PHP_FUNCTION(http_request_body_encode);
+#endif /* HTTP_HAVE_CURL */
+PHP_FUNCTION(http_request_method_register);
+PHP_FUNCTION(http_request_method_unregister);
+PHP_FUNCTION(http_request_method_exists);
+PHP_FUNCTION(http_request_method_name);
+PHP_FUNCTION(ob_etaghandler);
+#ifdef HTTP_HAVE_ZLIB
+PHP_FUNCTION(http_deflate);
+PHP_FUNCTION(http_inflate);
+PHP_FUNCTION(ob_deflatehandler);
+PHP_FUNCTION(ob_inflatehandler);
+#endif
+PHP_FUNCTION(http_support);
+
+#endif /* PHP_HTTP_H */
+
+/*
+ * Local variables:
+ * tab-width: 4
+ * c-basic-offset: 4
+ * End:
+ * vim600: noet sw=4 ts=4 fdm=marker
+ * vim<600: noet sw=4 ts=4
+ */
+
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_cache_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_cache_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_cache_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_cache_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_cookie_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_cookie_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_cookie_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_cookie_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_date_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_date_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_date_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_date_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_deflatestream_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_deflatestream_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_deflatestream_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_deflatestream_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_encoding_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_encoding_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_encoding_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_encoding_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_exception_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_exception_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_exception_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_exception_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_filter_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_filter_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_filter_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_filter_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_inflatestream_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_inflatestream_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_inflatestream_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_inflatestream_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_info_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_info_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_info_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_info_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_message_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_message_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_message_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_message_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_message_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_message_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_message_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_message_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_persistent_handle_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_persistent_handle_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_persistent_handle_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_persistent_handle_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_querystring_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_querystring_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_querystring_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_querystring_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_querystring_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_querystring_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_querystring_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_querystring_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_body_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_body_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_body_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_body_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_datashare_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_datashare_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_datashare_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_datashare_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_int.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_int.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_int.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_int.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_method_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_method_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_method_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_method_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_pool_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_pool_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_request_pool_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_request_pool_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_requestdatashare_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_requestdatashare_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_requestdatashare_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_requestdatashare_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_requestpool_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_requestpool_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_requestpool_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_requestpool_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_response_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_response_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_response_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_response_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_send_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_send_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_send_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_send_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_std_defs.h
^
|
(renamed from pecl_http-1.7.5/php_http_std_defs.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_std_defs.h
^
|
(renamed from pecl_http-1.7.5/php_http_std_defs.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_url_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_url_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_url_api.h
^
|
(renamed from pecl_http-1.7.5/php_http_url_api.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_util_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_util_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/php_http_util_object.h
^
|
(renamed from pecl_http-1.7.5/php_http_util_object.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/phpstr/phpstr.c
^
|
(renamed from pecl_http-1.7.5/phpstr/phpstr.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/phpstr/phpstr.c
^
|
(renamed from pecl_http-1.7.5/phpstr/phpstr.c)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/phpstr/phpstr.h
^
|
(renamed from pecl_http-1.7.5/phpstr/phpstr.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/phpstr/phpstr.h
^
|
(renamed from pecl_http-1.7.5/phpstr/phpstr.h)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_007.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_007.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_007.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_007.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_008.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_008.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_008.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_008.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_009_bug16700.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_009_bug16700.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpMessage_009_bug16700.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpMessage_009_bug16700.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpQueryString_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpQueryString_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestDataShare_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestDataShare_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestDataShare_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestDataShare_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestDataShare_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestDataShare_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestDataShare_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestDataShare_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequestPool_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequestPool_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_007.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_007.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_007.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_007.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_008.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_008.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_008.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_008.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_009.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_009.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_009.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_009.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_010.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_010.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpRequest_010.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpRequest_010.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/HttpResponse_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/HttpResponse_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/allowed_methods_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/allowed_methods_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/allowed_methods_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/allowed_methods_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/allowed_methods_002_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/allowed_methods_002_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/allowed_methods_002_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/allowed_methods_002_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/bug_15800.phpt
^
|
(renamed from pecl_http-1.7.5/tests/bug_15800.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/bug_15800.phpt
^
|
(renamed from pecl_http-1.7.5/tests/bug_15800.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_str_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_str_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_str_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_str_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/build_url_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/build_url_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/chunked_decode_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/chunked_decode_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/cloning_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/cloning_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/cloning_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/cloning_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/data.txt
^
|
(renamed from pecl_http-1.7.5/tests/data.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/data.txt
^
|
(renamed from pecl_http-1.7.5/tests/data.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/date_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/date_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/date_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/date_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/date_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/date_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/date_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/date_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/encoding_objects_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/encoding_objects_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/encoding_objects_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/encoding_objects_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/encodings.phpt
^
|
(renamed from pecl_http-1.7.5/tests/encodings.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/encodings.phpt
^
|
(renamed from pecl_http-1.7.5/tests/encodings.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_031.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_031.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_031.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_031.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_032.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_032.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_032.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_032.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_033.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_033.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_033.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_033.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_034.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_034.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_034.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_034.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_041.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_041.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_041.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_041.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_042.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_042.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_042.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_042.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_043.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_043.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_043.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_043.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_044.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_044.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/etag_mode_044.phpt
^
|
(renamed from pecl_http-1.7.5/tests/etag_mode_044.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/exceptions.phpt
^
|
(renamed from pecl_http-1.7.5/tests/exceptions.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/exceptions.phpt
^
|
(renamed from pecl_http-1.7.5/tests/exceptions.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/get_request_data_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/get_request_data_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/get_request_data_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/get_request_data_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/log.inc
^
|
(renamed from pecl_http-1.7.5/tests/log.inc)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/log.inc
^
|
(renamed from pecl_http-1.7.5/tests/log.inc)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/negotiation_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/negotiation_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/negotiation_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/negotiation_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/ob_deflatehandler_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/ob_deflatehandler_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/ob_deflatehandler_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/ob_deflatehandler_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/ob_inflatehandler_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/ob_inflatehandler_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/ob_inflatehandler_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/ob_inflatehandler_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_cookie_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_cookie_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_cookie_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_cookie_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_cookie_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_cookie_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_cookie_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_cookie_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_message_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_message_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_params_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_params_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/parse_params_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/parse_params_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/persistent_handles_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/persistent_handles_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/persistent_handles_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/persistent_handles_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/persistent_handles_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/persistent_handles_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/persistent_handles_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/persistent_handles_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/persistent_handles_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/persistent_handles_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/persistent_handles_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/persistent_handles_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_011.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_011.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_011.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_011.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_011_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_011_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_011_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_011_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_012.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_012.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_012.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_012.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_012_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_012_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_012_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_012_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_013.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_013.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_013.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_013.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_013_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_013_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/redirect_013_logging.phpt
^
|
(renamed from pecl_http-1.7.5/tests/redirect_013_logging.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_cookies.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_cookies.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_cookies.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_cookies.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_etag.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_etag.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_etag.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_etag.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_gzip.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_gzip.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_gzip.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_gzip.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_methods.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_methods.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_methods.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_methods.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_put_data.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_put_data.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/request_put_data.phpt
^
|
(renamed from pecl_http-1.7.5/tests/request_put_data.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_004.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_004.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_006.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_006.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_010.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_010.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_010.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_010.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_011.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_011.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_data_011.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_data_011.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_failed_precond_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_failed_precond_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_failed_precond_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_failed_precond_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_005.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_005.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_008.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_008.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_008.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_008.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_009.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_009.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_009.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_009.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_010.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_010.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_010.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_010.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_011.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_011.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_011.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_011.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_012.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_012.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_012.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_012.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_013.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_013.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_file_013.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_file_013.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_ifrange_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_ifrange_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_ifrange_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_ifrange_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_ifrange_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_ifrange_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/send_ifrange_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/send_ifrange_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/skip.inc
^
|
(renamed from pecl_http-1.7.5/tests/skip.inc)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/skip.inc
^
|
(renamed from pecl_http-1.7.5/tests/skip.inc)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/stream_filters_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/stream_filters_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/stream_filters_001.phpt
^
|
(renamed from pecl_http-1.7.5/tests/stream_filters_001.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/stream_filters_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/stream_filters_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/stream_filters_002.phpt
^
|
(renamed from pecl_http-1.7.5/tests/stream_filters_002.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/stream_filters_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/stream_filters_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/stream_filters_003.phpt
^
|
(renamed from pecl_http-1.7.5/tests/stream_filters_003.phpt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/urls.txt
^
|
(renamed from pecl_http-1.7.5/tests/urls.txt)
|
[-]
[+]
|
Changed |
pecl_http-1.7.6.tar.bz2/pecl_http-1.7.6/tests/urls.txt
^
|
(renamed from pecl_http-1.7.5/tests/urls.txt)
|