From bc7cb1a15a67c859c8c71c4b52bb35fe9425a63d Mon Sep 17 00:00:00 2001 From: rsc Date: Sun, 23 Nov 2003 18:04:47 +0000 Subject: new utilities. the .C files compile but are renamed to avoid building automatically. --- src/cmd/tee.c | 75 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 src/cmd/tee.c (limited to 'src/cmd/tee.c') diff --git a/src/cmd/tee.c b/src/cmd/tee.c new file mode 100644 index 00000000..83db8a08 --- /dev/null +++ b/src/cmd/tee.c @@ -0,0 +1,75 @@ +/* + * tee-- pipe fitting + */ + +#include +#include + +int uflag; +int aflag; +int openf[100]; + +char in[8192]; + +int intignore(void*, char*); + +void +main(int argc, char **argv) +{ + int i; + int r, n; + + ARGBEGIN { + case 'a': + aflag++; + break; + + case 'i': + atnotify(intignore, 1); + break; + + case 'u': + uflag++; + /* uflag is ignored and undocumented; it's a relic from Unix */ + break; + + default: + fprint(2, "usage: tee [-ai] [file ...]\n"); + exits("usage"); + } ARGEND + + USED(argc); + n = 0; + while(*argv) { + if(aflag) { + openf[n] = open(argv[0], OWRITE); + if(openf[n] < 0) + openf[n] = create(argv[0], OWRITE, 0666); + seek(openf[n], 0L, 2); + } else + openf[n] = create(argv[0], OWRITE, 0666); + if(openf[n] < 0) { + fprint(2, "tee: cannot open %s: %r\n", argv[0]); + } else + n++; + argv++; + } + openf[n++] = 1; + + for(;;) { + r = read(0, in, sizeof in); + if(r <= 0) + exits(nil); + for(i=0; i