From 8ecefa411d235498ed036c6e173f62547a2e5dd4 Mon Sep 17 00:00:00 2001 From: rsc Date: Thu, 11 Aug 2005 16:45:04 +0000 Subject: Add get command. --- src/cmd/vbackup/vftp.c | 95 +++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 82 insertions(+), 13 deletions(-) (limited to 'src') diff --git a/src/cmd/vbackup/vftp.c b/src/cmd/vbackup/vftp.c index bae4b901..a5f1874d 100644 --- a/src/cmd/vbackup/vftp.c +++ b/src/cmd/vbackup/vftp.c @@ -22,7 +22,7 @@ char *cmdhelp(int, char**); char *cmdcd(int, char**); char *cmdpwd(int, char**); char *cmdls(int, char**); -char *cmdcp(int, char**); +char *cmdget(int, char**); char *cmdblock(int, char**); char *cmddisk(int, char**); @@ -38,6 +38,7 @@ Cmd cmdtab[] = { "cd", cmdcd, "cd dir - change directory", "ls", cmdls, "ls [-d] path... - list file", + "get", cmdget, "get path [lpath] - copy file to local directory", "pwd", cmdpwd, "pwd - print working directory", "help", cmdhelp, "help - print usage summaries", "block", cmdblock, "block path offset - print disk offset of path's byte offset", @@ -162,12 +163,12 @@ lsdir(char *dir, Nfs3Handle *h) cookie = 0; for(;;){ ok = fsysreaddir(fsys, auth, h, 8192, cookie, &data, &count, &eof); -fprint(2, "got %d\n", count); if(ok != Nfs3Ok){ nfs3errstr(ok); fprint(2, "ls %s: %r\n", dir); return; } +fprint(2, "got %d\n", count); p = data; ep = data+count; while(pblocksize, o, &buf, &n, &eof)) != Nfs3Ok){ + nfs3errstr(ok); + fprint(2, "reading %s: %r\n", argv[0]); + close(fd); + return nil; + } + if(write(fd, buf, n) != n){ + fprint(2, "writing %s: %r\n", local); + close(fd); + free(buf); + return nil; + } + free(buf); + } + close(fd); + fprint(2, "copied %,lld bytes\n", o); + return nil; +} + + char* cmdblock(int argc, char **argv) { @@ -334,17 +396,24 @@ threadmain(int argc, char **argv) fmtinstall('F', vtfcallfmt); fmtinstall('H', encodefmt); fmtinstall('V', vtscorefmt); - - if(vtparsescore(argv[0], nil, score) < 0) - sysfatal("bad score '%s'", argv[0]); - if((z = vtdial(nil)) == nil) - sysfatal("vtdial: %r"); - if(vtconnect(z) < 0) - sysfatal("vtconnect: %r"); - if((c = vtcachealloc(z, 16384, 32)) == nil) - sysfatal("vtcache: %r"); - if((disk = diskopenventi(c, score)) == nil) - sysfatal("diskopenventi: %r"); + + if(access(argv[0], AEXIST) >= 0 || strchr(argv[0], '/')){ + if((disk = diskopenfile(argv[0])) == nil) + sysfatal("diskopen: %r"); + if((disk = diskcache(disk, 16384, 16)) == nil) + sysfatal("diskcache: %r"); + }else{ + if(vtparsescore(argv[0], nil, score) < 0) + sysfatal("bad score '%s'", argv[0]); + if((z = vtdial(nil)) == nil) + sysfatal("vtdial: %r"); + if(vtconnect(z) < 0) + sysfatal("vtconnect: %r"); + if((c = vtcachealloc(z, 16384, 32)) == nil) + sysfatal("vtcache: %r"); + if((disk = diskopenventi(c, score)) == nil) + sysfatal("diskopenventi: %r"); + } if((fsys = fsysopen(disk)) == nil) sysfatal("ffsopen: %r"); -- cgit v1.2.3