# HG changeset patch # User Christian Hammond # Date 1038049691 0 # Node ID 3fdfe787211892a7e382b191c307f20577bd1bd0 # Parent 544e48c05f61b0b19e6089b15c2608fa27681666 [gaim-migrate @ 4191] - Fixed a segfault that occurred when a key/value pair had no value (i.e., in the mail notification packets that the Yahoo server is sending out). - Skip over a garbage character in mail notification packets that's causing the sender name key/value pair to be ignored. - Some code cleanups, which should optimize it (though not noticeably so) and make it easier to read. Thanks go to ZuperDee for this. Hope this works for everybody else. committer: Tailor Script diff -r 544e48c05f61 -r 3fdfe7872118 src/protocols/yahoo/yahoo.c --- a/src/protocols/yahoo/yahoo.c Fri Nov 22 21:11:39 2002 +0000 +++ b/src/protocols/yahoo/yahoo.c Sat Nov 23 11:08:11 2002 +0000 @@ -268,19 +268,20 @@ pair->key = strtol(key, NULL, 10); accept = x; /* if x is 0 there was no key, so don't accept it */ - if (accept) + if (len - pos + 1 <= 0) { + /* Truncated. Garbage or something. */ + accept = 0; + } + + if (accept) { value = g_malloc(len - pos + 1); - x = 0; - while (pos + 1 < len) { - if (data[pos] == 0xc0 && data[pos + 1] == 0x80) - break; - if (accept) + x = 0; + while (pos + 1 < len) { + if (data[pos] == 0xc0 && data[pos + 1] == 0x80) + break; value[x++] = data[pos++]; - } - if (accept) + } value[x] = 0; - pos += 2; - if (accept) { pair->value = g_strdup(value); g_free(value); pkt->hash = g_slist_append(pkt->hash, pair); @@ -288,6 +289,11 @@ } else { g_free(pair); } + pos += 2; + + /* Skip over garbage we've noticed in the mail notifications */ + if (data[0] == '9' && data[pos] == 0x01) + pos++; } }