ref: babf901b4a508c3ec5d1f89655f10377bbdf9637
dir: /appl/cmd/bind.b/
implement Bind;
include "sys.m";
sys: Sys;
include "draw.m";
Bind: module
{
init: fn(ctxt: ref Draw->Context, args: list of string);
};
stderr: ref Sys->FD;
usage()
{
sys->fprint(stderr, "usage: bind [-a|-b|-c|-ac|-bc] [-q] source target\n");
raise "fail:usage";
}
init(nil: ref Draw->Context, args: list of string)
{
sys = load Sys Sys->PATH;
stderr = sys->fildes(2);
flags := 0;
qflag := 0;
if(args != nil)
args = tl args;
while(args != nil && (a := hd args) != "" && a[0] == '-'){
args = tl args;
if(a == "--")
break;
for(o := 1; o < len a; o++)
case a[o] {
'a' =>
flags |= Sys->MAFTER;
'b' =>
flags |= Sys->MBEFORE;
'c' =>
flags |= Sys->MCREATE;
'q' =>
qflag = 1;
* =>
usage();
}
}
if(len args != 2 || flags&Sys->MAFTER && flags&Sys->MBEFORE)
usage();
f1 := hd args;
f2 := hd tl args;
if(sys->bind(f1, f2, flags) < 0){
if(qflag)
exit;
# try to improve the error message
err := sys->sprint("%r");
if(sys->stat(f1).t0 < 0)
sys->fprint(stderr, "bind: %s: %r\n", f1);
else if(sys->stat(f2).t0 < 0)
sys->fprint(stderr, "bind: %s: %r\n", f2);
else
sys->fprint(stderr, "bind: cannot bind %s onto %s: %s\n", f1, f2, err);
raise "fail:bind";
}
}