summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@php.net>2004-02-17 15:10:16 +0000
committerDmitry Stogov <dmitry@php.net>2004-02-17 15:10:16 +0000
commit7edf9bc2c346ecbc6b82610d30f29431085ce0b9 (patch)
treec007c56b7033ba3856284ee323c685c0e82a4fa8 /ext
parentc796a4769052e15bf70007e2916a480074f45e67 (diff)
downloadphp-git-7edf9bc2c346ecbc6b82610d30f29431085ce0b9.tar.gz
support for XMLSchema <element> nillable attribute
Diffstat (limited to 'ext')
-rw-r--r--ext/soap/php_encoding.c42
-rw-r--r--ext/soap/php_schema.c3
-rw-r--r--ext/soap/php_sdl.c16
-rw-r--r--ext/soap/soap.c1
4 files changed, 49 insertions, 13 deletions
diff --git a/ext/soap/php_encoding.c b/ext/soap/php_encoding.c
index 69bf69a4b1..4a16e8ee06 100644
--- a/ext/soap/php_encoding.c
+++ b/ext/soap/php_encoding.c
@@ -108,7 +108,7 @@ static void set_ns_and_type(xmlNodePtr node, encodeTypePtr type);
if (!zval || Z_TYPE_P(zval) == IS_NULL) { \
if (style == SOAP_ENCODED) {\
xmlSetProp(xml, "xsi:nil", "1"); \
- }\
+ } \
return xml; \
} \
}
@@ -979,12 +979,34 @@ static int model_to_xml_object(xmlNodePtr node, sdlContentModelPtr model, HashTa
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 @@ static xmlNodePtr to_xml_object(encodeTypePtr type, zval *data, int style, xmlNo
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);
}
diff --git a/ext/soap/php_schema.c b/ext/soap/php_schema.c
index 6918cc7492..34bf786f1d 100644
--- a/ext/soap/php_schema.c
+++ b/ext/soap/php_schema.c
@@ -2135,6 +2135,9 @@ static void schema_type_fixup(sdlCtx *ctx, sdlTypePtr type)
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");
}
diff --git a/ext/soap/php_sdl.c b/ext/soap/php_sdl.c
index e9d7246f33..3993758f15 100644
--- a/ext/soap/php_sdl.c
+++ b/ext/soap/php_sdl.c
@@ -877,7 +877,7 @@ static sdlPtr load_wsdl(char *struri)
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 @@ static sdlContentModelPtr sdl_deserialize_model(sdlTypePtr *types, sdlTypePtr *e
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:
diff --git a/ext/soap/soap.c b/ext/soap/soap.c
index 8802ba2193..5ab8a3687e 100644
--- a/ext/soap/soap.c
+++ b/ext/soap/soap.c
@@ -387,6 +387,7 @@ static void php_soap_init_globals(zend_soap_globals *soap_globals)
/* 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);