ref: c630a46750f449cd67ab56e6045f1e0100613362
parent: b4a91c5174ad687bc35971e2342112f975ba363c
author: qwx <[email protected]>
date: Fri Oct 28 12:43:11 EDT 2022
experimental pipeto command
--- a/cmd.c
+++ b/cmd.c
@@ -1,5 +1,6 @@
#include <u.h>
#include <libc.h>
+#include <thread.h>
#include "dat.h"
#include "fns.h"
@@ -40,10 +41,35 @@
return 0;
}
+static int epfd[2];
+
+static void
+rc(void *s)
+{
+ close(epfd[1]);
+ dup(epfd[0], 0);
+ close(epfd[0]);
+ procexecl(nil, "/bin/rc", "rc", "-c", s, nil);
+ sysfatal("procexec: %r");
+}
+
+static int
+pipeto(char *arg)
+{
+ if(pipe(epfd) < 0)
+ sysfatal("pipe: %r");
+ if(procrfork(rc, arg, mainstacksize, RFFDG|RFNOTEG|RFNAMEG) < 0)
+ sysfatal("procrfork: %r");
+ close(epfd[0]);
+ writebuf(epfd[1]);
+ close(epfd[1]);
+ return 0;
+}
+
/* the entire string is treated as the filename, ie.
* spaces and any other weird characters will be part
* of it */
-int
+static int
writeto(char *arg)
{
int r, fd;
@@ -81,16 +107,30 @@
s += n;
}
switch(r){
-// case 'd': delete(s); break;
-// case 'c': cut(s); break;
-// case 'p': paste(s); break;
-// case 'x': crop(s); break;
-// case '^': exchange(s); break;
-// case '|': pipeto(s); break;
-// case '<': pipefrom(s); break;
+// case 'd': return delete(s);
+// case 'c': return cut(s);
+// case 'p': return paste(s);
+// case 'x': return crop(s);
+// case '^': return exchange(s);
+ case '|': return pipeto(s);
+// case '<': return pipefrom(s);
case 'w': return writeto(s);
-// case 'r': readfrom(s); break;
+// case 'r': return readfrom(s);
default: werrstr("unknown command %C", r); break;
}
return -1;
+}
+
+static void
+catch(void *, char *msg)
+{
+ if(strstr(msg, "closed pipe"))
+ noted(NCONT);
+ noted(NDFLT);
+}
+
+void
+initcmd(void)
+{
+ notify(catch);
}
--- a/fns.h
+++ b/fns.h
@@ -1,4 +1,5 @@
int cmd(char*);
+void initcmd(void);
void update(void);
void setzoom(int, int);
void setpan(int);
--- a/pplay.c
+++ b/pplay.c
@@ -79,11 +79,10 @@
static char *
prompt(Rune r)
{
- int n;
static char buf[512];
snprint(buf, sizeof buf, "%C", r);
- if((n = enter(nil, buf, sizeof(buf)-UTFmax, mc, kc, _screen)) < 0)
+ if(enter(nil, buf, sizeof(buf)-UTFmax, mc, kc, _screen) < 0)
return nil;
return buf;
}
@@ -164,6 +163,7 @@
{kc->c, &r, CHANRCV},
{nil, nil, CHANEND}
};
+ initcmd();
toggleplay();
for(;;){
switch(alt(a)){