diff options
author | rsc <devnull@localhost> | 2006-02-26 15:20:28 +0000 |
---|---|---|
committer | rsc <devnull@localhost> | 2006-02-26 15:20:28 +0000 |
commit | d4baecd94dfbfc13dc3e4583d39ab194667e698f (patch) | |
tree | 1fe04acd0f73f651a0b03e65e4e35810bdb8f9f3 /src/cmd/upas | |
parent | eb0e8f26c4e6a3b4a4780132f2270efa530ad816 (diff) | |
download | plan9port-d4baecd94dfbfc13dc3e4583d39ab194667e698f.tar.gz plan9port-d4baecd94dfbfc13dc3e4583d39ab194667e698f.tar.bz2 plan9port-d4baecd94dfbfc13dc3e4583d39ab194667e698f.zip |
various fixes
Diffstat (limited to 'src/cmd/upas')
-rw-r--r-- | src/cmd/upas/ned/nedmail.c | 26 |
1 files changed, 17 insertions, 9 deletions
diff --git a/src/cmd/upas/ned/nedmail.c b/src/cmd/upas/ned/nedmail.c index e4fce08a..c6ca2f28 100644 --- a/src/cmd/upas/ned/nedmail.c +++ b/src/cmd/upas/ned/nedmail.c @@ -237,7 +237,6 @@ threadmain(int argc, char **argv) cflag = 1; break; case 'f': - sysfatal("-f not available"); file = EARGF(usage()); break; case 's': @@ -490,7 +489,6 @@ dir2message(Message *parent, int reverse) highest = last->fileno; n = fsdirreadall(fd, &d); - fprint(2,"read %d messages\n", n); for(i = 0; i < n; i++){ if((d[i].qid.type & QTDIR) == 0) continue; @@ -1515,16 +1513,22 @@ pcmd(Cmd *x, Message *m) void printpartindented(String *s, char *part, char *indent) { + int fd; char *p; String *path; Biobuf *b; - fprint(2,"printpartindented: fixme\n"); path = extendpath(s, part); - b = Bopen(s_to_c(path), OREAD); + fd = fsopenfd(mailfs, s_to_c(path), OREAD); s_free(path); - if(b == nil){ - fprint(2, "!message dissappeared\n"); + if(fd < 0){ + fprint(2, "!message disappeared\n"); + return; + } + b = Bfdopen(fd, OREAD); + if(b == 0){ + fprint(2, "out of memory\n"); + close(fd); return; } while((p = Brdline(b, '\n')) != nil){ @@ -2358,6 +2362,7 @@ xpipecmd(Cmd *c, Message *m, char *part) path = extendpath(m->path, part); fd = fsopenfd(mailfs, s_to_c(path), OREAD); s_free(path); + if(fd < 0){ // compatibility with older upas/fs path = extendpath(m->path, "raw"); fd = fsopenfd(mailfs, s_to_c(path), OREAD); @@ -2421,7 +2426,7 @@ switchmb(char *file, char *singleton) // if the user didn't say anything and there // is an mbox mounted already, use that one // so that the upas/fs -fdefault default is honored. - if(file || (singleton && fsaccess(mailfs, singleton, 0) < 0)){ + if(0 && (file || (singleton && fsaccess(mailfs, singleton, 0) < 0))){ /* XXX all wrong */ fprint(2, "file=%s singleton=%s\n", file, singleton); if(file == nil) @@ -2491,9 +2496,12 @@ switchmb(char *file, char *singleton) path = s_reset(nil); mboxpath(mbname, user, path, 0); }else{ + if(file) + strecpy(mbname, mbname+sizeof mbname, file); + else + strcpy(mbname, "mbox"); path = s_reset(nil); - mboxpath("mbox", user, path, 0); - strcpy(mbname, "mbox"); + mboxpath(mbname, user, path, 0); } snprint(root, sizeof root, "%s", mbname); |