dmitry          Tue Feb 17 10:10:18 2004 EDT

  Modified files:              
    /php-src/ext/soap   php_encoding.c php_schema.c php_sdl.c soap.c 
  Log:
  support for XMLSchema <element> nillable attribute
  
  
http://cvs.php.net/diff.php/php-src/ext/soap/php_encoding.c?r1=1.59&r2=1.60&ty=u
Index: php-src/ext/soap/php_encoding.c
diff -u php-src/ext/soap/php_encoding.c:1.59 php-src/ext/soap/php_encoding.c:1.60
--- php-src/ext/soap/php_encoding.c:1.59        Tue Feb 17 03:18:53 2004
+++ php-src/ext/soap/php_encoding.c     Tue Feb 17 10:10:16 2004
@@ -17,7 +17,7 @@
   |          Dmitry Stogov <[EMAIL PROTECTED]>                             |
   +----------------------------------------------------------------------+
 */
-/* $Id: php_encoding.c,v 1.59 2004/02/17 08:18:53 dmitry Exp $ */
+/* $Id: php_encoding.c,v 1.60 2004/02/17 15:10:16 dmitry Exp $ */
 
 #include <time.h>
 
@@ -108,7 +108,7 @@
        if (!zval || Z_TYPE_P(zval) == IS_NULL) { \
          if (style == SOAP_ENCODED) {\
                        xmlSetProp(xml, "xsi:nil", "1"); \
-               }\
+               } \
                return xml; \
        } \
 }
@@ -979,12 +979,34 @@
 
                                        zend_hash_internal_pointer_reset(ht);
                                        while 
(zend_hash_get_current_data(ht,(void**)&val) == SUCCESS) {
-                                               property = master_to_xml(enc, *val, 
style, node);
+                                               if (Z_TYPE_PP(val) == IS_NULL && 
model->u.element->nillable) {
+                                                       property = 
xmlNewNode(NULL,"BOGUS");
+                                                       xmlAddChild(node, property);
+                                                       if (style == SOAP_ENCODED) {
+                                                               xmlSetProp(property, 
"xsi:nil", "1");
+                                                       } else {
+                                                         xmlNsPtr xsi = 
encode_add_ns(property,XSI_NAMESPACE);
+                                                               xmlSetNsProp(property, 
xsi, "nil", "1");
+                                                       }
+                                               } else {
+                                                       property = master_to_xml(enc, 
*val, style, node);
+                                               }
                                                xmlNodeSetName(property, 
model->u.element->name);
                                                zend_hash_move_forward(ht);
                                        }
                                } else {
-                                       property = master_to_xml(enc, *data, style, 
node);
+                                       if (Z_TYPE_PP(data) == IS_NULL && 
model->u.element->nillable) {
+                                               property = xmlNewNode(NULL,"BOGUS");
+                                               xmlAddChild(node, property);
+                                               if (style == SOAP_ENCODED) {
+                                                       xmlSetProp(property, 
"xsi:nil", "1");
+                                               } else {
+                                                 xmlNsPtr xsi = 
encode_add_ns(property,XSI_NAMESPACE);
+                                                       xmlSetNsProp(property, xsi, 
"nil", "1");
+                                               }
+                                       } else {
+                                               property = master_to_xml(enc, *data, 
style, node);
+                                       }
                                        xmlNodeSetName(property, 
model->u.element->name);
                                }
                                return 1;
@@ -1149,7 +1171,19 @@
 
                                zend_hash_internal_pointer_reset(prop);
                                while (zend_hash_get_current_data(prop,(void**)&val) 
== SUCCESS) {
-                                       xmlNodePtr property = 
master_to_xml(array_el->encode, *val, style, xmlParam);
+                                       xmlNodePtr property;
+                                       if (Z_TYPE_PP(val) == IS_NULL && 
array_el->nillable) {
+                                               property = xmlNewNode(NULL,"BOGUS");
+                                               xmlAddChild(xmlParam, property);
+                                               if (style == SOAP_ENCODED) {
+                                                       xmlSetProp(property, 
"xsi:nil", "1");
+                                               } else {
+                                                 xmlNsPtr xsi = 
encode_add_ns(property,XSI_NAMESPACE);
+                                                       xmlSetNsProp(property, xsi, 
"nil", "1");
+                                               }
+                                       } else {
+                                               property = 
master_to_xml(array_el->encode, *val, style, xmlParam);
+                                       }
                                        xmlNodeSetName(property, array_el->name);
                                        zend_hash_move_forward(prop);
                                }
http://cvs.php.net/diff.php/php-src/ext/soap/php_schema.c?r1=1.43&r2=1.44&ty=u
Index: php-src/ext/soap/php_schema.c
diff -u php-src/ext/soap/php_schema.c:1.43 php-src/ext/soap/php_schema.c:1.44
--- php-src/ext/soap/php_schema.c:1.43  Fri Feb 13 10:19:09 2004
+++ php-src/ext/soap/php_schema.c       Tue Feb 17 10:10:16 2004
@@ -17,7 +17,7 @@
   |          Dmitry Stogov <[EMAIL PROTECTED]>                             |
   +----------------------------------------------------------------------+
 */
-/* $Id: php_schema.c,v 1.43 2004/02/13 15:19:09 dmitry Exp $ */
+/* $Id: php_schema.c,v 1.44 2004/02/17 15:10:16 dmitry Exp $ */
 
 #include "php_soap.h"
 #include "libxml/uri.h"
@@ -2135,6 +2135,9 @@
                        if (zend_hash_find(ctx->sdl->elements, type->ref, 
strlen(type->ref)+1, (void**)&tmp) == SUCCESS) {
                                type->encode = (*tmp)->encode;
                                /* TODO: nillable */
+                               if ((*tmp)->nillable) {
+                                 type->nillable = 1;
+                               }
                        } else {
                                php_error(E_ERROR, "SOAP-ERROR: Parsing Schema: 
unresolved element 'ref' attribute");
                        }
http://cvs.php.net/diff.php/php-src/ext/soap/php_sdl.c?r1=1.61&r2=1.62&ty=u
Index: php-src/ext/soap/php_sdl.c
diff -u php-src/ext/soap/php_sdl.c:1.61 php-src/ext/soap/php_sdl.c:1.62
--- php-src/ext/soap/php_sdl.c:1.61     Tue Feb 17 04:23:28 2004
+++ php-src/ext/soap/php_sdl.c  Tue Feb 17 10:10:16 2004
@@ -17,7 +17,7 @@
   |          Dmitry Stogov <[EMAIL PROTECTED]>                             |
   +----------------------------------------------------------------------+
 */
-/* $Id: php_sdl.c,v 1.61 2004/02/17 09:23:28 dmitry Exp $ */
+/* $Id: php_sdl.c,v 1.62 2004/02/17 15:10:16 dmitry Exp $ */
 
 #include "php_soap.h"
 #include "libxml/uri.h"
@@ -877,7 +877,7 @@
        return ctx.sdl;
 }
 
-#define WSDL_CACHE_VERSION 02
+#define WSDL_CACHE_VERSION 03
 
 #define WSDL_CACHE_GET(ret,type,buf)   memcpy(&ret,*buf,sizeof(type)); *buf += 
sizeof(type);
 #define WSDL_CACHE_GET_INT(ret,buf)    ret = 
((int)(*buf)[0])|((int)(*buf)[1]<<8)|((int)(*buf)[2]<<16)|((int)(*buf)[3]<<24); *buf 
+= 4;
@@ -992,14 +992,12 @@
                case XSD_CONTENT_ALL:
                case XSD_CONTENT_CHOICE:
                        WSDL_CACHE_GET_INT(i, in);
-                       if (i > 0) {
-                               model->u.content = emalloc(sizeof(HashTable));
-                               zend_hash_init(model->u.content, i, NULL, 
delete_model, 0);
-                               while (i > 0) {
-                                       sdlContentModelPtr x = 
sdl_deserialize_model(types, elements, in);
-                                       
zend_hash_next_index_insert(model->u.content,&x,sizeof(sdlContentModelPtr),NULL);
-                                       i--;
-                               }
+                       model->u.content = emalloc(sizeof(HashTable));
+                       zend_hash_init(model->u.content, i, NULL, delete_model, 0);
+                       while (i > 0) {
+                               sdlContentModelPtr x = sdl_deserialize_model(types, 
elements, in);
+                               
zend_hash_next_index_insert(model->u.content,&x,sizeof(sdlContentModelPtr),NULL);
+                               i--;
                        }
                        break;
                case XSD_CONTENT_GROUP_REF:
http://cvs.php.net/diff.php/php-src/ext/soap/soap.c?r1=1.86&r2=1.87&ty=u
Index: php-src/ext/soap/soap.c
diff -u php-src/ext/soap/soap.c:1.86 php-src/ext/soap/soap.c:1.87
--- php-src/ext/soap/soap.c:1.86        Tue Feb 17 03:18:53 2004
+++ php-src/ext/soap/soap.c     Tue Feb 17 10:10:16 2004
@@ -17,7 +17,7 @@
   |          Dmitry Stogov <[EMAIL PROTECTED]>                             |
   +----------------------------------------------------------------------+
 */
-/* $Id: soap.c,v 1.86 2004/02/17 08:18:53 dmitry Exp $ */
+/* $Id: soap.c,v 1.87 2004/02/17 15:10:16 dmitry Exp $ */
 
 #ifdef HAVE_CONFIG_H
 #include "config.h"
@@ -387,6 +387,7 @@
        /* hash by namespace */
        zend_hash_add(&soap_globals->defEncNs, XSD_1999_NAMESPACE, 
sizeof(XSD_1999_NAMESPACE), XSD_NS_PREFIX, sizeof(XSD_NS_PREFIX), NULL);
        zend_hash_add(&soap_globals->defEncNs, XSD_NAMESPACE, sizeof(XSD_NAMESPACE), 
XSD_NS_PREFIX, sizeof(XSD_NS_PREFIX), NULL);
+       zend_hash_add(&soap_globals->defEncNs, XSI_NAMESPACE, sizeof(XSI_NAMESPACE), 
XSI_NS_PREFIX, sizeof(XSI_NS_PREFIX), NULL);
        zend_hash_add(&soap_globals->defEncNs, SOAP_1_1_ENC_NAMESPACE, 
sizeof(SOAP_1_1_ENC_NAMESPACE), SOAP_1_1_ENC_NS_PREFIX, 
sizeof(SOAP_1_1_ENC_NS_PREFIX), NULL);
        zend_hash_add(&soap_globals->defEncNs, SOAP_1_2_ENC_NAMESPACE, 
sizeof(SOAP_1_2_ENC_NAMESPACE), SOAP_1_2_ENC_NS_PREFIX, 
sizeof(SOAP_1_2_ENC_NS_PREFIX), NULL);
 

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to