X-Git-Url: https://jasonwoof.com/gitweb/?p=dwm.git;a=blobdiff_plain;f=util.c;h=76ba5abb45eb5f502a4ed3f31672ff1402c369d2;hp=435069f9903703412fe2edfc3514058d01014959;hb=b1669b5c48f71c9a7a919dbf09a1af527c62f69a;hpb=439e15d09f6fa9271d3b49ef97194f0c80ebe161 diff --git a/util.c b/util.c index 435069f..76ba5ab 100644 --- a/util.c +++ b/util.c @@ -82,19 +82,59 @@ swap(void **p1, void **p2) } void -spawn(Display *dpy, const char *shell, const char *cmd) +spawn(Display *dpy, char *argv[]) { - if(!cmd || !shell) + if(!argv || !argv[0]) return; if(fork() == 0) { if(fork() == 0) { if(dpy) close(ConnectionNumber(dpy)); - execl(shell, shell, "-c", cmd, (const char *)0); - fprintf(stderr, "gridwm: execl %s", shell); + setsid(); + execvp(argv[0], argv); + fprintf(stderr, "gridwm: execvp %s", argv[0]); perror(" failed"); } exit (0); } wait(0); } + +void +pipe_spawn(char *buf, unsigned int len, Display *dpy, char *argv[]) +{ + unsigned int l, n; + int pfd[2]; + + if(!argv || !argv[0]) + return; + + if(pipe(pfd) == -1) { + perror("pipe"); + exit(1); + } + + if(fork() == 0) { + if(dpy) + close(ConnectionNumber(dpy)); + setsid(); + dup2(pfd[1], STDOUT_FILENO); + close(pfd[0]); + close(pfd[1]); + execvp(argv[0], argv); + fprintf(stderr, "gridwm: execvp %s", argv[0]); + perror(" failed"); + } + else { + n = 0; + close(pfd[1]); + while(l > n) { + if((l = read(pfd[0], buf + n, len - n)) < 1) + break; + n += l; + } + close(pfd[0]); + buf[n - 1] = 0; + } + wait(0); +}