diff options
author | Joe Marcus Clarke <marcus@FreeBSD.org> | 2002-11-23 23:56:10 +0000 |
---|---|---|
committer | Joe Marcus Clarke <marcus@FreeBSD.org> | 2002-11-23 23:56:10 +0000 |
commit | b960828c6d1b67e8467c31dfd52f896bafd6ae19 (patch) | |
tree | a952caccd2c4b4fb11148d4d6a25735d8c9376f9 /net/gaim | |
parent | a98b4af282fb2c827477f7e3c0d546fc2296fc3b (diff) | |
download | ports-b960828c6d1b67e8467c31dfd52f896bafd6ae19.tar.gz ports-b960828c6d1b67e8467c31dfd52f896bafd6ae19.zip |
Notes
Diffstat (limited to 'net/gaim')
-rw-r--r-- | net/gaim/Makefile | 1 | ||||
-rw-r--r-- | net/gaim/files/patch-src_protocols_yahoo_yahoo.c | 49 |
2 files changed, 50 insertions, 0 deletions
diff --git a/net/gaim/Makefile b/net/gaim/Makefile index ad9091594210..2f440eb81180 100644 --- a/net/gaim/Makefile +++ b/net/gaim/Makefile @@ -7,6 +7,7 @@ PORTNAME= gaim PORTVERSION= 0.59.6 +PORTREVISION= 1 CATEGORIES?= net MASTER_SITES= ${MASTER_SITE_SOURCEFORGE} MASTER_SITE_SUBDIR= ${PORTNAME} diff --git a/net/gaim/files/patch-src_protocols_yahoo_yahoo.c b/net/gaim/files/patch-src_protocols_yahoo_yahoo.c new file mode 100644 index 000000000000..f538f5c4ba62 --- /dev/null +++ b/net/gaim/files/patch-src_protocols_yahoo_yahoo.c @@ -0,0 +1,49 @@ +This patch fixes a segfault that can occur when a Yahoo user receives new +mail. This patch is from gaim CVS, and will be integrated in the next +release. + +--- src/protocols/yahoo/yahoo.c 2002/11/12 00:50:21 1.43.2.7 ++++ src/protocols/yahoo/yahoo.c 2002/11/23 18:50:47 1.43.2.8 +@@ -259,19 +259,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); +@@ -279,6 +280,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++; + } + } + |