diff --git a/sys/src/cmd/faces/plumb.c b/sys/src/cmd/faces/plumb.c index 17d790701..b876d26b4 100644 --- a/sys/src/cmd/faces/plumb.c +++ b/sys/src/cmd/faces/plumb.c @@ -6,11 +6,9 @@ #include #include "faces.h" -static int showfd = -1; -static int seefd = -1; -static int logfd = -1; +static int showfd = -1; +static int seefd = -1; static char *user; -static char *logtag; char **maildirs; int nmaildirs; @@ -18,20 +16,10 @@ int nmaildirs; void initplumb(void) { - showfd = plumbopen("send", OWRITE); - seefd = plumbopen("seemail", OREAD); - - if(seefd < 0){ - logfd = open("/sys/log/mail", OREAD); - seek(logfd, 0LL, 2); - user = getenv("user"); - if(user == nil){ - fprint(2, "faces: can't find user name: %r\n"); - exits("$user"); - } - logtag = emalloc(32+strlen(user)+1); - sprint(logtag, " delivered %s From ", user); - } + if((showfd = plumbopen("send", OWRITE)) == -1) + sysfatal("plumbopen send: %r"); + if((seefd = plumbopen("seemail", OREAD)) == -1) + sysfatal("plumbopen seemail: %r"); } void @@ -103,43 +91,6 @@ setname(Face *f, char *sender) } } -int -getc(void) -{ - static uchar buf[512]; - static int nbuf = 0; - static int i = 0; - - while(i == nbuf){ - i = 0; - nbuf = read(logfd, buf, sizeof buf); - if(nbuf == 0){ - sleep(15000); - continue; - } - if(nbuf < 0) - return -1; - } - return buf[i++]; -} - -char* -getline(char *buf, int n) -{ - int i, c; - - for(i=0; i= 0){ - m = plumbrecv(seefd); - if(m == nil) - killall("error on seemail plumb port"); - t = value(m->attr, "mailtype", ""); - if(strcmp(t, "modify") == 0) - goto Ignore; - else if(strcmp(t, "delete") == 0) - delete(m->data, value(m->attr, "digest", nil)); - else if(strcmp(t, "new") == 0) - for(i=0; idata, maildirs[i], strlen(maildirs[i])) == 0) - goto Found; - } - else - fprint(2, "faces: unknown plumb message type %s\n", t); - Ignore: + m = plumbrecv(seefd); + if(m == nil) + killall("error on seemail plumb port"); + t = value(m->attr, "mailtype", ""); + if(strcmp(t, "modify") == 0) + goto Ignore; + else if(strcmp(t, "delete") == 0) + delete(m->data, value(m->attr, "digest", nil)); + else if(strcmp(t, "new") == 0) + for(i=0; idata, maildirs[i], strlen(maildirs[i])) == 0) + goto Found; + } + else + fprint(2, "faces: unknown plumb message type %s\n", t); + Ignore: + plumbfree(m); + continue; + + Found: + xtime = parsedate(value(m->attr, "date", date)); + digestp = value(m->attr, "digest", nil); + if(alreadyseen(digestp)){ + /* duplicate upas/fs can send duplicate messages */ plumbfree(m); continue; - - Found: - xtime = parsedate(value(m->attr, "date", date)); - digestp = value(m->attr, "digest", nil); - if(alreadyseen(digestp)){ - /* duplicate upas/fs can send duplicate messages */ - plumbfree(m); - continue; - } - senderp = estrdup(value(m->attr, "sender", "???")); - showmailp = estrdup(m->data); - if(digestp) - digestp = estrdup(digestp); - plumbfree(m); - }else{ - if(logrecv(&senderp, &xtime) <= 0) - killall("error reading log file"); - showmailp = estrdup(""); - digestp = nil; } + senderp = estrdup(value(m->attr, "sender", "???")); + showmailp = estrdup(m->data); + if(digestp) + digestp = estrdup(digestp); + plumbfree(m); setname(f, senderp); f->time = xtime; f->tm = *localtime(xtime);