--- /n/sources/plan9/sys/include/venti.h Sat Sep 1 04:42:21 2007 +++ /sys/include/venti.h Fri Mar 23 00:00:00 2012 @@ -334,7 +334,9 @@ }; VtConn* vtconn(int infd, int outfd); +int vtreconn(VtConn*, int, int); VtConn* vtdial(char*); +int vtredial(VtConn*, char*); void vtfreeconn(VtConn*); int vtsend(VtConn*, Packet*); Packet* vtrecv(VtConn*); --- /n/sources/plan9/sys/man/2/venti-conn Sun Dec 2 23:42:21 2007 +++ /sys/man/2/venti-conn Fri Mar 23 00:00:00 2012 @@ -28,7 +28,13 @@ VtConn* vtconn(int infd, int outfd) .PP .B +int vtreconn(VtConn *z, int infd, int outfd) +.PP +.B VtConn* vtdial(char *addr) +.PP +.B +int vtredial(VtConn *z, char *addr) .PP .B int vtversion(VtConn *z) --- /n/sources/plan9/sys/src/libventi/conn.c Sat Apr 21 21:04:00 2007 +++ /sys/src/libventi/conn.c Fri Mar 23 00:00:00 2012 @@ -27,6 +27,28 @@ return z; } +int +vtreconn(VtConn *z, int infd, int outfd) +{ + NetConnInfo *nci; + + z->state = VtStateAlloc; + if(z->infd >= 0) + close(z->infd); + z->infd = infd; + if(z->outfd >= 0) + close(z->outfd); + z->outfd = outfd; + nci = getnetconninfo(nil, infd); + if(nci == nil) + snprint(z->addr, sizeof z->addr, "/dev/fd/%d", infd); + else{ + strecpy(z->addr, z->addr+sizeof z->addr, nci->raddr); + freenetconninfo(nci); + } + return 0; +} + void vtfreeconn(VtConn *z) { --- /n/sources/plan9/sys/src/libventi/dial.c Sat Apr 21 21:04:01 2007 +++ /sys/src/libventi/dial.c Fri Mar 23 00:00:00 2012 @@ -23,3 +23,21 @@ strecpy(z->addr, z->addr+sizeof z->addr, na); return z; } + +int +vtredial(VtConn *z, char *addr) +{ + char *na; + int fd; + + if(addr == nil) + addr = getenv("venti"); + if(addr == nil) + addr = "$venti"; + + na = netmkaddr(addr, "tcp", "venti"); + if((fd = dial(na, nil, nil, nil)) < 0) + return fd; + + return vtreconn(z, fd, fd); +}