Mercurial > pidgin.yaz
annotate src/protocols/msn/cmdproc.c @ 10481:bcfea6c3d5c9
[gaim-migrate @ 11769]
Patch 1093958 from Felipe Contreras. It fixes stuff.
I also made some tweaks to make valgrind a bit happier.
committer: Tailor Script <tailor@pidgin.im>
author | Stu Tomlinson <stu@nosnilmot.com> |
---|---|
date | Fri, 07 Jan 2005 02:48:33 +0000 |
parents | e5455f1dc9b6 |
children | 1a97d5e88d12 |
rev | line source |
---|---|
8810 | 1 /** |
2 * @file cmdproc.c MSN command processor functions | |
3 * | |
4 * gaim | |
5 * | |
9198
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
6 * Gaim is the legal property of its developers, whose names are too numerous |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
7 * to list here. Please refer to the COPYRIGHT file distributed with this |
ab6636c5a136
[gaim-migrate @ 9993]
Christian Hammond <chipx86@chipx86.com>
parents:
9193
diff
changeset
|
8 * source distribution. |
8810 | 9 * |
10 * This program is free software; you can redistribute it and/or modify | |
11 * it under the terms of the GNU General Public License as published by | |
12 * the Free Software Foundation; either version 2 of the License, or | |
13 * (at your option) any later version. | |
14 * | |
15 * This program is distributed in the hope that it will be useful, | |
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
18 * GNU General Public License for more details. | |
19 * | |
20 * You should have received a copy of the GNU General Public License | |
21 * along with this program; if not, write to the Free Software | |
22 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
23 */ | |
24 #include "msn.h" | |
25 #include "cmdproc.h" | |
26 | |
27 MsnCmdProc * | |
28 msn_cmdproc_new(MsnSession *session) | |
29 { | |
30 MsnCmdProc *cmdproc; | |
31 | |
32 cmdproc = g_new0(MsnCmdProc, 1); | |
33 | |
34 cmdproc->session = session; | |
35 cmdproc->txqueue = g_queue_new(); | |
36 cmdproc->history = msn_history_new(); | |
37 | |
38 return cmdproc; | |
39 } | |
40 | |
41 void | |
42 msn_cmdproc_destroy(MsnCmdProc *cmdproc) | |
43 { | |
44 MsnTransaction *trans; | |
45 | |
46 while ((trans = g_queue_pop_head(cmdproc->txqueue)) != NULL) | |
47 msn_transaction_destroy(trans); | |
48 | |
49 g_queue_free(cmdproc->txqueue); | |
50 | |
51 msn_history_destroy(cmdproc->history); | |
10481 | 52 g_free(cmdproc); |
8810 | 53 } |
54 | |
55 void | |
56 msn_cmdproc_process_queue(MsnCmdProc *cmdproc) | |
57 { | |
58 MsnTransaction *trans; | |
59 | |
10481 | 60 while ((trans = g_queue_pop_head(cmdproc->txqueue)) != NULL) |
8810 | 61 msn_cmdproc_send_trans(cmdproc, trans); |
62 } | |
63 | |
64 void | |
65 msn_cmdproc_queue_trans(MsnCmdProc *cmdproc, MsnTransaction *trans) | |
66 { | |
67 g_return_if_fail(cmdproc != NULL); | |
68 g_return_if_fail(trans != NULL); | |
69 | |
70 g_queue_push_tail(cmdproc->txqueue, trans); | |
71 } | |
72 | |
73 static void | |
74 show_debug_cmd(MsnCmdProc *cmdproc, gboolean incoming, const char *command) | |
75 { | |
76 MsnServConn *servconn; | |
77 const char *names[] = { "NS", "SB" }; | |
78 char *show; | |
79 char tmp; | |
80 size_t len; | |
81 | |
82 servconn = cmdproc->servconn; | |
83 len = strlen(command); | |
84 show = g_strdup(command); | |
85 | |
86 tmp = (incoming) ? 'S' : 'C'; | |
87 | |
88 if ((show[len - 1] == '\n') && (show[len - 2] == '\r')) | |
89 { | |
90 show[len - 2] = '\0'; | |
91 } | |
92 | |
93 gaim_debug_misc("msn", "%c: %s %03d: %s\n", tmp, | |
94 names[servconn->type], servconn->num, show); | |
95 | |
96 g_free(show); | |
97 } | |
98 | |
99 void | |
100 msn_cmdproc_send_trans(MsnCmdProc *cmdproc, MsnTransaction *trans) | |
101 { | |
102 MsnServConn *servconn; | |
103 char *data; | |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
104 size_t len; |
8810 | 105 |
106 g_return_if_fail(cmdproc != NULL); | |
107 g_return_if_fail(trans != NULL); | |
108 | |
109 servconn = cmdproc->servconn; | |
10481 | 110 |
111 if (!servconn->connected) | |
112 return; | |
113 | |
8810 | 114 msn_history_add(cmdproc->history, trans); |
115 | |
116 data = msn_transaction_to_string(trans); | |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
117 |
8810 | 118 len = strlen(data); |
119 | |
120 show_debug_cmd(cmdproc, FALSE, data); | |
121 | |
122 if (trans->callbacks == NULL) | |
123 trans->callbacks = g_hash_table_lookup(cmdproc->cbs_table->cmds, | |
124 trans->command); | |
125 | |
126 if (trans->payload != NULL) | |
127 { | |
128 data = g_realloc(data, len + trans->payload_len); | |
129 memcpy(data + len, trans->payload, trans->payload_len); | |
130 len += trans->payload_len; | |
131 } | |
132 | |
133 msn_servconn_write(servconn, data, len); | |
134 | |
135 g_free(data); | |
136 } | |
137 | |
138 void | |
139 msn_cmdproc_send_quick(MsnCmdProc *cmdproc, const char *command, | |
140 const char *format, ...) | |
141 { | |
142 MsnServConn *servconn; | |
143 char *data; | |
8830
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
144 char *params = NULL; |
8810 | 145 va_list arg; |
146 size_t len; | |
147 | |
148 g_return_if_fail(cmdproc != NULL); | |
149 g_return_if_fail(command != NULL); | |
150 | |
151 servconn = cmdproc->servconn; | |
152 | |
10481 | 153 if (!servconn->connected) |
154 return; | |
155 | |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
156 if (format != NULL) |
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
157 { |
8830
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
158 va_start(arg, format); |
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
159 params = g_strdup_vprintf(format, arg); |
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
160 va_end(arg); |
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
161 } |
8810 | 162 |
163 if (params != NULL) | |
164 data = g_strdup_printf("%s %s\r\n", command, params); | |
165 else | |
166 data = g_strdup_printf("%s\r\n", command); | |
167 | |
168 g_free(params); | |
169 | |
170 len = strlen(data); | |
171 | |
172 show_debug_cmd(cmdproc, FALSE, data); | |
173 | |
174 msn_servconn_write(servconn, data, len); | |
175 | |
176 g_free(data); | |
177 } | |
178 | |
179 void | |
180 msn_cmdproc_send(MsnCmdProc *cmdproc, const char *command, | |
181 const char *format, ...) | |
182 { | |
183 MsnTransaction *trans; | |
184 va_list arg; | |
185 | |
186 g_return_if_fail(cmdproc != NULL); | |
187 g_return_if_fail(command != NULL); | |
188 | |
10481 | 189 if (!cmdproc->servconn->connected) |
190 return; | |
191 | |
8810 | 192 trans = g_new0(MsnTransaction, 1); |
193 | |
194 trans->command = g_strdup(command); | |
195 | |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
196 if (format != NULL) |
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
197 { |
8830
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
198 va_start(arg, format); |
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
199 trans->params = g_strdup_vprintf(format, arg); |
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
200 va_end(arg); |
f8038b1f7449
[gaim-migrate @ 9594]
Christian Hammond <chipx86@chipx86.com>
parents:
8810
diff
changeset
|
201 } |
8810 | 202 |
203 msn_cmdproc_send_trans(cmdproc, trans); | |
204 } | |
205 | |
206 void | |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
207 msn_cmdproc_process_payload(MsnCmdProc *cmdproc, char *payload, |
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
208 int payload_len) |
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
209 { |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
210 MsnCommand *last; |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
211 |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
212 g_return_if_fail(cmdproc != NULL); |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
213 |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
214 last = cmdproc->last_cmd; |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
215 last->payload = g_memdup(payload, payload_len); |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
216 last->payload_len = payload_len; |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
217 |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
218 if (last->payload_cb != NULL) |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
219 last->payload_cb(cmdproc, last, payload, payload_len); |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
220 } |
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
221 |
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
222 void |
8810 | 223 msn_cmdproc_process_msg(MsnCmdProc *cmdproc, MsnMessage *msg) |
224 { | |
10345 | 225 MsnMsgTypeCb cb; |
8810 | 226 |
9881 | 227 if (msn_message_get_content_type(msg) == NULL) |
228 { | |
229 gaim_debug_misc("msn", "failed to find message content\n"); | |
230 return; | |
231 } | |
232 | |
8810 | 233 cb = g_hash_table_lookup(cmdproc->cbs_table->msgs, |
234 msn_message_get_content_type(msg)); | |
235 | |
236 if (cb == NULL) | |
237 { | |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
238 gaim_debug_warning("msn", "Unhandled content-type '%s'\n", |
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
239 msn_message_get_content_type(msg)); |
8810 | 240 |
241 return; | |
242 } | |
243 | |
244 cb(cmdproc, msg); | |
245 } | |
246 | |
247 void | |
248 msn_cmdproc_process_cmd(MsnCmdProc *cmdproc, MsnCommand *cmd) | |
249 { | |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
250 MsnTransCb cb = NULL; |
8810 | 251 MsnTransaction *trans = NULL; |
252 | |
253 if (cmd->trId) | |
254 trans = msn_history_find(cmdproc->history, cmd->trId); | |
255 | |
10225 | 256 if (trans != NULL) |
257 if (trans->timer) | |
258 gaim_timeout_remove(trans->timer); | |
259 | |
8810 | 260 if (g_ascii_isdigit(cmd->command[0])) |
261 { | |
262 if (trans != NULL) | |
263 { | |
264 MsnErrorCb error_cb = NULL; | |
265 int error; | |
266 | |
267 error = atoi(cmd->command); | |
10225 | 268 |
269 if (trans->error_cb != NULL) | |
270 error_cb = trans->error_cb; | |
271 | |
272 if (error_cb == NULL && cmdproc->cbs_table->errors != NULL) | |
8810 | 273 error_cb = g_hash_table_lookup(cmdproc->cbs_table->errors, trans->command); |
274 | |
275 if (error_cb != NULL) | |
10225 | 276 { |
8810 | 277 error_cb(cmdproc, trans, error); |
10225 | 278 } |
8810 | 279 else |
280 { | |
281 #if 1 | |
282 msn_error_handle(cmdproc->session, error); | |
283 #else | |
284 gaim_debug_warning("msn", "Unhandled error '%s'\n", | |
285 cmd->command); | |
286 #endif | |
287 } | |
288 | |
289 return; | |
290 } | |
291 } | |
292 | |
293 if (cmdproc->cbs_table->async != NULL) | |
294 cb = g_hash_table_lookup(cmdproc->cbs_table->async, cmd->command); | |
295 | |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
296 if (cb == NULL && trans != NULL) |
8810 | 297 { |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
298 cmd->trans = trans; |
8810 | 299 |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
300 if (trans->callbacks != NULL) |
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
301 cb = g_hash_table_lookup(trans->callbacks, cmd->command); |
8810 | 302 } |
303 | |
10043 | 304 if (cb == NULL && cmdproc->cbs_table->fallback != NULL) |
305 cb = g_hash_table_lookup(cmdproc->cbs_table->fallback, cmd->command); | |
306 | |
8810 | 307 if (cb != NULL) |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
308 { |
8810 | 309 cb(cmdproc, cmd); |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
310 } |
8810 | 311 else |
312 { | |
313 gaim_debug_warning("msn", "Unhandled command '%s'\n", | |
9158
c30d81b4dd22
[gaim-migrate @ 9942]
Christian Hammond <chipx86@chipx86.com>
parents:
8830
diff
changeset
|
314 cmd->command); |
8810 | 315 } |
316 | |
9193
502707ca1836
[gaim-migrate @ 9988]
Christian Hammond <chipx86@chipx86.com>
parents:
9158
diff
changeset
|
317 if (trans != NULL && trans->pendent_cmd != NULL) |
10481 | 318 msn_transaction_unqueue_cmd(trans, cmdproc); |
8810 | 319 } |
320 | |
321 void | |
322 msn_cmdproc_process_cmd_text(MsnCmdProc *cmdproc, const char *command) | |
323 { | |
324 show_debug_cmd(cmdproc, TRUE, command); | |
325 | |
326 if (cmdproc->last_cmd != NULL) | |
327 msn_command_destroy(cmdproc->last_cmd); | |
328 | |
329 cmdproc->last_cmd = msn_command_from_string(command); | |
330 | |
331 msn_cmdproc_process_cmd(cmdproc, cmdproc->last_cmd); | |
332 } |