summaryrefslogtreecommitdiffstats
path: root/wsdl2c/CallVar.c
diff options
context:
space:
mode:
authorGravatar snowdrop2004-06-03 13:13:07 +0000
committerGravatar snowdrop2004-06-03 13:13:07 +0000
commit5dee322ce245ef858b3d0e6591cdc19d76e4cb30 (patch)
tree0ba0dfe188a4e9da2ebf2c9f32eb8b2e9a9a3401 /wsdl2c/CallVar.c
parent4666292be1927bdb2e319f417a08ab17c91de784 (diff)
downloadcsoap-5dee322ce245ef858b3d0e6591cdc19d76e4cb30.tar.gz
csoap-5dee322ce245ef858b3d0e6591cdc19d76e4cb30.tar.bz2
initial import
Diffstat (limited to 'wsdl2c/CallVar.c')
-rw-r--r--wsdl2c/CallVar.c126
1 files changed, 126 insertions, 0 deletions
diff --git a/wsdl2c/CallVar.c b/wsdl2c/CallVar.c
new file mode 100644
index 0000000..035f56c
--- /dev/null
+++ b/wsdl2c/CallVar.c
@@ -0,0 +1,126 @@
+/** Generated by xsd2c */
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+#include "CallVar.h"
+
+
+struct CallVar* CallVar_Create()
+{
+ struct CallVar* _res;
+ _res = (struct CallVar*)malloc(sizeof(struct CallVar));
+
+ _res->name = NULL;
+ _res->type = NULL;
+
+ return _res;
+}
+
+void CallVar_Free(struct CallVar* obj)
+{
+ if (obj == NULL) return;
+ if (obj->name != NULL)
+ {
+ free(obj->name);
+ obj->name = NULL;
+ }
+ if (obj->type != NULL)
+ {
+ free(obj->type);
+ obj->type = NULL;
+ }
+ free(obj);
+}
+
+void CallVar_Sax_Serialize(struct CallVar* obj,
+ const char *root_element_name,
+ void (*OnStartElement)(const char* element_name, int attr_count, char **keys, char **values, void* userData),
+ void (*OnCharacters)(const char* element_name, const char* chars, void* userData),
+ void (*OnEndElement)(const char* element_name, void* userData),
+ void* userData)
+{
+ int attrCount, curCount;
+ char **keys;
+ char **values;
+ char buffer[255];
+
+
+ attrCount = 0;
+
+ keys = (char**)malloc(sizeof(char*)*attrCount);
+ values = (char**)malloc(sizeof(char*)*attrCount);
+
+ curCount = 0;
+
+
+ OnStartElement(root_element_name, attrCount, keys, values, userData);
+
+ OnStartElement("name", 0, NULL, NULL, userData);
+ if (obj->name != NULL)
+ OnCharacters("name", obj->name, userData);
+ OnEndElement("name", userData);
+
+ OnStartElement("type", 0, NULL, NULL, userData);
+ if (obj->type != NULL)
+ OnCharacters("type", obj->type, userData);
+ OnEndElement("type", userData);
+
+ OnEndElement(root_element_name, userData);
+}
+
+#ifndef _DESERIALIZER_DISABLED_
+
+struct CallVar* CallVar_Deserialize(xmlNodePtr xmlRoot)
+{
+ xmlNodePtr cur;
+ xmlChar *key;
+ struct CallVar* obj;
+ obj = CallVar_Create();
+ cur = xmlRoot->xmlChildrenNode;
+ while (cur != NULL) {
+ if (cur->type != XML_ELEMENT_NODE) {
+ cur = cur->next;
+ continue;
+ }
+ printf("CallVar->%s\n", cur->name);
+ if ((!xmlStrcmp(cur->name, (const xmlChar *)"name"))){
+ key = xmlNodeListGetString(cur->doc, cur->xmlChildrenNode, 1);
+ CallVar_Set_name(obj, (const char*)key);
+ xmlFree(key);
+ }
+ if ((!xmlStrcmp(cur->name, (const xmlChar *)"type"))){
+ key = xmlNodeListGetString(cur->doc, cur->xmlChildrenNode, 1);
+ CallVar_Set_type(obj, (const char*)key);
+ xmlFree(key);
+ }
+ // TODO:
+ cur = cur->next;
+ }
+ return obj;
+}
+
+#endif
+char* CallVar_Get_name(struct CallVar* obj)
+{
+ return obj->name;
+}
+
+char* CallVar_Get_type(struct CallVar* obj)
+{
+ return obj->type;
+}
+
+void CallVar_Set_name(struct CallVar* obj, const char* name)
+{
+ if (obj->name != NULL) free(obj->name);
+ obj->name = (char*)malloc(strlen(name)+1);
+ strcpy(obj->name, name);
+}
+
+void CallVar_Set_type(struct CallVar* obj, const char* type)
+{
+ if (obj->type != NULL) free(obj->type);
+ obj->type = (char*)malloc(strlen(type)+1);
+ strcpy(obj->type, type);
+}
+