annotate mcabber/libjabber/pproxy.c @ 122:235fdd5bfd5d

[/trunk] Changeset 135 by mikael * TODO update
author mikael
date Tue, 26 Apr 2005 09:37:05 +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 "jabber.h"
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
21
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
22 /* these aren't the most efficient things in the world, a hash optimized for tiny spaces would be far better */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
23
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
24 ppdb _ppdb_new(pool p, jid id)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
25 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
26 ppdb ret;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
27 ret = pmalloc(p,sizeof(_ppdb));
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
28 ret->p = p;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
29 ret->pri = -1;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
30 ret->next = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
31 ret->user = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
32 ret->x = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
33 ret->id = jid_new(p,jid_full(id));
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
34
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
35 return ret;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
36 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
37
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
38 ppdb _ppdb_get(ppdb db, jid id)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
39 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
40 ppdb cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
41
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
42 if(db == NULL || id == NULL) return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
43
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
44 for(cur = db->next; cur != NULL; cur = cur->next)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
45 if(jid_cmp(cur->id,id) == 0) return cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
46
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
47 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
48 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
49
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
50 ppdb ppdb_insert(ppdb db, jid id, xmlnode x)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
51 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
52 char *res;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
53 ppdb cur, curu;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
54 pool p;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
55
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
56 if(id == NULL || id->server == NULL || x == NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
57 return db;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
58
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
59 /* new ppdb list dummy holder */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
60 if(db == NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
61 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
62 p = pool_heap(1024);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
63 db = _ppdb_new(p,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
64 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
65
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
66 cur = _ppdb_get(db,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
67
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
68 /* just update it */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
69 if(cur != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
70 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
71 xmlnode_free(cur->x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
72 cur->x = xmlnode_dup(x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
73 cur->pri = jutil_priority(x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
74 return db;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
75 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
76
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
77 /* make an entry for it */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
78 cur = _ppdb_new(db->p,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
79 cur->x = xmlnode_dup(x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
80 cur->pri = jutil_priority(x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
81 cur->next = db->next;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
82 db->next = cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
83
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
84 /* this is a presence from a resource, make an entry for just the user */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
85 if(id->user != NULL && id->resource != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
86 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
87 /* modify the id to just user@host */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
88 res = id->resource;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
89 jid_set(id,NULL,JID_RESOURCE);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
90 curu = _ppdb_get(db,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
91
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
92 /* no user entry, make one */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
93 if(curu == NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
94 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
95 curu = _ppdb_new(db->p,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
96 curu->next = db->next;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
97 db->next = curu;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
98 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
99
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
100 /* restore the id */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
101 jid_set(id,res,JID_RESOURCE);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
102
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
103 /* insert this resource into the user list */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
104 cur->user = curu->user;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
105 curu->user = cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
106 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
107
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
108 return db;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
109 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
110
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
111 xmlnode ppdb_primary(ppdb db, jid id)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
112 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
113 ppdb cur, top;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
114
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
115 if(db == NULL || id == NULL) return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
116
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
117 cur = _ppdb_get(db,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
118
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
119 if(cur == NULL) return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
120
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
121 /* not user@host check, just return */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
122 if(id->user == NULL || id->resource != NULL) return cur->x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
123
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
124 top = cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
125 for(cur = cur->user; cur != NULL; cur = cur->user)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
126 if(cur->pri >= top->pri) top = cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
127
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
128 if(top != NULL && top->pri >= 0) return top->x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
129
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
130 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
131 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
132
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
133 /* return the presence for the id, successive calls return all of the known resources for a user@host address */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
134 xmlnode ppdb_get(ppdb db, jid id)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
135 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
136 static ppdb last = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
137 ppdb cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
138
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
139 if(db == NULL || id == NULL) return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
140
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
141 /* MODE: if this is NOT just user@host addy, return just the single entry */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
142 if(id->user == NULL || id->resource != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
143 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
144 /* we were just here, return now */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
145 if(last != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
146 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
147 last = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
148 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
149 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
150
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
151 last = _ppdb_get(db,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
152 if(last != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
153 return last->x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
154 else
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
155 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
156 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
157
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
158 /* handle looping for user@host */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
159
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
160 /* we're already in the loop */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
161 if(last != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
162 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
163 /* this is the last entry in the list */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
164 if(last->user == NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
165 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
166 last = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
167 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
168 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
169
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
170 last = last->user;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
171 return last->x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
172 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
173
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
174 /* start a new loop */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
175 cur = _ppdb_get(db,id);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
176
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
177 if(cur == NULL) return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
178
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
179 last = cur->user;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
180 if(last != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
181 return last->x;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
182 else
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
183 return NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
184 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
185
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
186
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
187 void ppdb_free(ppdb db)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
188 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
189 ppdb cur;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
190
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
191 if(db == NULL) return;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
192
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
193 for(cur = db; cur != NULL; cur = cur->next)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
194 xmlnode_free(cur->x);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
195
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
196 pool_free(db->p);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
197 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
198