X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=uip%2Fpicksbr.c;h=91893e3cbf89f71138e39b0405d785bddf51a94b;hb=80bf776d0a4587c477bb8a248b9dbe1a31e74575;hp=26401f4841d92d808a9d484debe9ce866655f2fe;hpb=f311d0371d3585ad4f97a69de9669dd49197686a;p=mmh diff --git a/uip/picksbr.c b/uip/picksbr.c index 26401f4..91893e3 100644 --- a/uip/picksbr.c +++ b/uip/picksbr.c @@ -78,9 +78,10 @@ static struct swit parswit[] = { static char linebuf[LBSIZE + 1]; +static char decoded_linebuf[LBSIZE + 1]; /* the magic array for case-independence */ -static char cc[] = { +static unsigned char cc[] = { 0000,0001,0002,0003,0004,0005,0006,0007, 0010,0011,0012,0013,0014,0015,0016,0017, 0020,0021,0022,0023,0024,0025,0026,0027, @@ -656,12 +657,11 @@ static int GREPaction (params) plist { - NMH_UNUSED (msgnum); - int c, body, lf; long pos = start; register char *p1, *p2, *ebp, *cbp; char ibuf[BUFSIZ]; + NMH_UNUSED (msgnum); fseek (fp, start, SEEK_SET); body = 0; @@ -702,7 +702,8 @@ plist break; } lf++; - c = ' '; + /* Unfold by skipping the newline. */ + c = 0; } } if (c && p1 < &linebuf[LBSIZE - 1]) @@ -714,6 +715,13 @@ plist p1 = linebuf; p2 = n->n_expbuf; + /* Attempt to decode as a MIME header. If it's the last header, + body will be 1 and lf will be at least 1. */ + if ((body == 0 || lf > 0) && + decode_rfc2047 (linebuf, decoded_linebuf, sizeof decoded_linebuf)) { + p1 = decoded_linebuf; + } + if (n->n_circf) { if (advance (p1, p2)) return 1; @@ -931,12 +939,11 @@ static int TWSaction (params) plist { - NMH_UNUSED (stop); - int state; register char *bp; char buf[BUFSIZ], name[NAMESZ]; register struct tws *tw; + NMH_UNUSED (stop); fseek (fp, start, SEEK_SET); for (state = FLD, bp = NULL;;) {