commit 53af1186ca6d4e0560837ed19535ca38a6069201 from: rsc date: Sat May 06 22:53:44 2006 UTC show full name in from commit - 95d412d4bca1e7855818e09ee5afa260e6356504 commit + 53af1186ca6d4e0560837ed19535ca38a6069201 blob - a83216491ed2d3c5d9e6896050b7788d630730b8 blob + 4b5c23c75e4228ccfa8c55198cbf5ce58cc47d6e --- src/cmd/acme/mail/dat.h +++ src/cmd/acme/mail/dat.h @@ -65,6 +65,7 @@ struct Message /* header info */ char *from; + char *fromcolon; char *to; char *cc; char *replyto; blob - 1ba19c24768eca80ed6637ed041820a53fcede0c blob + 8e8443bea9d1b51fe0d686945d10ab2a390defd2 --- src/cmd/acme/mail/mesg.c +++ src/cmd/acme/mail/mesg.c @@ -80,7 +80,7 @@ line(char *data, char **pp) } static char* -mkaddrs(char *t) +mkaddrs(char *t, char **colon) { int i, nf, inquote; char **f, *s; @@ -96,14 +96,23 @@ mkaddrs(char *t) } f = emalloc(nf*sizeof f[0]); nf = tokenize(t, f, nf); + if(colon){ + fmtstrinit(&fmt); + for(i=0; i+1 0) + fmtprint(&fmt, ", "); + if(f[i][0] == 0 || strcmp(f[i], f[i+1]) == 0) + fmtprint(&fmt, "%s", f[i+1]); + else + fmtprint(&fmt, "%s <%s>", f[i], f[i+1]); + } + *colon = fmtstrflush(&fmt); + } fmtstrinit(&fmt); for(i=0; i+1 0) fmtprint(&fmt, ", "); - /* if(f[i][0] == 0 || strcmp(f[i], f[i+1]) == 0) */ - fmtprint(&fmt, "%s", f[i+1]); - /* else */ - /* fmtprint(&fmt, "%s <%s>", f[i], f[i+1]); */ + fmtprint(&fmt, "%s", f[i+1]); } free(f); return fmtstrflush(&fmt); @@ -127,19 +136,19 @@ loadinfo(Message *m, char *dir) *t++ = 0; if(strcmp(s, "from") == 0){ free(m->from); - m->from = mkaddrs(t); + m->from = mkaddrs(t, &m->fromcolon); }else if(strcmp(s, "sender") == 0){ free(m->sender); - m->sender = mkaddrs(t); + m->sender = mkaddrs(t, nil); }else if(strcmp(s, "to") == 0){ free(m->to); - m->to = mkaddrs(t); + m->to = mkaddrs(t, nil); }else if(strcmp(s, "cc") == 0){ free(m->cc); - m->cc = mkaddrs(t); + m->cc = mkaddrs(t, nil); }else if(strcmp(s, "replyto") == 0){ free(m->replyto); - m->replyto = mkaddrs(t); + m->replyto = mkaddrs(t, nil); }else if(strcmp(s, "subject") == 0){ free(m->subject); m->subject = estrdup(t); @@ -369,7 +378,7 @@ info(Message *m, int ind, int ogf) if (ogf) p=m->to; else - p=m->from; + p=m->fromcolon; if(ind==0 && shortmenu){ len = 30;