Mercurial > pidgin
annotate src/protocols/zephyr/ZRecvNot.c @ 13905:4e44ecb866bd
[gaim-migrate @ 16394]
msn_session_sync_users() iterates over the buddy list, following the ->next pointers of the groups, contacts, and buddies. msn_show_sync_issue(), if called, removed the buddy for which it was called, in preparation for the buddy either being added to the server list or confirmed-to-be-removed. This could lead to the buddy pointer being released and ->next therefore being junk.
The buddy is now not removed until the user responds to the action dialog presented via msn_show_sync_issue(). I'm unclear why gtkgaim got away with this exercise in memory stomping but Adium/libgaim crashed every time, but it's safer in any case.
I also changed some foo->bar to gaim_foo_get_bar().
committer: Tailor Script <tailor@pidgin.im>
| author | Evan Schoenberg <evan.s@dreskin.net> |
|---|---|
| date | Sun, 02 Jul 2006 09:37:25 +0000 |
| parents | 64895571248f |
| children |
| rev | line source |
|---|---|
| 2086 | 1 /* This file is part of the Project Athena Zephyr Notification System. |
| 2 * It contains source for ZReceiveNotice function. | |
| 3 * | |
| 4 * Created by: Robert French | |
| 5 * | |
| 6 * Copyright (c) 1987,1988 by the Massachusetts Institute of Technology. | |
| 7 * For copying and distribution information, see the file | |
| 8 * "mit-copyright.h". | |
| 9 */ | |
| 10 | |
|
8792
43d6c08d7e96
[gaim-migrate @ 9554]
Christian Hammond <chipx86@chipx86.com>
parents:
2086
diff
changeset
|
11 #include "internal.h" |
| 2086 | 12 |
| 13 Code_t ZReceiveNotice(notice, from) | |
| 14 ZNotice_t *notice; | |
| 15 struct sockaddr_in *from; | |
| 16 { | |
| 17 char *buffer; | |
| 18 struct _Z_InputQ *nextq; | |
| 19 int len, auth; | |
| 20 Code_t retval; | |
| 21 | |
| 22 if ((retval = Z_WaitForComplete()) != ZERR_NONE) | |
| 23 return (retval); | |
| 24 | |
| 25 nextq = Z_GetFirstComplete(); | |
| 26 | |
| 10690 | 27 if (!nextq) |
| 28 return (ENOMEM); | |
| 29 | |
| 2086 | 30 len = nextq->packet_len; |
| 31 | |
| 32 if (!(buffer = (char *) malloc((unsigned) len))) | |
| 33 return (ENOMEM); | |
| 34 | |
| 35 if (from) | |
| 36 *from = nextq->from; | |
| 37 | |
| 38 (void) memcpy(buffer, nextq->packet, len); | |
| 39 | |
| 40 auth = nextq->auth; | |
| 41 Z_RemQueue(nextq); | |
| 42 | |
| 43 if ((retval = ZParseNotice(buffer, len, notice)) != ZERR_NONE) | |
| 44 return (retval); | |
| 45 notice->z_checked_auth = auth; | |
| 46 return ZERR_NONE; | |
| 47 } |
