dmitry Wed Oct 5 03:01:48 2005 EDT Added files: /php-src/ext/soap/tests server022.phpt
Modified files: /php-src/ext/soap soap.c Log: Fixed throwing exceptions derived from SoapFault http://cvs.php.net/diff.php/php-src/ext/soap/soap.c?r1=1.162&r2=1.163&ty=u Index: php-src/ext/soap/soap.c diff -u php-src/ext/soap/soap.c:1.162 php-src/ext/soap/soap.c:1.163 --- php-src/ext/soap/soap.c:1.162 Mon Oct 3 05:52:43 2005 +++ php-src/ext/soap/soap.c Wed Oct 5 03:01:44 2005 @@ -17,7 +17,7 @@ | Dmitry Stogov <[EMAIL PROTECTED]> | +----------------------------------------------------------------------+ */ -/* $Id: soap.c,v 1.162 2005/10/03 09:52:43 dmitry Exp $ */ +/* $Id: soap.c,v 1.163 2005/10/05 07:01:44 dmitry Exp $ */ #ifdef HAVE_CONFIG_H #include "config.h" @@ -110,7 +110,7 @@ EG(current_execute_data) = _old_current_execute_data; \ if (EG(exception) == NULL || \ Z_TYPE_P(EG(exception)) != IS_OBJECT || \ - Z_OBJCE_P(EG(exception)) != soap_fault_class_entry) {\ + !instanceof_function(Z_OBJCE_P(EG(exception)), soap_fault_class_entry TSRMLS_CC)) {\ _bailout = 1;\ }\ } zend_end_try();\ @@ -1540,7 +1540,7 @@ } if (EG(exception)) { if (Z_TYPE_P(EG(exception)) == IS_OBJECT && - Z_OBJCE_P(EG(exception)) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE_P(EG(exception)), soap_fault_class_entry TSRMLS_CC)) { soap_server_fault_ex(function, EG(exception), NULL TSRMLS_CC); } else { zval_dtor(&constructor); @@ -1573,7 +1573,7 @@ #ifdef ZEND_ENGINE_2 if (EG(exception)) { if (Z_TYPE_P(EG(exception)) == IS_OBJECT && - Z_OBJCE_P(EG(exception)) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE_P(EG(exception)), soap_fault_class_entry TSRMLS_CC)) { soap_server_fault_ex(function, EG(exception), NULL TSRMLS_CC); } else { zval_dtor(&constructor); @@ -1643,7 +1643,7 @@ php_error_docref(NULL TSRMLS_CC, E_ERROR, "Function '%s' call failed", Z_STRVAL(h->function_name)); } if (Z_TYPE(h->retval) == IS_OBJECT && - Z_OBJCE(h->retval) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE(h->retval), soap_fault_class_entry TSRMLS_CC)) { zval *headerfault = NULL, **tmp; if (zend_hash_find(Z_OBJPROP(h->retval), "headerfault", sizeof("headerfault"), (void**)&tmp) == SUCCESS && @@ -1654,7 +1654,7 @@ #ifdef ZEND_ENGINE_2 } else if (EG(exception)) { if (Z_TYPE_P(EG(exception)) == IS_OBJECT && - Z_OBJCE_P(EG(exception)) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE_P(EG(exception)), soap_fault_class_entry TSRMLS_CC)) { zval *headerfault = NULL, **tmp; if (zend_hash_find(Z_OBJPROP_P(EG(exception)), "headerfault", sizeof("headerfault"), (void**)&tmp) == SUCCESS && @@ -1701,7 +1701,7 @@ #ifdef ZEND_ENGINE_2 if (EG(exception)) { if (Z_TYPE_P(EG(exception)) == IS_OBJECT && - Z_OBJCE_P(EG(exception)) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE_P(EG(exception)), soap_fault_class_entry TSRMLS_CC)) { soap_server_fault_ex(function, EG(exception), NULL TSRMLS_CC); } else { if (soap_obj) {zval_ptr_dtor(&soap_obj);} @@ -1714,7 +1714,7 @@ char *response_name; if (Z_TYPE(retval) == IS_OBJECT && - Z_OBJCE(retval) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE(retval), soap_fault_class_entry TSRMLS_CC)) { soap_server_fault_ex(function, &retval, NULL TSRMLS_CC); } @@ -2017,7 +2017,7 @@ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &fault) == SUCCESS && Z_TYPE_P(fault) == IS_OBJECT && - Z_OBJCE_P(fault) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE_P(fault), soap_fault_class_entry TSRMLS_CC)) { RETURN_TRUE; } RETURN_FALSE @@ -2439,7 +2439,7 @@ } #ifdef ZEND_ENGINE_2 if (Z_TYPE_P(return_value) == IS_OBJECT && - Z_OBJCE_P(return_value) == soap_fault_class_entry && + instanceof_function(Z_OBJCE_P(return_value), soap_fault_class_entry TSRMLS_CC) && (zend_hash_find(Z_OBJPROP_P(this_ptr), "_exceptions", sizeof("_exceptions"), (void **) &tmp) != SUCCESS || Z_TYPE_PP(tmp) != IS_BOOL || Z_LVAL_PP(tmp) != 0)) { zval *exception; @@ -3436,7 +3436,7 @@ xmlDocSetRootElement(doc, envelope); if (Z_TYPE_P(ret) == IS_OBJECT && - Z_OBJCE_P(ret) == soap_fault_class_entry) { + instanceof_function(Z_OBJCE_P(ret), soap_fault_class_entry TSRMLS_CC)) { char *detail_name; HashTable* prop; zval **tmp; http://cvs.php.net/co.php/php-src/ext/soap/tests/server022.phpt?r=1.1&p=1 Index: php-src/ext/soap/tests/server022.phpt +++ php-src/ext/soap/tests/server022.phpt --TEST-- SOAP Server 22: user fault (through throw of subclass) --SKIPIF-- <?php require_once('skipif.inc'); ?> --FILE-- <?php class MyFault extends SoapFault { function __construct() { parent::__construct("MyFault","My fault string"); } } function test() { throw new MyFault; } $server = new soapserver(null,array('uri'=>"http://testuri.org")); $server->addfunction("test"); $HTTP_RAW_POST_DATA = <<<EOF <?xml version="1.0" encoding="ISO-8859-1"?> <SOAP-ENV:Envelope SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:si="http://soapinterop.org/xsd"> <SOAP-ENV:Body> <ns1:test xmlns:ns1="http://testuri.org"/> </SOAP-ENV:Body> </SOAP-ENV:Envelope> EOF; $server->handle(); echo "ok\n"; ?> --EXPECT-- <?xml version="1.0" encoding="UTF-8"?> <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"><SOAP-ENV:Body><SOAP-ENV:Fault><faultcode>MyFault</faultcode><faultstring>My fault string</faultstring></SOAP-ENV:Fault></SOAP-ENV:Body></SOAP-ENV:Envelope> -- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php