annotate mcabber/libjabber/expat.c @ 183:c658c131ea10

[/trunk] Changeset 195 by mikael * Fix a small bug (status is uppercase in log files)
author mikael
date Thu, 05 May 2005 15:01:48 +0000
parents bf3d6e241714
children c3ae9251c197
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
25
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
1 /*
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
2 * This program is free software; you can redistribute it and/or modify
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
3 * it under the terms of the GNU General Public License as published by
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
4 * the Free Software Foundation; either version 2 of the License, or
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
5 * (at your option) any later version.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
6 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
7 * This program is distributed in the hope that it will be useful,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
10 * GNU General Public License for more details.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
11 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
12 * You should have received a copy of the GNU General Public License
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
13 * along with this program; if not, write to the Free Software
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
14 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
15 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
16 * Jabber
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
17 * Copyright (C) 1998-1999 The Jabber Team http://jabber.org/
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
18 */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
19
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
20 #include <libxode.h>
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
21
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
22 void expat_startElement(void* userdata, const char* name, const char** atts)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
23 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
24 /* get the xmlnode pointed to by the userdata */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
25 xmlnode *x = userdata;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
26 xmlnode current = *x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
27
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
28 if (current == NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
29 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
30 /* allocate a base node */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
31 current = xmlnode_new_tag(name);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
32 xmlnode_put_expat_attribs(current, atts);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
33 *x = current;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
34 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
35 else
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
36 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
37 *x = xmlnode_insert_tag(current, name);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
38 xmlnode_put_expat_attribs(*x, atts);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
39 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
40 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
41
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
42 void expat_endElement(void* userdata, const char* name)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
43 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
44 xmlnode *x = userdata;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
45 xmlnode current = *x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
46
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
47 current->complete = 1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
48 current = xmlnode_get_parent(current);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
49
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
50 /* if it's NULL we've hit the top folks, otherwise back up a level */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
51 if(current != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
52 *x = current;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
53 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
54
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
55 void expat_charData(void* userdata, const char* s, int len)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
56 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
57 xmlnode *x = userdata;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
58 xmlnode current = *x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
59
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
60 xmlnode_insert_cdata(current, s, len);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
61 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
62
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
63
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
64 xmlnode xmlnode_str(char *str, int len)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
65 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
66 XML_Parser p;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
67 xmlnode *x, node; /* pointer to an xmlnode */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
68
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
69 if(NULL == str)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
70 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
71
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
72 x = malloc(sizeof(void *));
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
73
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
74 *x = NULL; /* pointer to NULL */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
75 p = XML_ParserCreate(NULL);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
76 XML_SetUserData(p, x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
77 XML_SetElementHandler(p, expat_startElement, expat_endElement);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
78 XML_SetCharacterDataHandler(p, expat_charData);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
79 if(!XML_Parse(p, str, len, 1))
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
80 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
81 /* jdebug(ZONE,"xmlnode_str_error: %s",(char *)XML_ErrorString(XML_GetErrorCode(p)));*/
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
82 xmlnode_free(*x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
83 *x = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
84 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
85 node = *x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
86 free(x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
87 XML_ParserFree(p);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
88 return node; /* return the xmlnode x points to */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
89 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
90
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
91 xmlnode xmlnode_file(char *file)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
92 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
93 XML_Parser p;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
94 xmlnode *x, node; /* pointer to an xmlnode */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
95 char buf[BUFSIZ];
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
96 int done, fd, len;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
97
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
98 if(NULL == file)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
99 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
100
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
101 fd = open(file,O_RDONLY);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
102 if(fd < 0)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
103 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
104
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
105 x = malloc(sizeof(void *));
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
106
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
107 *x = NULL; /* pointer to NULL */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
108 p = XML_ParserCreate(NULL);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
109 XML_SetUserData(p, x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
110 XML_SetElementHandler(p, expat_startElement, expat_endElement);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
111 XML_SetCharacterDataHandler(p, expat_charData);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
112 do{
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
113 len = read(fd, buf, BUFSIZ);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
114 done = len < BUFSIZ;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
115 if(!XML_Parse(p, buf, len, done))
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
116 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
117 /* jdebug(ZONE,"xmlnode_file_parseerror: %s",(char *)XML_ErrorString(XML_GetErrorCode(p)));*/
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
118 xmlnode_free(*x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
119 *x = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
120 done = 1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
121 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
122 }while(!done);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
123
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
124 node = *x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
125 XML_ParserFree(p);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
126 free(x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
127 close(fd);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
128 return node; /* return the xmlnode x points to */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
129 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
130
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
131 int xmlnode2file(char *file, xmlnode node)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
132 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
133 char *doc;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
134 int fd, i;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
135
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
136 if(file == NULL || node == NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
137 return -1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
138
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
139 fd = open(file, O_CREAT | O_WRONLY | O_TRUNC, 0600);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
140 if(fd < 0)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
141 return -1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
142
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
143 doc = xmlnode2str(node);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
144 i = write(fd,doc,strlen(doc));
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
145 if(i < 0)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
146 return -1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
147
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
148 close(fd);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
149 return 1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
150 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
151
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
152 void xmlnode_put_expat_attribs(xmlnode owner, const char** atts)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
153 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
154 int i = 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
155 if (atts == NULL) return;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
156 while (atts[i] != '\0')
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
157 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
158 xmlnode_put_attrib(owner, atts[i], atts[i+1]);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
159 i += 2;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
160 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
161 }